X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=purple.pyx;h=0005f73e3e5fd46104497ea5d039c58cb435ce4e;hp=82c6035c8c89db9090e0fa283df4de6d5c393173;hb=14e5eeb47b8ddc28b1d35fa74126e3cf18ace098;hpb=df4a5bcd4de039784ad2abbd8c82d1b934bc0203 diff --git a/purple.pyx b/purple.pyx index 82c6035..0005f73 100644 --- a/purple.pyx +++ b/purple.pyx @@ -24,9 +24,14 @@ cdef extern from "c_purple.h": import ecore -__DEFAULT_PATH__ = "/tmp" -__APP_NAME__ = "carman-purple-python" -__APP_VERSION__ = "0.1" +cdef glib.GHashTable *c_ui_info + +c_ui_info = NULL + +cdef char *c_ui_name +cdef char *c_ui_version +cdef char *c_ui_website +cdef char *c_ui_dev_website cdef account.PurpleAccountUiOps c_account_ui_ops cdef blist.PurpleBlistUiOps c_blist_ui_ops @@ -40,10 +45,6 @@ cdef notify.PurpleNotifyUiOps c_notify_ui_ops cdef request.PurpleRequestUiOps c_request_ui_ops #cdef roomlist.PurpleRoomlistUiOps c_rlist_ui_ops -cdef glib.GHashTable *c_ui_info - -c_ui_info = NULL - include "account_cbs.pxd" include "blist_cbs.pxd" include "connection_cbs.pxd" @@ -60,79 +61,94 @@ include "util.pxd" cdef class Purple: """ Purple class. - @parm debug_enabled: Toggle debug messages. - @parm app_name: Set application name. - @parm default_path: Full path for libpurple user files. + @param debug_enabled: Toggle debug messages. + @param default_path: Full path for libpurple user files. """ - cdef object __accounts + def __init__(self, ui_name, ui_version, ui_website, ui_dev_website, \ + debug_enabled=None, default_path=None): + + global c_ui_name + global c_ui_version + global c_ui_website + global c_ui_dev_website - def __init__(self, debug_enabled=True, app_name=__APP_NAME__, default_path=__DEFAULT_PATH__): - self.__accounts = {} - if app_name is not __APP_NAME__: - __APP_NAME__ = app_name + c_ui_name = ui_name + c_ui_version = ui_version + c_ui_website = ui_website + c_ui_dev_website = ui_dev_website - if default_path is not __DEFAULT_PATH__: - __DEFAULT_PATH__ = default_path + if debug_enabled: + debug.purple_debug_set_enabled(debug_enabled) - debug.c_purple_debug_set_enabled(debug_enabled) - util.c_purple_util_set_user_dir(default_path) - plugin.c_purple_plugins_add_search_path(default_path) + if default_path: + util.purple_util_set_user_dir(default_path) # adds glib iteration inside ecore main loop ecore.timer_add(0.001, self.__glib_iteration_when_idle) def destroy(self): - core.c_purple_core_quit() + core.purple_core_quit() + + def __get_ui_name(self): + global c_ui_name + return str(c_ui_name) + ui_name = property(__get_ui_name) cdef void __core_ui_ops_ui_prefs_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "ui_prefs_init\n") - prefs.c_purple_prefs_load() + debug.purple_debug_info("core_ui_ops", "%s", "ui_prefs_init\n") + prefs.purple_prefs_load() - prefs.c_purple_prefs_add_none("/carman") + prefs.purple_prefs_add_none("/carman") cdef void __core_ui_ops_debug_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "debug_ui_init\n") + debug.purple_debug_info("core_ui_ops", "%s", "debug_ui_init\n") + pass cdef void __core_ui_ops_ui_init(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "ui_init\n") - - account.c_purple_accounts_set_ui_ops(&c_account_ui_ops) - connection.c_purple_connections_set_ui_ops(&c_conn_ui_ops) - blist.c_purple_blist_set_ui_ops(&c_blist_ui_ops) - conversation.c_purple_conversations_set_ui_ops(&c_conv_ui_ops) - notify.c_purple_notify_set_ui_ops(&c_notify_ui_ops) - #privacy.c_purple_privacy_set_ui_ops(&c_privacy_ui_ops) - request.c_purple_request_set_ui_ops(&c_request_ui_ops) - #ft.c_purple_xfers_set_ui_ops(&c_ft_ui_ops) - #roomlist.c_purple_roomlist_set_ui_ops(&c_rlist_ui_ops) + debug.purple_debug_info("core_ui_ops", "%s", "ui_init\n") + + account.purple_accounts_set_ui_ops(&c_account_ui_ops) + connection.purple_connections_set_ui_ops(&c_conn_ui_ops) + blist.purple_blist_set_ui_ops(&c_blist_ui_ops) + conversation.purple_conversations_set_ui_ops(&c_conv_ui_ops) + notify.purple_notify_set_ui_ops(&c_notify_ui_ops) + #privacy.purple_privacy_set_ui_ops(&c_privacy_ui_ops) + request.purple_request_set_ui_ops(&c_request_ui_ops) + #ft.purple_xfers_set_ui_ops(&c_ft_ui_ops) + #roomlist.purple_roomlist_set_ui_ops(&c_rlist_ui_ops) cdef void __core_ui_ops_quit(self): - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "core_ui_ops", "quit\n") - - global c_ui_info + debug.purple_debug_info("core_ui_ops", "%s", "quit\n") - account.c_purple_accounts_set_ui_ops(NULL) - connection.c_purple_connections_set_ui_ops(NULL) - blist.c_purple_blist_set_ui_ops(NULL) - conversation.c_purple_conversations_set_ui_ops(NULL) - notify.c_purple_notify_set_ui_ops(NULL) - #privacy.c_purple_privacy_set_ui_ops(NULL) - request.c_purple_request_set_ui_ops(NULL) - #ft.c_purple_xfers_set_ui_ops(NULL) - #roomlist.c_purple_roomlist_set_ui_ops(NULL) + account.purple_accounts_set_ui_ops(NULL) + connection.purple_connections_set_ui_ops(NULL) + blist.purple_blist_set_ui_ops(NULL) + conversation.purple_conversations_set_ui_ops(NULL) + notify.purple_notify_set_ui_ops(NULL) + #privacy.purple_privacy_set_ui_ops(NULL) + request.purple_request_set_ui_ops(NULL) + #ft.purple_xfers_set_ui_ops(NULL) + #roomlist.purple_roomlist_set_ui_ops(NULL) - if c_ui_info: - glib.g_hash_table_destroy(c_ui_info) + if self.c_ui_info: + glib.g_hash_table_destroy( self.c_ui_info) cdef glib.GHashTable *__core_ui_ops_get_ui_info(self): global c_ui_info + global c_ui_name + global c_ui_version + global c_ui_website + global c_ui_dev_website if c_ui_info == NULL: - c_ui_info = glib.g_hash_table_new(glib.g_str_hash, glib.g_str_equal) + c_ui_info = glib.g_hash_table_new(glib.g_str_hash, \ + glib.g_str_equal) - glib.g_hash_table_insert(c_ui_info, "name", __APP_NAME__) - glib.g_hash_table_insert(c_ui_info, "version", __APP_VERSION__) + glib.g_hash_table_insert(c_ui_info, "name", c_ui_name) + glib.g_hash_table_insert(c_ui_info, "version", c_ui_version) + glib.g_hash_table_insert(c_ui_info, "website", c_ui_website) + glib.g_hash_table_insert(c_ui_info, "dev_website", c_ui_dev_website) return c_ui_info def __glib_iteration_when_idle(self): @@ -141,6 +157,7 @@ cdef class Purple: def purple_init(self): """ Initializes libpurple """ + global c_ui_name c_account_ui_ops.notify_added = notify_added c_account_ui_ops.status_changed = status_changed @@ -215,36 +232,39 @@ cdef class Purple: c_eventloop_ui_ops.input_get_error = NULL c_eventloop_ui_ops.timeout_add_seconds = NULL - core.c_purple_core_set_ui_ops(&c_core_ui_ops) - eventloop.c_purple_eventloop_set_ui_ops(&c_eventloop_ui_ops) + core.purple_core_set_ui_ops(&c_core_ui_ops) + eventloop.purple_eventloop_set_ui_ops(&c_eventloop_ui_ops) # initialize purple core - ret = core.c_purple_core_init(__APP_NAME__) + ret = core.purple_core_init(c_ui_name) if ret is False: - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "main", "Exiting because libpurple initialization failed.\n") + debug.purple_debug_fatal("main", "%s", "libpurple " \ + "initialization failed.\n") return False # check if there is another instance of libpurple running - if core.c_purple_core_ensure_single_instance() == False: - debug.c_purple_debug(debug.PURPLE_DEBUG_INFO, "main", "Exiting because another instance of libpurple is already running.\n") - core.c_purple_core_quit() + if core.purple_core_ensure_single_instance() == False: + debug.purple_debug_fatal("main", "%s", "Another instance of " \ + "libpurple is already running.\n") + core.purple_core_quit() return False # create and load the buddy list - blist.c_purple_set_blist(blist.c_purple_blist_new()) - blist.c_purple_blist_load() + blist.purple_set_blist(blist.purple_blist_new()) + blist.purple_blist_load() # load pounces - pounce.c_purple_pounces_load() - - # initialize accounts - self.load_accounts() + pounce.purple_pounces_load() return ret - def add_callback(self, type, name, func): - """ Adds a callback 'func' with given name 'name' inside type 'type'. - Example: add_callback("account", "notify-added", notify_added_cb) + def add_callback(self, type, name, callback): + """ + Adds a callback with given name inside callback's type. + + @param type Callback type (e.g. "account") + @param name Callback name (e.g. "notify-added") + @param callback Callback to be called """ global account_cbs global blist_cbs @@ -258,11 +278,7 @@ cdef class Purple: "connection": connection_cbs, "conversation": conversation_cbs, "notify": notify_cbs, - "request": request_cbs }[type][name] = func - - def connect(self): - conn = Connection() - conn.connect() + "request": request_cbs }[type][name] = callback def signal_connect(self, name=None, cb=None): cdef int handle @@ -271,68 +287,112 @@ cdef class Purple: if name is None: return - jabber = prpl.c_purple_find_prpl("prpl-jabber") + jabber = prpl.purple_find_prpl("prpl-jabber") if jabber == NULL: return global signal_cbs signal_cbs[name] = cb - if name == "buddy-signed-off": - signals.c_purple_signal_connect( - blist.c_purple_blist_get_handle(), + if name == "signed-on": + signals.purple_signal_connect( + connection.purple_connections_get_handle(), + "signed-on", &handle, + signal_signed_on_cb, NULL) + elif name == "signed-off": + signals.purple_signal_connect( + connection.purple_connections_get_handle(), + "signed-off", &handle, + signal_signed_off_cb, NULL) + elif name == "connection-error": + signals.purple_signal_connect( + connection.purple_connections_get_handle(), + "connection-error", &handle, + signal_connection_error_cb, NULL) + elif name == "buddy-signed-on": + signals.purple_signal_connect( + blist.purple_blist_get_handle(), + "buddy-signed-on", &handle, + signal_buddy_signed_on_cb, NULL) + elif name == "buddy-signed-off": + signals.purple_signal_connect( + blist.purple_blist_get_handle(), "buddy-signed-off", &handle, signal_buddy_signed_off_cb, NULL) elif name == "receiving-im-msg": - signals.c_purple_signal_connect( - conversation.c_purple_conversations_get_handle(), + signals.purple_signal_connect( + conversation.purple_conversations_get_handle(), "receiving-im-msg", &handle, signal_receiving_im_msg_cb, NULL) elif name == "jabber-receiving-xmlnode": - signals.c_purple_signal_connect( + signals.purple_signal_connect( jabber, "jabber-receiving-xmlnode", &handle, jabber_receiving_xmlnode_cb, NULL) - def __get_accounts(self): - return self.__accounts - accounts = property(__get_accounts) + def accounts_get_all(self): + cdef glib.GList *iter + cdef account.PurpleAccount *acc + cdef char *username + cdef char *protocol_id - def new_account(self, username, protocol_id): - acc = Account(username, protocol_id) - return acc + iter = account.purple_accounts_get_all() + account_list = [] - def load_accounts(self): + while iter: + acc = iter.data + + if acc: + username = account.purple_account_get_username(acc) + protocol_id = account.purple_account_get_protocol_id(acc) + + if username != NULL and protocol_id != NULL: + account_list.append(Account(username, \ + Protocol(protocol_id), self)) + iter = iter.next + + return account_list + + def accounts_get_all_active(self): cdef glib.GList *iter cdef account.PurpleAccount *acc - iter = account.c_purple_accounts_get_all() + cdef char *username + cdef char *protocol_id + + iter = account.purple_accounts_get_all_active() + account_list = [] + while iter: acc = iter.data + if acc: - username = account.c_purple_account_get_username(acc) - protocol_id = account.c_purple_account_get_protocol_id(acc) - self.account_add(username.split("/")[0], protocol_id, "172.18.216.211", 8080) + username = account.purple_account_get_username(acc) + protocol_id = account.purple_account_get_protocol_id(acc) + + if username != NULL and protocol_id != NULL: + account_list.append(Account(username, \ + Protocol(protocol_id), self)) iter = iter.next - def account_add(self, username, protocol_id, host, port): - if not self.account_verify(username): - acc = purple.Account(username, protocol_id) - self.__accounts[username] = acc - if not account.c_purple_accounts_find(username, protocol_id): - acc.proxy.set_type(purple.ProxyInfoType().HTTP) - acc.proxy.set_host(host) - acc.proxy.set_port(port) - acc.save_into_xml() - - def account_verify(self, acc_username): - if self.__accounts: - for username in self.__accounts.keys(): - if acc_username == username: - return self.__accounts[username] - else: - return None + return account_list + + def protocols_get_all(self): + cdef glib.GList *iter + cdef plugin.PurplePlugin *pp + + iter = plugin.purple_plugins_get_protocols() + protocol_list = [] + while iter: + pp = iter.data + if pp.info and pp.info.name: + protocol_list.append(Protocol(pp.info.id)) + iter = iter.next + return protocol_list +include "protocol.pyx" +#include "plugin.pyx" include "proxy.pyx" +#include "protocol.pyx" include "account.pyx" include "buddy.pyx" -include "connection.pyx" +#include "connection.pyx" include "conversation.pyx"