für die Liste aller Seiten
Administratoren (Fortgeschritten), Entwickler
Mit Kochbuchrezepten ist es möglich, eigene Seitenaktionen für PmWiki zu definieren. Der korrespondierende Kode wird ausgeführt, wenn ein Parameter wie in dem folgenden Beispiel angegeben wird:
[[MyGroup/MyPage
?action=myaction]]
Mit einer solchen Aktion kann man die Anzeige und Behandlung der aktuellen Seite ändern - wie in den Standardaktionen
edit
oder print
. Oder man kann viele Wikiseiten auf einmal manipulieren oder globale Aufgabe durchführen wie das Ändern der gespeicherten Textauszeichnungen aller Seiten in dieser Gruppe (Wehe!) oder Daten sammeln aus allen Seiten im Wiki. Abhängig von seinem Kode kann es sogar egal sein, welchem Seiten-URL man die Aktion anfügt wie bei der Standardaktion phpinfo
.
Während ein Eigene Auszeichnungen vornehmlich bedeutungsvolle Textersetzungen an der aktuellen Seite vornehmen soll, wird eine Seitenaktion von einem URL-Parameter ausgelöst und kann deshalb in Verweisen als Aufruf von PHP-Funktionen eingesetzt werden, mit Wirkung auf die aktuelle Seite oder auf das ganze Wiki, wie in diesem Beispiel:
Auf jeden Fall müssen Sie sich klar darüber sein, wenn Sie PmWikis eingebaute Funtionen für angepasste Aktionen (Benutzeraktionen) nutzen wollen, dass Kochbuchrezepte in die config.php
eingefügt werden, welche früh während der Seitenbearbeitung aufgerufen wird. Das bedeutet, dass zu jenem Zeitpunkt viele Variablen der internen Funktionen (z. B. in pmwiki.php
) noch gar nicht sauber initialisiert sind. Dadurch können sich diese Funktionen unerwartet verhalten, wenn sie direkt in den eingefügten Rezeptdateien aufgerufen werden. Erinnern Sie sich, dass auch Funktionen, die für angepasste Textauszeichnungen (Custom markups) benutzt werden, immer erst später in dem Prozess aufgerufen werden — Markup()
berücksichtigt das. Analog können Sie einen Aktionsbehandler (action handler) nutzen, der PmWiki veranlasst, seinen Aktionskode zur rechten Zeit auszuführen, wenn alle internen Arbeiten erledigt sind.
Das folgende Beispiel zeigt, wie Sie eine Benutzeraktion myaction
aufsetzen können für den URL .../MyGroup/MyPage?action=myaction
. Das folgende unsinnige, aber instruktive, Beispiel wird dem Text einer anderen Seite
MyGroup.MyOtherPage
ein 'x' voranstellen. Dann wird die Seite MyGroup.MyPage
, die in dem URL steht, angezeigt.
$HandleActions['myaction'] = 'HandleMyAction'; # Wenn der URL 'action=myaction' enthält,
# rufe HandleMyAction zur rechen Zeit auf
$HandleAuth['myaction'] = 'admin'; # Autorisierungsebene $auth für HandleMyAction
function HandleMyAction($pagename, $auth) { # Parameter (Signatur) der Handler-Funktion, die PmWiki erwartet
global $Author; # aktuellen Benutzernamen behalten, z. B. für Seitenverlauf
$old = RetrieveAuthPage('MyGroup.MyOtherPage', $auth); # Alle Informationen der Seite MyGroup.MyOtherPage holen
$new = $old; # die Seiteninformationen, die unverändert bleiben,
# kopieren (z. B. Seitenverlauf)
$new['text'] = "x".$old['text']; # ... etwas am alten Text manipulieren
$Author='myactionbot'; # Autorname, der im Seitenverlauf für diese Manipulation
# eingetragen werden soll
$pn='MyGroup.MyOtherPage'; # nötig, weil UpdatePage nur mit Variablen (by reference)
# als Parameter aufgerufen werden darf
UpdatePage($pn,$old,$new); # ändere die aktuelle Wikiseite
HandleBrowse($pagename); # zeige die in dem URL angegebene Seite (z. B. MyGroup.MyPage) an
}
Anmerkungen:
Kategorie: PmWiki Developer
für die Liste aller Seiten