Fixing get_budies_online
[python-purple] / signal_cbs.pxd
index 41ff95f..b1bb26d 100644 (file)
@@ -21,44 +21,151 @@ cimport purple
 
 signal_cbs = {}
 
+cdef void signal_signed_on_cb (connection.PurpleConnection *gc, \
+                               glib.gpointer null):
+    cdef account.PurpleAccount *acc = connection.c_purple_connection_get_account(gc)
+    cdef char *c_username = NULL
+    cdef char *c_protocol_id = NULL
+
+    c_username = <char *> account.c_purple_account_get_username(acc)
+    if c_username == NULL:
+        username = None
+    else:
+        username = c_username
+
+    c_protocol_id = <char *> account.c_purple_account_get_protocol_id(acc)
+    if c_protocol_id == NULL:
+        protocol_id = None
+    else:
+        protocol_id = c_protocol_id
+
+    try:
+        (<object> signal_cbs["signed-on"])(username, protocol_id)
+    except KeyError:
+        pass
+
+cdef void signal_signed_off_cb (connection.PurpleConnection *gc, \
+                               glib.gpointer null):
+    cdef account.PurpleAccount *acc = connection.c_purple_connection_get_account(gc)
+    cdef char *c_username = NULL
+    cdef char *c_protocol_id = NULL
+
+    c_username = <char *> account.c_purple_account_get_username(acc)
+    if c_username == NULL:
+        username = None
+    else:
+        username = c_username
+
+    c_protocol_id = <char *> account.c_purple_account_get_protocol_id(acc)
+    if c_protocol_id == NULL:
+        protocol_id = None
+    else:
+        protocol_id = c_protocol_id
+
+    try:
+        (<object> signal_cbs["signed-off"])(username, protocol_id)
+    except KeyError:
+        pass
+
+cdef void signal_connection_error_cb (connection.PurpleConnection *gc, \
+        connection.PurpleConnectionError err, char *c_desc):
+
+    short_desc = {
+        0: "Network error",
+        1: "Invalid username",
+        2: "Authentication failed",
+        3: "Authentication impossible",
+        4: "No SSL support",
+        5: "Encryption error",
+        6: "Name in use",
+        7: "Invalid settings",
+        8: "SSL certificate not provided",
+        9: "SSL certificate untrusted",
+        10: "SSL certificate expired",
+        11: "SSL certificate not activated",
+        12: "SSL certificate hostname mismatch",
+        13: "SSL certificate fingerprint mismatch",
+        14: "SSL certificate self signed",
+        15: "SSL certificate other error",
+        16: "Other error" }[<int>err]
+
+    if c_desc == NULL:
+        desc = None
+    else:
+        desc = c_desc
+
+    try:
+        (<object> signal_cbs["connection-error"])(short_desc, desc)
+    except KeyError:
+        pass
+
+cdef void signal_buddy_signed_on_cb (blist.PurpleBuddy *buddy):
+    cdef char *c_name = NULL
+    cdef char *c_alias = NULL
+
+    c_name = <char *> blist.c_purple_buddy_get_name(buddy)
+    if c_name == NULL:
+        name = None
+    else:
+        name = c_name
+
+    c_alias = <char *> blist.c_purple_buddy_get_alias_only(buddy)
+    if c_alias == NULL:
+        alias = None
+    else:
+        alias = c_alias
+
+    try:
+        (<object> signal_cbs["buddy-signed-on"])(name, alias)
+    except KeyError:
+        pass
+
 cdef void signal_buddy_signed_off_cb (blist.PurpleBuddy *buddy):
-    debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "signal",
-                         "buddy_signed_off\n")
+    cdef char *c_name = NULL
+    cdef char *c_alias = NULL
+
+    c_name = <char *> blist.c_purple_buddy_get_name(buddy)
+    if c_name == NULL:
+        name = None
+    else:
+        name = c_name
 
-    if buddy.server_alias:
-        name = buddy.server_alias
+    c_alias = <char *> blist.c_purple_buddy_get_alias_only(buddy)
+    if c_alias == NULL:
+        alias = None
     else:
-        if buddy.alias:
-            name = buddy.alias
-        else:
-            name = buddy.name
+        alias = c_alias
 
     try:
-        (<object>signal_cbs["buddy_signed_off"])(name)
+        (<object> signal_cbs["buddy-signed-off"])(name, alias)
     except KeyError:
         pass
 
 cdef glib.gboolean signal_receiving_im_msg_cb (account.PurpleAccount *account,
-                                        char **sender,
-                                        char **message,
-                                        conversation.PurpleConversation *conv,
-                                        conversation.PurpleMessageFlags *flags):
-    debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "signal",
-                         "receivinv_im_msg_cb\n")
-
+        char **sender, char **message, conversation.PurpleConversation *conv,
+        conversation.PurpleMessageFlags *flags):
     cdef blist.PurpleBuddy *buddy = blist.c_purple_find_buddy(account, sender[0])
+    cdef char *c_alias = NULL
 
-    if buddy.server_alias:
-        name = buddy.server_alias
+    c_alias = <char *> blist.c_purple_buddy_get_alias_only(buddy)
+    if c_alias == NULL:
+        alias = None
     else:
-        if buddy.alias:
-            name = buddy.alias
-        else:
-            name = buddy.name
+        alias = c_alias
 
-    stripped_msg = util.c_purple_markup_strip_html(message[0])
+    stripped = util.c_purple_markup_strip_html(message[0])
 
     try:
-        return (<object>signal_cbs["receiving_im_msg"])(sender[0], name, stripped_msg)
+        return (<object> signal_cbs["receiving-im-msg"])(sender[0], alias, stripped)
     except KeyError:
         return False
+
+cdef void jabber_receiving_xmlnode_cb (connection.PurpleConnection *gc,
+        xmlnode.xmlnode **packet, glib.gpointer null):
+
+    message = xmlnode.xmlnode_to_str(packet[0], NULL)
+
+    try:
+        (<object> signal_cbs["jabber-receiving-xmlnode"])(message)
+    except KeyError:
+        pass