X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=account.pyx;h=16e5dcd6169e7b959af67e83ed43ae3a9681eb7a;hp=0e985488f3149eb6f3c8780fd806095ab8af4dbe;hb=f43bb1fee1c9660e1e8f39640926a8ed2ad52715;hpb=e7e4e8ff4937aed9c1b732719bc310c3e8a88f5e;ds=sidebyside
diff --git a/account.pyx b/account.pyx
index 0e98548..16e5dcd 100644
--- a/account.pyx
+++ b/account.pyx
@@ -17,49 +17,266 @@
# along with this program. If not, see .
#
-cimport glib
+cimport purple
-cimport account
-cimport blist
-cimport savedstatuses
-cimport status
+from protocol import Protocol
cdef class Account:
- """ Account class """
- cdef account.PurpleAccount *__account
- cdef savedstatuses.PurpleSavedStatus *__sstatus
+ """
+ Account class
+ @param username
+ @param protocol_id
+ """
- def __cinit__(self, char *username, char *protocol_id):
- self.__account = account.c_purple_account_new(username, protocol_id)
+ def __init__(self, username, protocol_id):
+ self.__username = username
+ self.__protocol = Protocol(self, protocol_id)
+
+ if self._get_structure() == NULL:
+ self.__exists = False
+ else:
+ self.__exists = True
+
+ cdef account.PurpleAccount *_get_structure(self):
+ return account.purple_accounts_find(self.username, \
+ self.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_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_id(self):
+ cdef char *protocol_id = NULL
+ if self.__exists:
+ protocol_id = account.purple_account_get_protocol_id( \
+ self._get_structure())
+ if protocol_id:
+ return protocol_id
+ else:
+ return None
+ else:
+ return self.protocol_id
+ protocol_id = property(__get_protocol_id)
+
+ 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.
+
+ @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_id(self, protocol_id):
+ """
+ Sets the account's protocol ID.
+
+ @param protocol_id The protocol ID
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ self.__protocol._set_protocol_id(protocol_id)
+ 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