X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=account.pyx;h=7dd484fa158d210e953b97f83e57fff535e6875d;hp=0e985488f3149eb6f3c8780fd806095ab8af4dbe;hb=a9c739f31cfa8cbb2a91e79f829a71f09406d73b;hpb=e7e4e8ff4937aed9c1b732719bc310c3e8a88f5e
diff --git a/account.pyx b/account.pyx
index 0e98548..7dd484f 100644
--- a/account.pyx
+++ b/account.pyx
@@ -17,49 +17,201 @@
# along with this program. If not, see .
#
-cimport glib
+cimport purple
-cimport account
-cimport blist
-cimport savedstatuses
-cimport status
+cdef extern from *:
+ ctypedef char const_char "const char"
cdef class Account:
""" Account class """
- cdef account.PurpleAccount *__account
+ cdef account.PurpleAccount *c_account
+ cdef plugin.PurplePlugin *c_plugin
+ cdef prpl.PurplePluginProtocolInfo *c_prpl_info
+ cdef plugin.PurplePluginInfo *c_plugin_info
cdef savedstatuses.PurpleSavedStatus *__sstatus
+ cdef ProxyInfo __proxy
- def __cinit__(self, char *username, char *protocol_id):
- self.__account = account.c_purple_account_new(username, protocol_id)
+ def __init__(self, char *username, char *protocol_id):
+ cdef proxy.PurpleProxyInfo *c_proxyinfo
+ cdef account.PurpleAccount *acc = NULL
- def set_password(self, password):
- account.c_purple_account_set_password(self.__account, password)
+ acc = account.c_purple_accounts_find(username, protocol_id)
+ if acc:
+ self.c_account = acc
+ c_proxyinfo = account.c_purple_account_get_proxy_info(self.c_account)
+ else:
+ self.c_account = account.c_purple_account_new(username, protocol_id)
+ c_proxyinfo = account.c_purple_account_get_proxy_info(self.c_account)
+ if c_proxyinfo == NULL:
+ c_proxyinfo = proxy.c_purple_proxy_info_new()
+ proxy.c_purple_proxy_info_set_type(c_proxyinfo, proxy.PURPLE_PROXY_NONE)
+ account.c_purple_account_set_proxy_info(self.c_account, c_proxyinfo)
+ self.__proxy = ProxyInfo()
+ self.__proxy.c_proxyinfo = c_proxyinfo
+ acc = NULL
- def set_enabled(self, ui, value):
- account.c_purple_account_set_enabled(self.__account, ui, value)
+ self.c_plugin = plugin.c_purple_plugins_find_with_id(protocol_id)
+ self.c_prpl_info = plugin.c_PURPLE_PLUGIN_PROTOCOL_INFO(self.c_plugin)
+
+ def __get_username(self):
+ if self.c_account:
+ return account.c_purple_account_get_username(self.c_account)
+ else:
+ return None
+ def __set_username(self, username):
+ if self.c_account:
+ account.c_purple_account_set_username(self.c_account, username)
+ username = property(__get_password, __set_username)
+
+ def __get_password(self):
+ if self.c_account:
+ return account.c_purple_account_get_password(self.c_account)
+ else:
+ return None
+ def __set_password(self, password):
+ if self.c_account:
+ account.c_purple_account_set_password(self.c_account, password)
+ password = property(__get_password, __set_password)
+
+ def __get_alias(self):
+ if self.c_account:
+ return account.c_purple_account_get_alias(self.c_account)
+ else:
+ return None
+ def __set_alias(self, alias):
+ if self.c_account:
+ account.c_purple_account_set_alias(self.c_account, alias)
+ alias = property(__get_alias, __set_alias)
+
+ def __get_user_info(self):
+ if self.c_account:
+ return account.c_purple_account_get_user_info(self.c_account)
+ else:
+ return None
+ def __set_user_info(self, user_info):
+ if self.c_account:
+ account.c_purple_account_set_user_info(self.c_account, user_info)
+ user_info = property(__get_user_info, __set_user_info)
- def get_acc_username(self):
- if self.__account:
- return account.c_purple_account_get_username(self.__account)
+ def __get_protocol_id(self):
+ if self.c_account:
+ return account.c_purple_account_get_protocol_id(self.c_account)
+ else:
+ return None
+ def __set_protocol_id(self, protocol_id):
+ if self.c_account:
+ account.c_purple_account_set_protocol_id(self.c_account, protocol_id)
+ protocol_id = property(__get_protocol_id, __set_protocol_id)
- def get_password(self):
- if self.__account:
- return account.c_purple_account_get_password(self.__account)
+ def __get_remember_password(self):
+ if self.c_account:
+ return account.c_purple_account_get_remember_password(self.c_account)
+ else:
+ return None
+ def __set_remember_password(self, value):
+ if self.c_account:
+ account.c_purple_account_set_remember_password(self.c_account, value)
+ remember_password = property(__get_remember_password, __set_remember_password)
+
+ def get_protocol_name(self):
+ if self.c_account:
+ return account.c_purple_account_get_protocol_name(self.c_account)
+ else:
+ return None
+
+ def get_enabled(self, ui):
+ if self.c_account:
+ return account.c_purple_account_get_enabled(self.c_account, ui)
+ else:
+ return None
+
+ def set_enabled(self, ui, value):
+ if self.c_account:
+ account.c_purple_account_set_enabled(self.c_account, ui, value)
def set_status(self):
self.__sstatus = savedstatuses.c_purple_savedstatus_new(NULL, status.PURPLE_STATUS_AVAILABLE)
savedstatuses.c_purple_savedstatus_activate(self.__sstatus)
- def get_buddies_online(self, acc):
+ def __get_proxy(self):
+ return self.__proxy
+ proxy = property(__get_proxy)
+
+ def get_buddies_online(self):
cdef glib.GSList *iter
cdef blist.PurpleBuddy *buddy
+ cdef char *c_name = NULL
+ cdef char *c_alias = NULL
buddies = []
- iter = blist.c_purple_find_buddies(self.__account, NULL)
+ iter = blist.c_purple_find_buddies(self.c_account, NULL)
while iter:
+ c_name = NULL
+ c_alias = NULL
buddy = iter.data
- if