1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
# -*- coding: utf-8 -*-
# user
# Copyright (C) 2016 LEAP
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
"""
Bitmask Command Line interface: user
"""
import argparse
import getpass
import sys
from leap.bitmask.cli import command
class User(command.Command):
service = 'bonafide'
usage = '''{name} user <subcommand>
Bitmask account service
SUBCOMMANDS:
create Registers new user, if possible
auth Logs in against the provider
logout Ends any active session with the provider
active Shows the active user, if any
'''.format(name=command.appname)
commands = ['active']
def __init__(self):
super(User, self).__init__()
self.data.append('user')
def create(self, raw_args):
username = self.username(raw_args)
passwd = getpass.getpass()
self.data += ['signup', username, passwd, True]
return self._send(printer=command.default_dict_printer)
def auth(self, raw_args):
username = self.username(raw_args)
passwd = getpass.getpass()
self.data += ['authenticate', username, passwd, True]
return self._send(printer=command.default_dict_printer)
def logout(self, raw_args):
username = self.username(raw_args)
self.data += ['logout', username]
return self._send(printer=command.default_dict_printer)
def username(self, raw_args):
args = tuple([command.appname] + sys.argv[1:3])
parser = argparse.ArgumentParser(
description='Bitmask user',
prog='%s %s %s' % args)
parser.add_argument('username', nargs=1,
help='username ID, in the form <user@example.org>')
subargs = parser.parse_args(raw_args)
username = subargs.username[0]
if not username:
self._error("Missing username ID but needed for this command")
if '@' not in username:
self._error("Username ID must be in the form <user@example.org>")
return username
|