about summary refs log tree commit diff stats
path: root/apidocs/c/profhooks.h
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2016-07-30 23:00:45 +0100
committerJames Booth <boothj5@gmail.com>2016-07-30 23:00:45 +0100
commit43b1d7f7cd4e753effe3c15f0724798077638ff3 (patch)
treef4926506e1abe5ac50463712f84be1661157c3ec /apidocs/c/profhooks.h
parent9603e04e346d2981a9c1e7ca9a17cf0cdb230954 (diff)
downloadprofani-tty-43b1d7f7cd4e753effe3c15f0724798077638ff3.tar.gz
Update plugins API docs
Diffstat (limited to 'apidocs/c/profhooks.h')
-rw-r--r--apidocs/c/profhooks.h208
1 files changed, 148 insertions, 60 deletions
diff --git a/apidocs/c/profhooks.h b/apidocs/c/profhooks.h
index 039abacc..78f77291 100644
--- a/apidocs/c/profhooks.h
+++ b/apidocs/c/profhooks.h
@@ -3,128 +3,216 @@ C Hooks.
 */
 
 /**
-Called when profanity loads the plugin
-@param version The version of profanity as a string e.g. "0.5.0"
-@param status The build status, either "development" or "release"
+Called when a plugin is loaded, either when profanity is started, or when the /plugins load or /plugins install commands are called
+@param version the version of Profanity
+@param status the package status of Profanity, "development" or "release"
+@param account_name account name of the currently logged in account, or NULL if not logged in
+@param fulljid the users full Jabber ID (barejid and resource) if logged in, NULL otherwise
 */
-void prof_init(const char * const version, const char * const status);
+void prof_init(const char * const version, const char * const status, const char *const account_name, const char *const fulljid);
 
 /**
-Called when profanity starts, after {@link prof_init}
+Called when Profanity is started
 */
 void prof_on_start(void);
 
 /**
-Called when profanity shuts down
+Called when the user quits Profanity
 */
 void prof_on_shutdown(void);
 
 /**
-Called when an account is connected
-@param account_name The name of the account
-@param fulljid The full JID of the account
+Called when a plugin is unloaded with the /plugins unload command
+*/
+void prof_on_unload(void);
+
+/**
+Called when the user connects with an account
+@param account_name account name of the account used for logging in
+@param fulljid the full Jabber ID (barejid and resource) of the account
 */
 void prof_on_connect(const char * const account_name, const char * const fulljid);
 
 /**
-Called when an account is disconnected
-@param account_name The name of the account
-@param fulljid The full JID of the account
+Called when the user disconnects an account
+@param account_name account name of the account being disconnected
+@param fulljid the full Jabber ID (barejid and resource) of the account
 */
 void prof_on_disconnect(const char * const account_name, const char * const fulljid);
 
 /**
-Called before a regular chat message is displayed
-@param jid The JID of the sender
-@param message The message received
-@return The new message, or NULL if no change made to the message
+Called before a chat message is displayed
+@param barejid Jabber ID of the message sender
+@param message the received message
+@return the new message to display, or NULL to preserve the original message 
 */
 char* prof_pre_chat_message_display(const char * const jid, const char *message);
 
 /**
-Called after a regular chat message is displayed
-@param jid The JID of the sender
-@param message The message received
+Called after a chat message is displayed
+@param barejid Jabber ID of the message sender
+@param message the received message
 */
 void prof_post_chat_message_display(const char * const jid, const char *message);
 
 /**
-Called before a regular chat message is sent
-@param jid The JID of the recipient
-@param message The message to send
-@return The new message, or NULL if no change made to the message
+Called before a chat message is sent
+@param barejid Jabber ID of the message recipient
+@param message the message to be sent
+@return the new message to send, or NULL to preserve the original message 
 */
 char* prof_pre_chat_message_send(const char * const jid, const char *message);
 
 /**
-Called after a regular chat message is sent
-@param jid The JID of the recipient
-@param message The message sent
+Called after a chat message has been sent
+@param barejid Jabber ID of the message recipient
+@param message the sent message
 */
 void prof_post_chat_message_send(const char * const jid, const char *message);
 
 /**
-Called before a MUC message is displayed
-@param room The JID of the room
-@param nick The nickname of the sender
-@param message The message received
-@return The new message, or NULL if no change made to the message
+Called before a chat room message is displayed
+@param room Jabber ID of the room
+@param nick nickname of message sender
+@param message the received message
+@return the new message to display, or NULL to preserve the original message 
 */
 char* prof_pre_room_message_display(const char * const room, const char * const nick, const char *message);
 
 /**
-Called after a MUC message is displayed
-@param room The JID of the room
-@param nick The nickname of the sender
-@param message The message received
+Called after a chat room message is displayed
+@param room Jabber ID of the room
+@param nick nickname of the message sender 
+@param message the received message
 */
 void prof_post_room_message_display(const char * const room, const char * const nick, const char *message);
 
 /**
-Called before a MUC message is sent
-@param room The JID of the room
-@param message The message to send
-@return The new message, or NULL if no change made to the message
+Called before a chat room message is sent
+@param room Jabber ID of the room
+@param message the message to be sent
+@return the new message to send, or NULL to preserve the original message 
 */
 char* prof_pre_room_message_send(const char * const room, const char *message);
 
 /**
-Called after a MUC message is sent
-@param room The JID of the room
-@param message The message sent
+Called after a chat room message has been sent
+@param room Jabber ID of the room
+@param message the sent message
 */
 void prof_post_room_message_send(const char * const room, const char *message);
 
 /**
-Called before a MUC private message is displayed
-@param room The JID of the room
-@param nick The nickname of the sender
-@param message The message received
-@return The new message, or NULL if no change made to the message
+Called when the server sends a chat room history message
+@param room Jabber ID of the room
+@param nick nickname of the message sender
+@param message the message to be sent
+@param timestamp time the message was originally sent to the room, in ISO8601 format
+*/
+void prof_on_room_history_message(const char * const room, const char *const nick, const char *const message, const char *const timestamp);
+
+/**
+Called before a private chat room message is displayed
+@param room Jabber ID of the room
+@param nick nickname of message sender
+@param message the received message
+@return the new message to display, or NULL to preserve the original message 
 */
 char* prof_pre_priv_message_display(const char * const room, const char * const nick, const char *message);
 
 /**
-Called after a MUC private message is displayed
-@param room The JID of the room
-@param nick The nickname of the sender
-@param message The message received
+Called after a private chat room message is displayed
+@param room Jabber ID of the room
+@param nick nickname of the message sender 
+@param message the received message
 */
 void prof_post_priv_message_display(const char * const room, const char * const nick, const char *message);
 
 /**
-Called before a MUC private message is sent
-@param room The JID of the room
-@param nick The nickname of the recipient
-@param message The message to send
-@return The new message, or NULL if no change made to the message
+Called before a private chat room message is sent
+@param room Jabber ID of the room
+@param nick nickname of message recipient
+@param message the message to be sent
+@return the new message to send, or NULL to preserve the original message 
 */
 char* prof_pre_priv_message_send(const char * const room, const char * const nick, const char *message);
 
 /**
-Called after a MUC private message is sent
-@param room The JID of the room
-@param nick The nickname of the recipient
-@param message The message sent
+Called after a private chat room message has been sent
+@param room Jabber ID of the room
+@param nick nickname of the message recipient
+@param message the sent message
 */
 void prof_post_priv_message_send(const char * const room, const char * const nick, const char *message);
+
+/**
+Called before an XMPP message stanza is sent
+@param stanza The stanza to send
+@return The new stanza to send, or NULL to preserve the original stanza
+*/
+char* prof_on_message_stanza_send(const char *const stanza);
+
+/**
+Called when an XMPP message stanza is received
+@param stanza The stanza received
+@return 1 if Profanity should continue to process the message stanza, 0 otherwise
+*/
+int prof_on_message_stanza_receive(const char *const stanza);
+
+/**
+Called before an XMPP presence stanza is sent
+@param stanza The stanza to send
+@return The new stanza to send, or NULL to preserve the original stanza
+*/
+char* prof_on_presence_stanza_send(const char *const stanza);
+
+/**
+Called when an XMPP presence stanza is received
+@param stanza The stanza received
+@return 1 if Profanity should continue to process the presence stanza, 0 otherwise
+*/
+int prof_on_presence_stanza_receive(const char *const stanza);
+
+/**
+Called before an XMPP iq stanza is sent
+@param stanza The stanza to send
+@return The new stanza to send, or NULL to preserve the original stanza
+*/
+char* prof_on_iq_stanza_send(const char *const stanza);
+
+/**
+Called when an XMPP iq stanza is received
+@param stanza The stanza received
+@return 1 if Profanity should continue to process the iq stanza, 0 otherwise
+*/
+int prof_on_iq_stanza_receive(const char *const stanza);
+
+/**
+Called when a contact goes offline
+@param barejid Jabber ID of the contact
+@param resource the resource being disconnected
+@param status the status message received with the offline presence, or NULL
+*/
+void prof_on_contact_offline(const char *const barejid, const char *const resource, const char *const status);
+
+/**
+Called when a presence notification is received from a contact
+@param barejid Jabber ID of the contact
+@param resource the resource being disconnected
+@param presence presence of the contact, one of "chat", "online", "away", "xa" or "dnd"
+@param status the status message received with the presence, or NULL
+@param priority the priority associated with the resource
+*/
+void prof_on_contact_presence(const char *const barejid, const char *const resource, const char *const presence, const char *const status, const int priority);
+
+/**
+Called when a chat window is focussed
+@param barejid Jabber ID of the chat window recipient
+*/
+void prof_on_chat_win_focus(const char *const barejid);
+
+/**
+Called when a chat room window is focussed
+@param room Jabber ID of the room
+*/
+void prof_on_room_win_focus(const char *const roomjid);