Fixed accounts.pxd recursive call from other .pxd files.
[python-purple] / nullclient.py
index 375625f..81a5ac2 100644 (file)
 import purple
 import purple
+import ecore
+import getpass
+import sys
+
+cbs = {}
+acc_cbs = {}
+blist_cbs = {}
+conn_cbs = {}
+conv_cbs = {}
+notify_cbs = {}
+request_cbs = {}
+signal_cbs = {}
+
+def account_callback(name):
+    print "---- account callback example: %s" % name
+
+acc_cbs["notify_added"] = account_callback
+acc_cbs["status_changed"] = account_callback
+acc_cbs["request_add"] = account_callback
+acc_cbs["request_authorize"] = account_callback
+acc_cbs["close_account_request"] = account_callback
+
+cbs["account"] = acc_cbs
+
+def blist_callback(name):
+    print "---- blist callback example: %s" % name
+
+blist_cbs["new_list"] = blist_callback
+blist_cbs["new_node"] = blist_callback
+blist_cbs["show"] = blist_callback
+blist_cbs["update"] = blist_callback
+blist_cbs["remove"] = blist_callback
+blist_cbs["destroy"] = blist_callback
+blist_cbs["set_visible"] = blist_callback
+blist_cbs["request_add_buddy"] = blist_callback
+blist_cbs["request_add_chat"] = blist_callback
+blist_cbs["request_add_group"] = blist_callback
+
+cbs["blist"] = blist_cbs
+
+def conn_callback(name):
+    print "---- connection callback example: %s" % name
+
+conn_cbs["connect_progress"] = conn_callback
+conn_cbs["connected"] = conn_callback
+conn_cbs["disconnected"] = conn_callback
+conn_cbs["notice"] = conn_callback
+conn_cbs["report_disconnect"] = conn_callback
+conn_cbs["network_connected"] = conn_callback
+conn_cbs["network_disconnected"] = conn_callback
+conn_cbs["report_disconnect_reason"] = conn_callback
+
+cbs["connection"] = conn_cbs
+
+def conv_callback(name):
+    print "---- conversation callback example: %s" % name
+
+conv_cbs["create_conversation"] = conv_callback
+conv_cbs["destroy_conversation"] = conv_callback
+conv_cbs["write_chat"] = conv_callback
+conv_cbs["write_im"] = conv_callback
+conv_cbs["write_conv"] = conv_callback
+conv_cbs["chat_add_users"] = conv_callback
+conv_cbs["chat_rename_user"] = conv_callback
+conv_cbs["chat_remove_users"] = conv_callback
+conv_cbs["chat_update_user"] = conv_callback
+conv_cbs["present"] = conv_callback
+conv_cbs["has_focus"] = conv_callback
+conv_cbs["custom_smiley_add"] = conv_callback
+conv_cbs["custom_smiley_write"] = conv_callback
+conv_cbs["custom_smiley_close"] = conv_callback
+conv_cbs["send_confirm"] = conv_callback
+
+cbs["conversation"] = conv_cbs
+
+def notify_callback(name):
+    print "----  notify callback example: %s" % name
+
+notify_cbs["notify_message"] = notify_callback
+notify_cbs["notify_email"] = notify_callback
+notify_cbs["notify_emails"] = notify_callback
+notify_cbs["notify_formatted"] = notify_callback
+notify_cbs["notify_searchresults"] = notify_callback
+notify_cbs["notify_searchresults_new_rows"] = notify_callback
+notify_cbs["notify_userinfo"] = notify_callback
+notify_cbs["notify_uri"] = notify_callback
+notify_cbs["close_notify"] = notify_callback
+
+cbs["notify"] = notify_cbs
+
+def request_callback(name):
+    print "---- request callback example: %s" % name
+
+request_cbs["request_input"] = request_callback
+request_cbs["request_choice"] = request_callback
+request_cbs["request_action"] = request_callback
+request_cbs["request_fields"] = request_callback
+request_cbs["request_file"] = request_callback
+request_cbs["close_request"] = request_callback
+request_cbs["request_folder"] = request_callback
+
+cbs["request"] = request_cbs
+
+def buddy_signed_off_cb(name):
+    print "---- signal callback example: sign off from buddy %s" % name
+
+def receiving_im_msg_cb(sender, message):
+    print "---- signal callback example: receiving im message from %s" % sender
+    print "---- message: %s" % message
+
+signal_cbs["buddy_signed_off"] = buddy_signed_off_cb
+signal_cbs["receiving_im_msg"] = receiving_im_msg_cb
 
 class NullClient:
     def __init__(self):
 
 class NullClient:
     def __init__(self):
-        self.p = purple.Purple()
+        self.p = purple.Purple(debug_enabled=False)
         self.account = None
 
     def execute(self):
         self.account = None
 
     def execute(self):
-        self.p.purple_init()
+        global cbs
+        self.p.purple_init(cbs)
 
     def set_protocol(self, protocol):
         for i in self.p.get_protocols():
 
     def set_protocol(self, protocol):
         for i in self.p.get_protocols():
@@ -20,13 +133,28 @@ class NullClient:
         self.account = purple.Account(username, protocol)
         self.account.set_password(password)
         self.account.set_enabled("carman-purple-python", True)
         self.account = purple.Account(username, protocol)
         self.account.set_password(password)
         self.account.set_enabled("carman-purple-python", True)
+    def get_buddies(self):
+        buddies = self.account.get_buddies_online()
+        print buddies
+
+def getuser():
+    sys.stdout.write("GTalk account: ")
+    username = sys.stdin.readline()
+    return username[:-1]
+
+def getpassword():
+    return getpass.getpass()
 
 if __name__ == '__main__':
 
     client = NullClient()
     client.execute()
     client.set_protocol("XMPP")
 
 if __name__ == '__main__':
 
     client = NullClient()
     client.execute()
     client.set_protocol("XMPP")
-    client.new_account("seu_email@email.com", client.protocol,"sua_senha_aqui")
+    username = getuser()
+    password = getpassword()
+    client.new_account(username, client.protocol, password)
 
     client.p.connect()
 
     client.p.connect()
-    client.p.run_loop()
+    client.p.attach_signals(signal_cbs)
+    ecore.timer_add(20, client.get_buddies)
+    ecore.main_loop_begin()