X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=account.pyx;h=915f52fec832988aeaa9869475bdd01953017148;hp=0e985488f3149eb6f3c8780fd806095ab8af4dbe;hb=234217a000fe6784068165ec2046ee24054219c8;hpb=e7e4e8ff4937aed9c1b732719bc310c3e8a88f5e
diff --git a/account.pyx b/account.pyx
index 0e98548..915f52f 100644
--- a/account.pyx
+++ b/account.pyx
@@ -17,49 +17,263 @@
# along with this program. If not, see .
#
-cimport glib
-
-cimport account
-cimport blist
-cimport savedstatuses
-cimport status
+cimport purple
cdef class Account:
- """ Account class """
- cdef account.PurpleAccount *__account
- cdef savedstatuses.PurpleSavedStatus *__sstatus
+ """
+ Account class
+ @param core Purple class instance
+ @param username
+ @param protocol Protocol class instance
+ """
+
+ def __init__(self, username, protocol, core):
+ self.__username = username
+ self.__protocol = protocol
+ self.__core = core
+
+ if protocol.exists and self._get_structure() != NULL:
+ self.__exists = True
+ else:
+ self.__exists = False
+
+ cdef account.PurpleAccount *_get_structure(self):
+ return account.purple_accounts_find(self.username, \
+ self.protocol.protocol_id)
+
+ def __is_connected(self):
+ if self.__exists:
+ return account.purple_account_is_connected(self._get_structure())
+ else:
+ return None
+ is_connected = property(__is_connected)
+
+ def __is_connecting(self):
+ if self.__exists:
+ return account.purple_account_is_connecting(self._get_structure())
+ else:
+ return None
+ is_connecting = property(__is_connecting)
+
+ def __is_disconnected(self):
+ if self.__exists:
+ return account.purple_account_is_disconnected( \
+ self._get_structure())
+ else:
+ return None
+ is_disconnected = property(__is_disconnected)
+
+ def __get_core(self):
+ return self.__core
+ core = property(__get_core)
+
+ def __get_exists(self):
+ return self.__exists
+ exists = property(__get_exists)
+
+ def __get_username(self):
+ cdef char *username = NULL
+ if self.__exists:
+ username = account.purple_account_get_username( \
+ self._get_structure())
+ if username:
+ return username
+ else:
+ return None
+ else:
+ return self.__username
+ username = property(__get_username)
+
+ def __get_protocol(self):
+ return self.protocol
+ protocol = property(__get_protocol)
+
+ def __get_password(self):
+ cdef char *password = NULL
+ if self.__exists:
+ password = account.purple_account_get_password( \
+ self._get_structure())
+ if password:
+ return password
+ else:
+ return None
+ else:
+ return None
+ password = property(__get_password)
+
+ def __get_alias(self):
+ cdef char *alias = NULL
+ if self.__exists:
+ alias = account.purple_account_get_alias(self._get_structure())
+ if alias:
+ return alias
+ else:
+ return None
+ else:
+ return None
+ alias = property(__get_alias)
+
+ def __get_user_info(self):
+ cdef char *user_info = NULL
+ if self.__exists:
+ user_info = account.purple_account_get_user_info(self._get_structure())
+ if user_info:
+ return user_info
+ else:
+ return None
+ else:
+ return None
+ user_info = property(__get_user_info)
+
+ def __get_remember_password(self):
+ if self.__exists:
+ return account.purple_account_get_remember_password( \
+ self._get_structure())
+ else:
+ return None
+ remember_password = property(__get_remember_password)
+
+ def __get_enabled(self):
+ if self.__exists:
+ return account.purple_account_get_enabled(self._get_structure(), \
+ self.core.ui_name)
+ else:
+ return None
+ enabled = property(__get_enabled)
+
+ def set_username(self, username):
+ """
+ Sets the account's username.
- def __cinit__(self, char *username, char *protocol_id):
- self.__account = account.c_purple_account_new(username, protocol_id)
+ @param username The username
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_account_set_username(self._get_structure(), \
+ username)
+ return True
+ else:
+ return False
+
+ def set_protocol(self, protocol):
+ """
+ Sets the account's protocol.
+
+ @param protocol A Protocol class instance
+ @return True if successful, False if account doesn't exists
+ """
+ if protocol.exists and self.__exists:
+ account.purple_account_set_protocol_id(self._get_structure(), \
+ protocol.protocol_id)
+ self.__protocol = protocol
+ return True
+ else:
+ return False
def set_password(self, password):
- account.c_purple_account_set_password(self.__account, password)
-
- def set_enabled(self, ui, value):
- account.c_purple_account_set_enabled(self.__account, ui, value)
-
- def get_acc_username(self):
- if self.__account:
- return account.c_purple_account_get_username(self.__account)
-
- def get_password(self):
- if self.__account:
- return account.c_purple_account_get_password(self.__account)
-
- 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):
- cdef glib.GSList *iter
- cdef blist.PurpleBuddy *buddy
- buddies = []
- iter = blist.c_purple_find_buddies(self.__account, NULL)
- while iter:
- buddy = iter.data
- if