X-Git-Url: http://git.maemo.org/git/?p=python-purple;a=blobdiff_plain;f=account.pyx;h=81d6ab901587d193acf326daa94d39bd4d9edcb9;hp=427d2bdebf24c469303a3c38e854dbb5e4156c46;hb=refs%2Fheads%2Fmaster;hpb=b81a85360c67a5721e59458aeec5d7b9280a290e
diff --git a/account.pyx b/account.pyx
index 427d2bd..81d6ab9 100644
--- a/account.pyx
+++ b/account.pyx
@@ -17,7 +17,15 @@
# along with this program. If not, see .
#
-cimport purple
+cimport account
+cimport accountopt
+cimport blist
+cimport plugin
+cimport prefs
+cimport prpl
+cimport savedstatuses
+cimport server
+cimport status
cdef class Account:
"""
@@ -95,7 +103,7 @@ cdef class Account:
def _get_protocol_options(self):
"""
- @return Dictionary {'setting': value, ...}
+ @return Dictionary {'setting': value, ...}
"""
cdef glib.GList *iter
cdef account.PurpleAccount *c_account
@@ -133,9 +141,10 @@ cdef class Account:
str_value = accountopt.purple_account_option_get_default_string(option)
- # Google Talk default domain hackery!
- if str_value == NULL and str( label_name) == "Connect server":
- str_value = "talk.google.com"
+ # Hack to set string "" as default value to Account options when
+ # the default value of the protocol is NULL
+ if str_value == NULL:
+ str_value = ""
str_value = account.purple_account_get_string(c_account, setting, str_value)
val = str( str_value)
@@ -221,6 +230,49 @@ cdef class Account:
return None
enabled = property(__get_enabled)
+ def __get_status_types(self):
+ cdef glib.GList *iter = NULL
+ cdef status.PurpleStatusType *c_statustype = NULL
+ cdef char *id = NULL
+ cdef char *name = NULL
+
+ status_types = []
+ if self.__exists:
+ iter = account.purple_account_get_status_types(self._get_structure())
+ while iter:
+ c_statustype = iter.data
+ id = status.purple_status_type_get_id(c_statustype)
+ name = status.purple_status_type_get_name(c_statustype)
+ status_types.append((id, name))
+ iter = iter.next
+
+ return status_types
+
+ status_types = property(__get_status_types)
+
+ def __get_active_status(self):
+ cdef status.PurpleStatus* c_status = NULL
+ cdef char *type = NULL
+ cdef char *name = NULL
+ cdef char *msg = NULL
+ if self.__exists:
+ active = {}
+ c_status = account.purple_account_get_active_status(self._get_structure())
+ type = status.purple_status_get_id(c_status)
+ name = status.purple_status_get_name(c_status)
+ msg = status.purple_status_get_attr_string(c_status,
+ "message")
+
+ active['type'] = type
+ active['name'] = name
+ if msg:
+ active['message'] = msg
+
+ return active
+ else:
+ return None
+ active_status = property(__get_active_status)
+
def set_username(self, username):
"""
Sets the account's username.
@@ -283,7 +335,7 @@ cdef class Account:
sett = str( setting)
- if not po.has_key(sett):
+ if sett not in po:
iter = iter.next
continue
@@ -391,27 +443,24 @@ cdef class Account:
if self.__exists:
return False
else:
- # FIXME: Using purple_accounts_add(...) to save to xml
- # I think we could improve this ..
account.purple_accounts_add(account.purple_account_new( \
self.__username, self.__protocol.id))
self.__exists = True
return True
-
- def remove_account(self, username, protocol_id):
- """
- Removes as existing account.
- @return True if successful, False if account doesnt exists
+ def remove(self):
+ """
+ Removes an existing account.
+
+ @return True if successful, False if account doesn't exists
"""
- who = account.purple_accounts_find(username, protocol_id)
-
- if who == NULL:
- return False
- else
- account.purple_accounts_remove( who )
- return True
+ if self.__exists:
+ account.purple_accounts_delete(self._get_structure())
+ self__exists = False
+ return True
+ else:
+ return False
def connect(self):
"""
@@ -471,6 +520,10 @@ cdef class Account:
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:
@@ -506,11 +559,11 @@ cdef class Account:
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)
- buddies_list = []
while iter:
c_alias = NULL
c_buddy = iter.data
@@ -527,6 +580,103 @@ cdef class Account:
buddies_list.append(new_buddy)
iter = iter.next
- return buddies_list
+
+ 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 = iter.data
+
+ name = blist.purple_buddy_get_name(c_buddy)
+ new_buddy = Buddy(name, self)
+
+ c_alias = 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:
- return None
+ 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
+ cdef char* msg_literal = "message"
+
+ if self.__exists:
+ if msg:
+ account.purple_account_set_status(self._get_structure(),
+ type, True, msg_literal, msg, NULL)
+ else:
+ account.purple_account_set_status(self._get_structure(),
+ 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
+
+include "buddy.pyx"