X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=account.pyx;h=d896dd05f558a1bdb5e4a1bd419637ca2fa670d5;hp=1a621409d6138af151d61e38accdaf0d5810faf6;hb=fa83e5e05e62fa5c6707312d375b97195143e6b7;hpb=a99a8cb697789ce35e1fa3a21713729f7b11f1ba diff --git a/account.pyx b/account.pyx index 1a62140..d896dd0 100644 --- a/account.pyx +++ b/account.pyx @@ -19,16 +19,16 @@ cimport purple -from protocol import Protocol - cdef class Account: """ Account class + @param core @param username @param protocol_id """ - def __init__(self, username, protocol_id): + def __init__(self, core, username, protocol_id): + self.__core = core self.__username = username self.__protocol = Protocol(self, protocol_id) @@ -41,6 +41,32 @@ cdef class Account: 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_core(self): + return self.__core + core = property(__get_core) + def __get_exists(self): return self.__exists exists = property(__get_exists) @@ -116,6 +142,14 @@ cdef class Account: 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. @@ -200,6 +234,20 @@ cdef class Account: else: return False + def set_enabled(self, value): + """ + Sets wheter or not this account is enabled. + + @param value True if it is enabled, or False otherwise + @return True if successful, False if account doesn't exists + """ + if self.__exists: + account.purple_account_set_enabled(self._get_structure(), \ + self.core.ui_name, bool(value)) + return True + else: + return False + def new(self): """ Creates a new account. @@ -212,3 +260,27 @@ cdef class Account: account.purple_account_new(self.username, self.protocol_id) self.__exists = True return True + + def connect(self): + """ + Connects to an account. + + @return True if successful, False if account doesn't exists + """ + if self.__exists: + account.purple_account_connect(self._get_structure()) + return True + else: + return False + + def disconnect(self): + """ + Disconnects from an account. + + @return True if successful, False if account doesn't exists + """ + if self.__exists: + account.purple_account_disconnect(self._get_structure()) + return True + else: + return False