360 lines
15 KiB
Markdown
360 lines
15 KiB
Markdown
**Friendica Addon/Plugin-Entwicklung**
|
|
==============
|
|
|
|
* [Zur Startseite der Hilfe](help)
|
|
|
|
Bitte schau dir das Beispiel-Addon "randplace" für ein funktionierendes Beispiel für manche der hier aufgeführten Funktionen an.
|
|
Das Facebook-Addon bietet ein Beispiel dafür, die "addon"- und "module"-Funktion gemeinsam zu integrieren.
|
|
Addons arbeiten, indem sie Event Hooks abfangen. Module arbeiten, indem bestimmte Seitenanfragen (durch den URL-Pfad) abgefangen werden
|
|
|
|
Plugin-Namen können keine Leerstellen oder andere Interpunktionen enthalten und werden als Datei- und Funktionsnamen genutzt.
|
|
Du kannst einen lesbaren Namen im Kommentarblock eintragen.
|
|
Jedes Addon muss beides beinhalten - eine Installations- und eine Deinstallationsfunktion, die auf dem Addon-/Plugin-Namen basieren; z.B. "plugin1name_install()".
|
|
Diese beiden Funktionen haben keine Argumente und sind dafür verantwortlich, Event Hooks zu registrieren und abzumelden (unregistering), die dein Plugin benötigt.
|
|
Die Installations- und Deinstallationsfunktionfunktionen werden auch ausgeführt (z.B. neu installiert), wenn sich das Plugin nach der Installation ändert - somit sollte deine Deinstallationsfunktion keine Daten zerstört und deine Installationsfunktion sollte bestehende Daten berücksichtigen.
|
|
Zukünftige Extensions werden möglicherweise "Setup" und "Entfernen" anbieten.
|
|
|
|
Plugins sollten einen Kommentarblock mit den folgenden vier Parametern enthalten:
|
|
|
|
/*
|
|
* Name: My Great Plugin
|
|
* Description: This is what my plugin does. It's really cool
|
|
* Version: 1.0
|
|
* Author: John Q. Public <john@myfriendicasite.com>
|
|
*/
|
|
|
|
Registriere deine Plugin-Hooks während der Installation.
|
|
|
|
register_hook($hookname, $file, $function);
|
|
|
|
$hookname ist ein String und entspricht einem bekannten Friendica-Hook.
|
|
|
|
$file steht für den Pfadnamen, der relativ zum Top-Level-Friendicaverzeichnis liegt.
|
|
Das *sollte* "addon/plugin_name/plugin_name.php' sein.
|
|
|
|
$function ist ein String und der Name der Funktion, die ausgeführt wird, wenn der Hook aufgerufen wird.
|
|
|
|
Deine Hook-Callback-Funktion wird mit mindestens einem und bis zu zwei Argumenten aufgerufen
|
|
|
|
function myhook_function(&$a, &$b) {
|
|
|
|
}
|
|
|
|
Wenn du Änderungen an den aufgerufenen Daten vornehmen willst, musst du diese als Referenzvariable (mit "&") während der Funktionsdeklaration deklarieren.
|
|
|
|
$a ist die Friendica "App"-Klasse, die eine Menge an Informationen über den aktuellen Friendica-Status beinhaltet, u.a. welche Module genutzt werden, Konfigurationsinformationen, Inhalte der Seite zum Zeitpunkt des Hook-Aufrufs.
|
|
Es ist empfohlen, diese Funktion "$a" zu nennen, um seine Nutzung an den Gebrauch an anderer Stelle anzugleichen.
|
|
|
|
$b kann frei benannt werden.
|
|
Diese Information ist speziell auf den Hook bezogen, der aktuell bearbeitet wird, und beinhaltet normalerweise Daten, die du sofort nutzen, anzeigen oder bearbeiten kannst.
|
|
Achte darauf, diese mit "&" zu deklarieren, wenn du sie bearbeiten willst.
|
|
|
|
|
|
**Module**
|
|
|
|
Plugins/Addons können auch als "Module" agieren und alle Seitenanfragen für eine bestimte URL abfangen.
|
|
Um ein Plugin als Modul zu nutzen, ist es nötig, die Funktion "plugin_name_module()" zu definieren, die keine Argumente benötigt und nichts weiter machen muss.
|
|
|
|
Wenn diese Funktion existiert, wirst du nun alle Seitenanfragen für "http://my.web.site/plugin_name" erhalten - mit allen URL-Komponenten als zusätzliche Argumente.
|
|
Diese werden in ein Array $a->argv geparst und stimmen mit $a->argc überein, wobei sie die Anzahl der URL-Komponenten abbilden.
|
|
So würde http://my.web.site/plugin/arg1/arg2 nach einem Modul "plugin" suchen und seiner Modulfunktion die $a-App-Strukur übergeben (dies ist für viele Komponenten verfügbar). Das umfasst:
|
|
|
|
$a->argc = 3
|
|
$a->argv = array(0 => 'plugin', 1 => 'arg1', 2 => 'arg2');
|
|
|
|
Deine Modulfunktionen umfassen oft die Funktion plugin_name_content(&$a), welche den Seiteninhalt definiert und zurückgibt.
|
|
Sie können auch plugin_name_post(&$a) umfassen, welches vor der content-Funktion aufgerufen wird und normalerweise die Resultate der POST-Formulare handhabt.
|
|
Du kannst ebenso plugin_name_init(&$a) nutzen, was oft frühzeitig aufgerufen wird und das Modul initialisert.
|
|
|
|
|
|
**Derzeitige Hooks:**
|
|
|
|
**'authenticate'** - wird aufgerufen, wenn sich der User einloggt.
|
|
$b ist ein Array
|
|
'username' => der übertragene Nutzername
|
|
'password' => das übertragene Passwort
|
|
'authenticated' => setze das auf einen anderen Wert als "0", damit der User sich authentifiziert
|
|
'user_record' => die erfolgreiche Authentifizierung muss auch einen gültigen Nutzereintrag aus der Datenbank zurückgeben
|
|
|
|
**'logged_in'** - wird aufgerufen, sobald ein Nutzer sich erfolgreich angemeldet hat.
|
|
$b beinhaltet den $a->Nutzer-Array
|
|
|
|
|
|
**'display_item'** - wird aufgerufen, wenn ein Beitrag für die Anzeige formatiert wird.
|
|
$b ist ein Array
|
|
'item' => Die Item-Details (Array), die von der Datenbank ausgegeben werden
|
|
'output' => Die HTML-Ausgabe (String) des Items, bevor es zur Seite hinzugefügt wird
|
|
|
|
**'post_local'** - wird aufgerufen, wenn der Statusbeitrag oder ein Kommentar im lokalen System eingetragen wird.
|
|
$b ist das Item-Array der Information, die in der Datenbank hinterlegt wird.
|
|
{Bitte beachte: der Seiteninhalt ist bbcode - nicht HTML)
|
|
|
|
**'post_local_end'** - wird aufgerufen, wenn ein lokaler Statusbeitrag oder Kommentar im lokalen System gespeichert wird.
|
|
$b ist das Item-Array einer Information, die gerade in der Datenbank gespeichert wurden.
|
|
{Bitte beachte: der Seiteninhalt ist bbcode - nicht HTML)
|
|
|
|
**'post_remote'** - wird aufgerufen, wenn ein Beitrag aus einer anderen Quelle empfangen wird. Dies kann auch genutzt werden, um lokale Aktivitäten oder systemgenerierte Nachrichten zu veröffentlichen/posten.
|
|
$b ist das Item-Array einer Information, die in der Datenbank und im Item gespeichert ist.
|
|
{Bitte beachte: der Seiteninhalt ist bbcode - nicht HTML)
|
|
|
|
**'settings_form'** - wird aufgerufen, wenn die HTML-Ausgabe für die Einstellungsseite generiert wird.
|
|
$b ist die HTML-Ausgabe (String) der Einstellungsseite vor dem finalen "</form>"-Tag.
|
|
|
|
**'settings_post'** - wird aufgerufen, wenn die Einstellungsseiten geladen werden.
|
|
$b ist der $_POST-Array
|
|
|
|
**'plugin_settings'** - wird aufgerufen, wenn die HTML-Ausgabe der Addon-Einstellungsseite generiert wird.
|
|
$b ist die HTML-Ausgabe (String) der Addon-Einstellungsseite vor dem finalen "</form>"-Tag.
|
|
|
|
**'plugin_settings_post'** - wird aufgerufen, wenn die Addon-Einstellungsseite geladen wird.
|
|
$b ist der $_POST-Array
|
|
|
|
**'profile_post'** - wird aufgerufen, wenn die Profilseite angezeigt wird.
|
|
$b ist der $_POST-Array
|
|
|
|
**'profile_edit'** - wird aufgerufen, bevor die Profil-Bearbeitungsseite angezeigt wird.
|
|
$b ist ein Array
|
|
'profile' => Profileintrag (Array) aus der Datenbank
|
|
'entry' => die HTML-Ausgabe (string) des generierten Eintrags
|
|
|
|
**'profile_advanced'** - wird aufgerufen, wenn die HTML-Ausgabe für das "Advanced profile" generiert wird; stimmt mit dem "Profil"-Tab auf der Profilseite der Nutzer überein.
|
|
$b ist die HTML-Ausgabe (String) des erstellten Profils
|
|
(Die Details des Profil-Arrays sind in $a->profile)
|
|
|
|
**'directory_item'** - wird von der Verzeichnisseite aufgerufen, wenn ein Item für die Anzeige formatiert wird.
|
|
$b ist ein Array
|
|
'contact' => Kontakteintrag (Array) einer Person aus der Datenbank
|
|
'entry' => die HTML-Ausgabe (String) des generierten Eintrags
|
|
|
|
**'profile_sidebar_enter'** - wird aufgerufen, bevor die Sidebar "Kurzprofil" einer Seite erstellt wird.
|
|
$b ist der Profil-Array einer Person
|
|
|
|
**'profile_sidebar'** - wird aufgerufen, wenn die Sidebar "Kurzprofil" einer Seite erstellt wird.
|
|
$b ist ein Array
|
|
'profile' => Kontakteintrag (Array) einer Person aus der Datenbank
|
|
'entry' => die HTML-Ausgabe (String) des generierten Eintrags
|
|
|
|
**'contact_block_end'** - wird aufgerufen, wenn der Block "Kontakte/Freunde" der Profil-Sidebar komplett formatiert wurde.
|
|
$b ist ein Array
|
|
'contacts' => Array von "contacts"
|
|
'output' => die HTML-Ausgabe (String) des Kontaktblocks
|
|
|
|
**'bbcode'** - wird während der Umwandlung von bbcode auf HTML aufgerufen.
|
|
$b ist der konvertierte Text (String)
|
|
|
|
**'html2bbcode'** - wird während der Umwandlung von HTML zu bbcode aufgerufen (z.B. bei Nachrichtenbeiträgen).
|
|
$b ist der konvertierte Text (String)
|
|
|
|
**'page_header'** - wird aufgerufen, nachdem der Bereich der Seitennavigation geladen wurde.
|
|
$b ist die HTML-Ausgabe (String) der "nav"-Region
|
|
|
|
**'personal_xrd'** - wird aufgerufen, bevor die Ausgabe der persönlichen XRD-Datei erzeugt wird.
|
|
$b ist ein Array
|
|
'user' => die hinterlegten Einträge der Person
|
|
'xml' => die komplette XML-Datei die ausgegeben wird
|
|
|
|
**'home_content'** - wird aufgerufen, bevor die Ausgabe des Homepage-Inhalts erstellt wird; wird nicht eingeloggten Nutzern angezeigt.
|
|
$b ist die HTML-Ausgabe (String) der Auswahlregion
|
|
|
|
**'contact_edit'** - wird aufgerufen, wenn die Kontaktdetails vom Nutzer auf der "Kontakte"-Seite bearbeitet werden.
|
|
$b ist ein Array
|
|
'contact' => Kontakteintrag (Array) des abgezielten Kontakts
|
|
'output' => die HTML-Ausgabe (String) der "Kontakt bearbeiten"-Seite
|
|
|
|
**'contact_edit_post'** - wird aufgerufen, wenn die "Kontakt bearbeiten"-Seite ausgegeben wird.
|
|
$b ist der $_POST-Array
|
|
|
|
**'init_1'** - wird aufgerufen, kurz nachdem die Datenbank vor Beginn der Sitzung geöffnet wird.
|
|
$b wird nicht genutzt
|
|
|
|
**'page_end'** - wird aufgerufen, nachdem die Funktion des HTML-Inhalts komplett abgeschlossen ist.
|
|
$b ist die HTML-Ausgabe (String) vom Inhalt-"div"
|
|
|
|
**'avatar_lookup'** - wird aufgerufen, wenn der Avatar geladen wird.
|
|
$b ist ein Array
|
|
'size' => Größe des Avatars, der geladen wird
|
|
'email' => Email-Adresse, um nach dem Avatar zu suchen
|
|
'url' => generierte URL (String) des Avatars
|
|
|
|
|
|
Eine komplette Liste aller Hook-Callbacks mit den zugehörigen Dateien (am 14-Feb-2012 generiert): Bitte schau in die Quellcodes für Details zu Hooks, die oben nicht dokumentiert sind.
|
|
|
|
boot.php: call_hooks('login_hook',$o);
|
|
|
|
boot.php: call_hooks('profile_sidebar_enter', $profile);
|
|
|
|
boot.php: call_hooks('profile_sidebar', $arr);
|
|
|
|
boot.php: call_hooks("proc_run", $arr);
|
|
|
|
include/contact_selectors.php: call_hooks('network_to_name', $nets);
|
|
|
|
include/api.php: call_hooks('logged_in', $a->user);
|
|
|
|
include/api.php: call_hooks('logged_in', $a->user);
|
|
|
|
include/queue.php: call_hooks('queue_predeliver', $a, $r);
|
|
|
|
include/queue.php: call_hooks('queue_deliver', $a, $params);
|
|
|
|
include/text.php: call_hooks('contact_block_end', $arr);
|
|
|
|
include/text.php: call_hooks('smilie', $s);
|
|
|
|
include/text.php: call_hooks('prepare_body_init', $item);
|
|
|
|
include/text.php: call_hooks('prepare_body', $prep_arr);
|
|
|
|
include/text.php: call_hooks('prepare_body_final', $prep_arr);
|
|
|
|
include/nav.php: call_hooks('page_header', $a->page['nav']);
|
|
|
|
include/auth.php: call_hooks('authenticate', $addon_auth);
|
|
|
|
include/bbcode.php: call_hooks('bbcode',$Text);
|
|
|
|
include/oauth.php: call_hooks('logged_in', $a->user);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_pre_' . $selname, $arr);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_post_' . $selname, $o);
|
|
|
|
include/acl_selectors.php: call_hooks('contact_select_options', $x);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_pre_' . $selname, $arr);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_post_' . $selname, $o);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_pre_' . $selname, $arr);
|
|
|
|
include/acl_selectors.php: call_hooks($a->module . '_post_' . $selname, $o);
|
|
|
|
include/notifier.php: call_hooks('notifier_normal',$target_item);
|
|
|
|
include/notifier.php: call_hooks('notifier_end',$target_item);
|
|
|
|
include/items.php: call_hooks('atom_feed', $atom);
|
|
|
|
include/items.php: call_hooks('atom_feed_end', $atom);
|
|
|
|
include/items.php: call_hooks('atom_feed_end', $atom);
|
|
|
|
include/items.php: call_hooks('parse_atom', $arr);
|
|
|
|
include/items.php: call_hooks('post_remote',$arr);
|
|
|
|
include/items.php: call_hooks('atom_author', $o);
|
|
|
|
include/items.php: call_hooks('atom_entry', $o);
|
|
|
|
include/bb2diaspora.php: call_hooks('bb2diaspora',$Text);
|
|
|
|
include/cronhooks.php: call_hooks('cron', $d);
|
|
|
|
include/security.php: call_hooks('logged_in', $a->user);
|
|
|
|
include/html2bbcode.php: call_hooks('html2bbcode', $text);
|
|
|
|
include/Contact.php: call_hooks('remove_user',$r[0]);
|
|
|
|
include/Contact.php: call_hooks('contact_photo_menu', $args);
|
|
|
|
include/conversation.php: call_hooks('conversation_start',$cb);
|
|
|
|
include/conversation.php: call_hooks('render_location',$locate);
|
|
|
|
include/conversation.php: call_hooks('display_item', $arr);
|
|
|
|
include/conversation.php: call_hooks('render_location',$locate);
|
|
|
|
include/conversation.php: call_hooks('display_item', $arr);
|
|
|
|
include/conversation.php: call_hooks('item_photo_menu', $args);
|
|
|
|
include/conversation.php: call_hooks('jot_tool', $jotplugins);
|
|
|
|
include/conversation.php: call_hooks('jot_networks', $jotnets);
|
|
|
|
include/plugin.php: if(! function_exists('call_hooks')) {
|
|
|
|
include/plugin.php:function call_hooks($name, &$data = null) {
|
|
|
|
index.php: call_hooks('init_1');
|
|
|
|
index.php: call_hooks('app_menu', $arr);
|
|
|
|
index.php: call_hooks('page_end', $a->page['content']);
|
|
|
|
mod/photos.php: call_hooks('photo_post_init', $_POST);
|
|
|
|
mod/photos.php: call_hooks('photo_post_file',$ret);
|
|
|
|
mod/photos.php: call_hooks('photo_post_end',$foo);
|
|
|
|
mod/photos.php: call_hooks('photo_post_end',$foo);
|
|
|
|
mod/photos.php: call_hooks('photo_post_end',$foo);
|
|
|
|
mod/photos.php: call_hooks('photo_post_end',intval($item_id));
|
|
|
|
mod/photos.php: call_hooks('photo_upload_form',$ret);
|
|
|
|
mod/friendica.php: call_hooks('about_hook', $o);
|
|
|
|
mod/editpost.php: call_hooks('jot_tool', $jotplugins);
|
|
|
|
mod/editpost.php: call_hooks('jot_networks', $jotnets);
|
|
|
|
mod/parse_url.php: call_hooks('parse_link', $arr);
|
|
|
|
mod/home.php: call_hooks('home_init',$ret);
|
|
|
|
mod/home.php: call_hooks("home_content",$o);
|
|
|
|
mod/contacts.php: call_hooks('contact_edit_post', $_POST);
|
|
|
|
mod/contacts.php: call_hooks('contact_edit', $arr);
|
|
|
|
mod/settings.php: call_hooks('plugin_settings_post', $_POST);
|
|
|
|
mod/settings.php: call_hooks('connector_settings_post', $_POST);
|
|
|
|
mod/settings.php: call_hooks('settings_post', $_POST);
|
|
|
|
mod/settings.php: call_hooks('plugin_settings', $settings_addons);
|
|
|
|
mod/settings.php: call_hooks('connector_settings', $settings_connectors);
|
|
|
|
mod/settings.php: call_hooks('settings_form',$o);
|
|
|
|
mod/register.php: call_hooks('register_account', $newuid);
|
|
|
|
mod/like.php: call_hooks('post_local_end', $arr);
|
|
|
|
mod/xrd.php: call_hooks('personal_xrd', $arr);
|
|
|
|
mod/item.php: call_hooks('post_local_start', $_REQUEST);
|
|
|
|
mod/item.php: call_hooks('post_local',$datarray);
|
|
|
|
mod/item.php: call_hooks('post_local_end', $datarray);
|
|
|
|
mod/profile.php: call_hooks('profile_advanced',$o);
|
|
|
|
mod/profiles.php: call_hooks('profile_post', $_POST);
|
|
|
|
mod/profiles.php: call_hooks('profile_edit', $arr);
|
|
|
|
mod/tagger.php: call_hooks('post_local_end', $arr);
|
|
|
|
mod/cb.php: call_hooks('cb_init');
|
|
|
|
mod/cb.php: call_hooks('cb_post', $_POST);
|
|
|
|
mod/cb.php: call_hooks('cb_afterpost');
|
|
|
|
mod/cb.php: call_hooks('cb_content', $o);
|
|
|
|
mod/directory.php: call_hooks('directory_item', $arr);
|
|
|