Mercurial > libervia-backend
diff sat_frontends/jp/cmd_invitation.py @ 2624:56f94936df1e
code style reformatting using black
author | Goffi <goffi@goffi.org> |
---|---|
date | Wed, 27 Jun 2018 20:14:46 +0200 |
parents | 26edcf3a30eb |
children | 378188abe941 |
line wrap: on
line diff
--- a/sat_frontends/jp/cmd_invitation.py Wed Jun 27 07:51:29 2018 +0200 +++ b/sat_frontends/jp/cmd_invitation.py Wed Jun 27 20:14:46 2018 +0200 @@ -29,32 +29,111 @@ class Create(base.CommandBase): - def __init__(self, host): - base.CommandBase.__init__(self, host, 'create', use_profile=False, use_output=C.OUTPUT_DICT, help=_(u'create and send an invitation')) - self.need_loop=True + base.CommandBase.__init__( + self, + host, + "create", + use_profile=False, + use_output=C.OUTPUT_DICT, + help=_(u"create and send an invitation"), + ) + self.need_loop = True def add_parser_options(self): - self.parser.add_argument("-j", "--jid", type=base.unicode_decoder, default='', help='jid of the invitee (default: generate one)') - self.parser.add_argument("-P", "--password", type=base.unicode_decoder, default='', help='password of the invitee profile/XMPP account (default: generate one)') - self.parser.add_argument("-n", "--name", type=base.unicode_decoder, default='', help='name of the invitee') - self.parser.add_argument("-N", "--host-name", type=base.unicode_decoder, default='', help='name of the host') - self.parser.add_argument("-e", "--email", action="append", type=base.unicode_decoder, default=[], help='email(s) to send the invitation to (if --no-email is set, email will just be saved)') - self.parser.add_argument("--no-email", action="store_true", help='do NOT send invitation email') - self.parser.add_argument("-l", "--lang", type=base.unicode_decoder, default='', help='main language spoken by the invitee') - self.parser.add_argument("-u", "--url", type=base.unicode_decoder, default='', help='template to construct the URL') - self.parser.add_argument("-s", "--subject", type=base.unicode_decoder, default='', help='subject of the invitation email (default: generic subject)') - self.parser.add_argument("-b", "--body", type=base.unicode_decoder, default='', help='body of the invitation email (default: generic body)') - self.parser.add_argument("-x", "--extra", metavar=('KEY', 'VALUE'), type=base.unicode_decoder, action='append', nargs=2, default=[], help='extra data to associate with invitation/invitee') - self.parser.add_argument("-p", "--profile", type=base.unicode_decoder, default='', help="profile doing the invitation (default: don't associate profile)") + self.parser.add_argument( + "-j", + "--jid", + type=base.unicode_decoder, + default="", + help="jid of the invitee (default: generate one)", + ) + self.parser.add_argument( + "-P", + "--password", + type=base.unicode_decoder, + default="", + help="password of the invitee profile/XMPP account (default: generate one)", + ) + self.parser.add_argument( + "-n", + "--name", + type=base.unicode_decoder, + default="", + help="name of the invitee", + ) + self.parser.add_argument( + "-N", + "--host-name", + type=base.unicode_decoder, + default="", + help="name of the host", + ) + self.parser.add_argument( + "-e", + "--email", + action="append", + type=base.unicode_decoder, + default=[], + help="email(s) to send the invitation to (if --no-email is set, email will just be saved)", + ) + self.parser.add_argument( + "--no-email", action="store_true", help="do NOT send invitation email" + ) + self.parser.add_argument( + "-l", + "--lang", + type=base.unicode_decoder, + default="", + help="main language spoken by the invitee", + ) + self.parser.add_argument( + "-u", + "--url", + type=base.unicode_decoder, + default="", + help="template to construct the URL", + ) + self.parser.add_argument( + "-s", + "--subject", + type=base.unicode_decoder, + default="", + help="subject of the invitation email (default: generic subject)", + ) + self.parser.add_argument( + "-b", + "--body", + type=base.unicode_decoder, + default="", + help="body of the invitation email (default: generic body)", + ) + self.parser.add_argument( + "-x", + "--extra", + metavar=("KEY", "VALUE"), + type=base.unicode_decoder, + action="append", + nargs=2, + default=[], + help="extra data to associate with invitation/invitee", + ) + self.parser.add_argument( + "-p", + "--profile", + type=base.unicode_decoder, + default="", + help="profile doing the invitation (default: don't associate profile)", + ) def invitationCreateCb(self, invitation_data): self.output(invitation_data) self.host.quit(C.EXIT_OK) def invitationCreateEb(self, failure_): - self.disp(u"can't create invitation: {reason}".format( - reason=failure_), error=True) + self.disp( + u"can't create invitation: {reason}".format(reason=failure_), error=True + ) self.host.quit(C.EXIT_BRIDGE_ERRBACK) def start(self): @@ -63,11 +142,13 @@ emails_extra = self.args.email[1:] if self.args.no_email: if email: - extra['email'] = email - data_format.iter2dict(u'emails_extra', emails_extra) + extra["email"] = email + data_format.iter2dict(u"emails_extra", emails_extra) else: if not email: - self.parser.error(_(u'you need to specify an email address to send email invitation')) + self.parser.error( + _(u"you need to specify an email address to send email invitation") + ) self.host.bridge.invitationCreate( email, @@ -83,46 +164,66 @@ extra, self.args.profile, callback=self.invitationCreateCb, - errback=self.invitationCreateEb) + errback=self.invitationCreateEb, + ) class Get(base.CommandBase): - def __init__(self, host): - base.CommandBase.__init__(self, host, 'get', use_profile=False, use_output=C.OUTPUT_DICT, help=_(u'get invitation data')) - self.need_loop=True + base.CommandBase.__init__( + self, + host, + "get", + use_profile=False, + use_output=C.OUTPUT_DICT, + help=_(u"get invitation data"), + ) + self.need_loop = True def add_parser_options(self): - self.parser.add_argument("id", type=base.unicode_decoder, - help=_(u"invitation UUID")) - self.parser.add_argument("-j", "--with-jid", action="store_true", help=_(u"start profile session and retrieve jid")) + self.parser.add_argument( + "id", type=base.unicode_decoder, help=_(u"invitation UUID") + ) + self.parser.add_argument( + "-j", + "--with-jid", + action="store_true", + help=_(u"start profile session and retrieve jid"), + ) def output_data(self, data, jid_=None): if jid_ is not None: - data['jid'] = jid_ + data["jid"] = jid_ self.output(data) self.host.quit() def invitationGetCb(self, invitation_data): if self.args.with_jid: - profile = invitation_data[u'guest_profile'] + profile = invitation_data[u"guest_profile"] + def session_started(dummy): self.host.bridge.asyncGetParamA( - u'JabberID', - u'Connection', + u"JabberID", + u"Connection", profile_key=profile, callback=lambda jid_: self.output_data(invitation_data, jid_), - errback=partial(self.errback, - msg=_(u"can't retrieve jid: {}"), - exit_code=C.EXIT_BRIDGE_ERRBACK)) + errback=partial( + self.errback, + msg=_(u"can't retrieve jid: {}"), + exit_code=C.EXIT_BRIDGE_ERRBACK, + ), + ) self.host.bridge.profileStartSession( - invitation_data[u'password'], + invitation_data[u"password"], profile, callback=session_started, - errback=partial(self.errback, - msg=_(u"can't start session: {}"), - exit_code=C.EXIT_BRIDGE_ERRBACK)) + errback=partial( + self.errback, + msg=_(u"can't start session: {}"), + exit_code=C.EXIT_BRIDGE_ERRBACK, + ), + ) else: self.output_data(invitation_data) @@ -130,61 +231,120 @@ self.host.bridge.invitationGet( self.args.id, callback=self.invitationGetCb, - errback=partial(self.errback, - msg=_(u"can't get invitation data: {}"), - exit_code=C.EXIT_BRIDGE_ERRBACK)) + errback=partial( + self.errback, + msg=_(u"can't get invitation data: {}"), + exit_code=C.EXIT_BRIDGE_ERRBACK, + ), + ) class Modify(base.CommandBase): - def __init__(self, host): - base.CommandBase.__init__(self, host, 'modify', use_profile=False, help=_(u'modify existing invitation')) - self.need_loop=True + base.CommandBase.__init__( + self, host, "modify", use_profile=False, help=_(u"modify existing invitation") + ) + self.need_loop = True def add_parser_options(self): - self.parser.add_argument("--replace", action='store_true', help='replace the whole data') - self.parser.add_argument("-n", "--name", type=base.unicode_decoder, default='', help='name of the invitee') - self.parser.add_argument("-N", "--host-name", type=base.unicode_decoder, default='', help='name of the host') - self.parser.add_argument("-e", "--email", type=base.unicode_decoder, default='', help='email to send the invitation to (if --no-email is set, email will just be saved)') - self.parser.add_argument("-l", "--lang", dest="language", type=base.unicode_decoder, default='', - help='main language spoken by the invitee') - self.parser.add_argument("-x", "--extra", metavar=('KEY', 'VALUE'), type=base.unicode_decoder, action='append', nargs=2, default=[], help='extra data to associate with invitation/invitee') - self.parser.add_argument("-p", "--profile", type=base.unicode_decoder, default='', help="profile doing the invitation (default: don't associate profile") - self.parser.add_argument("id", type=base.unicode_decoder, - help=_(u"invitation UUID")) + self.parser.add_argument( + "--replace", action="store_true", help="replace the whole data" + ) + self.parser.add_argument( + "-n", + "--name", + type=base.unicode_decoder, + default="", + help="name of the invitee", + ) + self.parser.add_argument( + "-N", + "--host-name", + type=base.unicode_decoder, + default="", + help="name of the host", + ) + self.parser.add_argument( + "-e", + "--email", + type=base.unicode_decoder, + default="", + help="email to send the invitation to (if --no-email is set, email will just be saved)", + ) + self.parser.add_argument( + "-l", + "--lang", + dest="language", + type=base.unicode_decoder, + default="", + help="main language spoken by the invitee", + ) + self.parser.add_argument( + "-x", + "--extra", + metavar=("KEY", "VALUE"), + type=base.unicode_decoder, + action="append", + nargs=2, + default=[], + help="extra data to associate with invitation/invitee", + ) + self.parser.add_argument( + "-p", + "--profile", + type=base.unicode_decoder, + default="", + help="profile doing the invitation (default: don't associate profile", + ) + self.parser.add_argument( + "id", type=base.unicode_decoder, help=_(u"invitation UUID") + ) def invitationModifyCb(self): - self.disp(_(u'invitations have been modified correctly')) + self.disp(_(u"invitations have been modified correctly")) self.host.quit(C.EXIT_OK) def invitationModifyEb(self, failure_): - self.disp(u"can't create invitation: {reason}".format( - reason=failure_), error=True) + self.disp( + u"can't create invitation: {reason}".format(reason=failure_), error=True + ) self.host.quit(C.EXIT_BRIDGE_ERRBACK) def start(self): extra = dict(self.args.extra) - for arg_name in ('name', 'host_name', 'email', 'language', 'profile'): + for arg_name in ("name", "host_name", "email", "language", "profile"): value = getattr(self.args, arg_name) if not value: continue if arg_name in extra: - self.parser.error(_(u"you can't set {arg_name} in both optional argument and extra").format(arg_name=arg_name)) + self.parser.error( + _( + u"you can't set {arg_name} in both optional argument and extra" + ).format(arg_name=arg_name) + ) extra[arg_name] = value self.host.bridge.invitationModify( self.args.id, extra, self.args.replace, callback=self.invitationModifyCb, - errback=self.invitationModifyEb) + errback=self.invitationModifyEb, + ) class List(base.CommandBase): - def __init__(self, host): - extra_outputs = {'default': self.default_output} - base.CommandBase.__init__(self, host, 'list', use_profile=False, use_output=C.OUTPUT_COMPLEX, extra_outputs=extra_outputs, help=_(u'list invitations data')) - self.need_loop=True + extra_outputs = {"default": self.default_output} + base.CommandBase.__init__( + self, + host, + "list", + use_profile=False, + use_output=C.OUTPUT_COMPLEX, + extra_outputs=extra_outputs, + help=_(u"list invitations data"), + ) + self.need_loop = True def default_output(self, data): for idx, datum in enumerate(data.iteritems()): @@ -192,12 +352,17 @@ self.disp(u"\n") key, invitation_data = datum self.disp(A.color(C.A_HEADER, key)) - indent = u' ' + indent = u" " for k, v in invitation_data.iteritems(): - self.disp(indent + A.color(C.A_SUBHEADER, k + u':') + u' ' + unicode(v)) + self.disp(indent + A.color(C.A_SUBHEADER, k + u":") + u" " + unicode(v)) def add_parser_options(self): - self.parser.add_argument("-p", "--profile", default=C.PROF_KEY_NONE, help=_(u"return only invitations linked to this profile")) + self.parser.add_argument( + "-p", + "--profile", + default=C.PROF_KEY_NONE, + help=_(u"return only invitations linked to this profile"), + ) def invitationListCb(self, data): self.output(data) @@ -207,13 +372,21 @@ self.host.bridge.invitationList( self.args.profile, callback=self.invitationListCb, - errback=partial(self.errback, - msg=_(u"can't list invitations: {}"), - exit_code=C.EXIT_BRIDGE_ERRBACK)) + errback=partial( + self.errback, + msg=_(u"can't list invitations: {}"), + exit_code=C.EXIT_BRIDGE_ERRBACK, + ), + ) class Invitation(base.CommandBase): subcommands = (Create, Get, Modify, List) def __init__(self, host): - super(Invitation, self).__init__(host, 'invitation', use_profile=False, help=_(u'invitation of user(s) without XMPP account')) + super(Invitation, self).__init__( + host, + "invitation", + use_profile=False, + help=_(u"invitation of user(s) without XMPP account"), + )