+ return True
+
+ def set_password(self, password):
+ """
+ Sets the account's password.
+
+ @param password The password
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_account_set_password(self._get_structure(), \
+ password)
+ return True
+ else:
+ return False
+
+ def set_alias(self, alias):
+ """
+ Sets the account's alias
+
+ @param alias The alias
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_account_set_alias(self._get_structure(), \
+ alias)
+ return True
+ else:
+ return False
+
+ def set_user_info(self, user_info):
+ """
+ Sets the account's user information
+
+ @param user_info The user information
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_account_set_user_info(self._get_structure(), \
+ user_info)
+ return True
+ else:
+ return False
+
+ def set_remember_password(self, remember_password):
+ """
+ Sets whether or not this account should save its password.
+
+ @param remember_password True if should remember the password,
+ or False otherwise
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_account_set_remember_password( \
+ self._get_structure(), remember_password)
+ return True
+ 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.
+
+ @return True if successful, False if account already exists
+ """
+ if self.__exists:
+ return False
+ else:
+ account.purple_accounts_add(account.purple_account_new( \
+ self.__username, self.__protocol.id))
+
+ self.__exists = True
+ return True
+
+ def remove(self):
+ """
+ Removes an existing account.
+
+ @return True if successful, False if account doesn't exists
+ """
+ if self.__exists:
+ account.purple_accounts_delete(self._get_structure())
+ self__exists = False
+ return True
+ else:
+ return False
+
+ 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
+
+ def add_buddy(self, name, alias=None, group=None):
+ """
+ Adds a buddy to account's buddy list.
+
+ @param name Buddy name
+ @param alias Buddy alias (optional)
+ @return True if successfull, False otherwise
+ """
+ cdef blist.PurpleBuddy *c_buddy = NULL
+ cdef blist.PurpleGroup *c_group = NULL
+ cdef char *c_alias = NULL
+
+ if alias:
+ c_alias = alias
+ else:
+ c_alias = NULL
+
+ if self.__exists and \
+ account.purple_account_is_connected(self._get_structure()):
+ if blist.purple_find_buddy(self._get_structure(), name):
+ return False
+
+ if group:
+ c_group = blist.purple_find_group(group)
+ if c_group == NULL:
+ c_group = blist.purple_group_new(group)
+
+ c_buddy = blist.purple_buddy_new(self._get_structure(), \
+ name, c_alias)
+ if c_buddy == NULL:
+ return False
+
+ blist.purple_blist_add_buddy(c_buddy, NULL, c_group, NULL)
+ account.purple_account_add_buddy(self._get_structure(), c_buddy)
+ if c_alias:
+ blist.purple_blist_alias_buddy(c_buddy, c_alias)
+ server.serv_alias_buddy(c_buddy)
+
+ return True
+
+ else:
+ return None
+
+ def remove_buddy(self, name):
+ """
+ Removes a buddy from account's buddy list.
+
+ @param name Buddy name
+ @return True if successful, False otherwise
+ """
+ cdef blist.PurpleBuddy *c_buddy = NULL
+ cdef blist.PurpleGroup *c_group = NULL
+
+ if self.__exists and \
+ account.purple_account_is_connected(self._get_structure()):
+ c_buddy = blist.purple_find_buddy(self._get_structure(), name)
+ if c_buddy == NULL:
+ return False
+
+ c_group = blist.purple_buddy_get_group(c_buddy)
+
+ account.purple_account_remove_buddy(self._get_structure(), \
+ c_buddy, c_group)
+ blist.purple_blist_remove_buddy(c_buddy)
+ return True
+ else:
+ return None
+
+ def get_buddies_online(self):
+ cdef glib.GSList *iter = NULL
+ cdef blist.PurpleBuddy *c_buddy = NULL
+ cdef char *c_alias = NULL
+
+ buddies_list = []
+ if self.__exists and \
+ account.purple_account_is_connected(self._get_structure()):
+ iter = blist.purple_find_buddies(self._get_structure(), NULL)
+
+ while iter:
+ c_alias = NULL
+ c_buddy = <blist.PurpleBuddy *> iter.data
+ if <blist.PurpleBuddy *> c_buddy and \
+ status.purple_presence_is_online( \
+ blist.purple_buddy_get_presence(c_buddy)):
+ name = <char *> blist.purple_buddy_get_name(c_buddy)
+
+ new_buddy = Buddy(name, self)
+
+ c_alias = <char *> blist.purple_buddy_get_alias_only(c_buddy)
+ if c_alias:
+ new_buddy.set_alias(c_alias)
+
+ buddies_list.append(new_buddy)
+ iter = iter.next
+
+ return buddies_list
+
+ def get_buddies(self):
+ """
+ @return Account's buddies list
+ """
+ cdef glib.GSList *iter = NULL
+ cdef blist.PurpleBuddy *c_buddy = NULL
+ cdef char *c_alias = NULL
+
+ buddies_list = []
+ if self.__exists:
+ iter = blist.purple_find_buddies(self._get_structure(), NULL)
+
+ while iter:
+ c_alias = NULL
+ c_buddy = <blist.PurpleBuddy *> iter.data
+
+ name = <char *> blist.purple_buddy_get_name(c_buddy)
+ new_buddy = Buddy(name, self)
+
+ c_alias = <char *> blist.purple_buddy_get_alias_only(c_buddy)
+ if c_alias:
+ new_buddy.set_alias(c_alias)
+
+ buddies_list.append(new_buddy)
+ iter = iter.next
+
+ return buddies_list
+
+ def request_add_buddy(self, buddy_username, buddy_alias):
+ if buddy_alias:
+ blist.purple_blist_request_add_buddy(self._get_structure(), \
+ buddy_username, NULL, buddy_alias)
+ else:
+ blist.purple_blist_request_add_buddy(self._get_structure(), \
+ buddy_username, NULL, NULL)
+
+ def set_active_status(self, type, msg=None):
+ cdef status.PurpleStatusType *c_statustype = NULL
+ cdef savedstatuses.PurpleSavedStatus *c_savedstatus = NULL
+
+ if self.__exists:
+ if msg:
+ account.purple_account_set_status(self._get_structure(),
+ <char *> type, True, "message", <char *> msg, NULL)
+ else:
+ account.purple_account_set_status(self._get_structure(),
+ <char *> type, True, NULL)
+
+ # FIXME: We can create only a savedstatus for each statustype
+ c_savedstatus = savedstatuses.purple_savedstatus_find(type)
+ if c_savedstatus == NULL:
+ c_statustype = account.purple_account_get_status_type( \
+ self._get_structure(), type)
+ c_savedstatus = savedstatuses.purple_savedstatus_new( \
+ NULL, status.purple_status_type_get_primitive( \
+ c_statustype))
+ savedstatuses.purple_savedstatus_set_title(c_savedstatus,
+ type)
+
+ savedstatuses.purple_savedstatus_set_message(c_savedstatus, msg)
+ prefs.purple_prefs_set_int("/purple/savedstatus/idleaway",
+ savedstatuses.purple_savedstatus_get_creation_time(c_savedstatus))
+
+ return True
+ else:
+ return False
+
+ def set_status_message(self, type, msg):
+ cdef status.PurpleStatus* c_status = NULL
+ cdef status.PurpleStatusType *c_statustype = NULL
+ cdef savedstatuses.PurpleSavedStatus *c_savedstatus = NULL
+
+ if self.__exists and msg:
+ c_status = account.purple_account_get_status(self._get_structure(),
+ type)
+ if c_status == NULL:
+ return False
+ status.purple_status_set_attr_string(c_status, "message", msg)
+
+ # FIXME: We can create only a savedstatus for each statustype
+ c_savedstatus = savedstatuses.purple_savedstatus_find(type)
+ if c_savedstatus == NULL:
+ c_statustype = account.purple_account_get_status_type( \
+ self._get_structure(), type)
+ c_savedstatus = savedstatuses.purple_savedstatus_new( \
+ NULL, status.purple_status_type_get_primitive( \
+ c_statustype))
+ savedstatuses.purple_savedstatus_set_title(c_savedstatus,
+ type)
+
+ savedstatuses.purple_savedstatus_set_message(c_savedstatus, msg)
+ return True
+ else:
+ return False