X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=purple.pyx;h=54be9311b9a5100f3ada8a8c8d0db64cb6d13323;hp=00ce7fc346f9b08586ca34e84f353c8de146d8a0;hb=dd446d6d03c2c550010993a4e949007c242ecbe7;hpb=7470d2d07fe34117a3e8928a00fd967159989f27 diff --git a/purple.pyx b/purple.pyx index 00ce7fc..54be931 100644 --- a/purple.pyx +++ b/purple.pyx @@ -63,10 +63,10 @@ cdef class Purple: @parm default_path: Full path for libpurple user files. """ - cdef object accounts + cdef object __accounts def __init__(self, debug_enabled=True, app_name=__APP_NAME__, default_path=__DEFAULT_PATH__): - self.accounts = {} + self.__accounts = {} if app_name is not __APP_NAME__: __APP_NAME__ = app_name @@ -141,15 +141,11 @@ cdef class Purple: """ Initializes libpurple """ if callbacks_dict is not None: - global account_cbs - global blist_cbs global connection_cbs global conversation_cbs global notify_cbs global request_cbs - account_cbs = callbacks_dict["account"] - blist_cbs = callbacks_dict["blist"] connection_cbs = callbacks_dict["connection"] conversation_cbs = callbacks_dict["conversation"] notify_cbs = callbacks_dict["notify"] @@ -250,8 +246,19 @@ cdef class Purple: # load pounces pounce.c_purple_pounces_load() + # initialize accounts + self.load_accounts() + return ret + def add_account_cb(self, name, func): + global account_cbs + account_cbs[name] = func + + def add_blist_cb(self, name, func): + global blist_cbs + blist_cbs[name] = func + def connect(self): conn = Connection() conn.connect() @@ -285,44 +292,43 @@ cdef class Purple: jabber, "jabber-receiving-xmlnode", &handle, jabber_receiving_xmlnode_cb, NULL) + def __get_accounts(self): + return self.__accounts + accounts = property(__get_accounts) + def new_account(self, username, protocol_id): acc = Account(username, protocol_id) return acc - def accounts_init(self): + def load_accounts(self): cdef glib.GList *iter cdef account.PurpleAccount *acc iter = account.c_purple_accounts_get_all() while iter: acc = iter.data if acc: - self.account_add(acc.username.split("/")[0], acc.protocol_id, "172.18.216.211", 8080) + 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) 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_add_dict(username, acc) + 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() - else: - print "Exists account" def account_verify(self, acc_username): - if self.accounts: - for username in self.accounts.keys(): + if self.__accounts: + for username in self.__accounts.keys(): if acc_username == username: - return self.accounts[username] - return None - - def accounts_add_dict(self, username, acc): - self.accounts[username] = acc - - def accounts_get_dict(self): - return self.accounts + return self.__accounts[username] + else: + return None include "proxy.pyx" include "account.pyx"