changeset 657:09bbd5c00244

jp: profiles management
author Dal <kedals0@gmail.com>
date Mon, 07 Oct 2013 14:56:09 +0200 (2013-10-07)
parents 7d6e5807504a
children e26134122ed7
files frontends/src/jp/jp
diffstat 1 files changed, 60 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/frontends/src/jp/jp	Wed Oct 02 20:25:19 2013 +0200
+++ b/frontends/src/jp/jp	Mon Oct 07 14:56:09 2013 +0200
@@ -108,6 +108,14 @@
                     help=_("Separate xmpp messages: send one message per line instead of one message alone."))
         parser.add_option("-n", "--new-line", action="store_true", default=False,
                     help=_("Add a new line at the beginning of the input (usefull for ascii art ;))"))
+        parser.add_option("--list-profiles", action="store_true", default=False,
+                    help=_("List available profiles"))
+        parser.add_option("-c", "--create-profile", action="store", type="string", nargs=3,
+                    help=_("Create a profile (args: profile_name jid password)"))
+        parser.add_option("--get-profile", action="store", type="string",
+                    help=_("Get profile informations (arg: profile_name)"))
+        parser.add_option("--rm-profile", action="store", type="string",
+                    help=_("Remove profile"))
         parser.add_option("--connect", action="store_true", default=False,
                     help=_("Connect the profile before doing anything else"))
         parser.add_option("--pipe-in", action="store_true", default=False,
@@ -116,6 +124,16 @@
                     help=_("Pipe a stream out "))
 
         (self.options, args) = parser.parse_args()
+        if self.options.list_profiles:
+            for p in self.bridge.getProfilesList():
+                info(p)
+            exit(0)
+        if self.options.create_profile or self.options.get_profile:
+            self.start_loop = True
+            return args
+        if self.options.rm_profile:
+            self.start_loop = False
+            return args
 
         if len(args) < 1 and not self.options.wait_file:
             parser.error(_("You must specify the destination JID (Jabber ID)").encode('utf-8'))
@@ -140,6 +158,40 @@
 
         return args
 
+    def create_profile(self):
+        """Create a new profile"""
+        profile, jid, password = self.options.create_profile
+        if profile in self.bridge.getProfilesList():
+            error("Profile %s already exists."%profile)
+            exit(1)
+        self.bridge.asyncCreateProfile(profile, lambda : self._create_profile(profile, jid, password), None)
+
+    def get_profile(self):
+        def setJID(jid):
+            info("jid: %s"%jid)
+            self.bridge.asyncGetParamA("Password", "Connection", profile_key=profile_name, callback=setPassword)
+        def setPassword(password):
+            info("pwd: %s"%password)
+            self.loop.quit()
+        profile_name  = self.options.get_profile
+        if profile_name not in self.bridge.getProfilesList():
+            error("Profile %s doesn't exist."%profile_name)
+            exit(1)
+        self.bridge.asyncGetParamA("JabberID", "Connection", profile_key=profile_name, callback=setJID)
+
+    def rm_profile(self):
+        profile_name  = self.options.rm_profile
+        if profile_name not in self.bridge.getProfilesList():
+            error("Profile %s doesn't exist."%profile_name)
+            exit(1)
+        self.bridge.deleteProfile(profile_name)
+
+    def _create_profile(self, profile_name, jid, password):
+        self.bridge.setParam("JabberID", jid, "Connection" ,profile_key=profile_name)
+        self.bridge.setParam("Server", JID(jid).domain, "Connection", profile_key=profile_name)
+        self.bridge.setParam("Password", password, "Connection", profile_key=profile_name)
+        self.loop.quit()
+
     def check_jabber_status(self):
         """Check that jabber status is allright"""
         def cantConnect():
@@ -352,7 +404,14 @@
 
     def go(self):
         self.check_options()
-        self.check_jabber_status()
+        if self.options.create_profile:
+            self.create_profile()
+        elif self.options.get_profile:
+            self.get_profile()
+        elif self.options.rm_profile:
+            self.rm_profile()
+        else:
+            self.check_jabber_status()
         if self.start_loop:
             self.loop = gobject.MainLoop()
             try: