1 # GNU MediaGoblin -- federated, autonomous media hosting
2 # Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
4 # This program is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU Affero General Public License as published by
6 # the Free Software Foundation, either version 3 of the License, or
7 # (at your option) any later version.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU Affero General Public License for more details.
14 # You should have received a copy of the GNU Affero General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
17 from __future__
import print_function
21 from mediagoblin
.gmg_commands
import util
as commands_util
22 from mediagoblin
import auth
23 from mediagoblin
import mg_globals
25 def adduser_parser_setup(subparser
):
26 subparser
.add_argument(
28 help="Username used to login")
29 subparser
.add_argument(
31 help="Your supersecret word to login, beware of storing it in bash history")
32 subparser
.add_argument(
34 help="Email to receive notifications")
38 #TODO: Lets trust admins this do not validate Emails :)
39 commands_util
.setup_app(args
)
41 args
.username
= unicode(commands_util
.prompt_if_not_set(args
.username
, "Username:"))
42 args
.password
= commands_util
.prompt_if_not_set(args
.password
, "Password:",True)
43 args
.email
= commands_util
.prompt_if_not_set(args
.email
, "Email:")
45 db
= mg_globals
.database
46 users_with_username
= \
47 db
.User
.query
.filter_by(
48 username
=args
.username
.lower()
51 if users_with_username
:
52 print(u
'Sorry, a user with that name already exists.')
57 entry
.username
= six
.text_type(args
.username
.lower())
58 entry
.email
= six
.text_type(args
.email
)
59 entry
.pw_hash
= auth
.gen_password_hash(args
.password
)
60 default_privileges
= [
61 db
.Privilege
.query
.filter(
62 db
.Privilege
.privilege_name
==u
'commenter').one(),
63 db
.Privilege
.query
.filter(
64 db
.Privilege
.privilege_name
==u
'uploader').one(),
65 db
.Privilege
.query
.filter(
66 db
.Privilege
.privilege_name
==u
'reporter').one(),
67 db
.Privilege
.query
.filter(
68 db
.Privilege
.privilege_name
==u
'active').one()
70 entry
.all_privileges
= default_privileges
73 print(u
"User created (and email marked as verified)")
76 def makeadmin_parser_setup(subparser
):
77 subparser
.add_argument(
79 help="Username to give admin level")
83 commands_util
.setup_app(args
)
85 db
= mg_globals
.database
87 user
= db
.User
.query
.filter_by(
88 username
=six
.text_type(args
.username
.lower())).one()
90 user
.all_privileges
.append(
91 db
.Privilege
.query
.filter(
92 db
.Privilege
.privilege_name
==u
'admin').one()
95 print(u
'The user is now Admin')
97 print(u
'The user doesn\'t exist')
100 def changepw_parser_setup(subparser
):
101 subparser
.add_argument(
103 help="Username used to login")
104 subparser
.add_argument(
106 help="Your NEW supersecret word to login")
110 commands_util
.setup_app(args
)
112 db
= mg_globals
.database
114 user
= db
.User
.query
.filter_by(
115 username
=six
.text_type(args
.username
.lower())).one()
117 user
.pw_hash
= auth
.gen_password_hash(args
.password
)
119 print(u
'Password successfully changed')
121 print(u
'The user doesn\'t exist')
124 def deleteuser_parser_setup(subparser
):
125 subparser
.add_argument(
127 help="Username to delete",
131 def deleteuser(args
):
132 commands_util
.setup_app(args
)
134 db
= mg_globals
.database
136 user
= db
.User
.query
.filter_by(username
=args
.username
.lower()).first()
139 print('The user %s has been deleted' % args
.username
)
141 print('The user %s doesn\'t exist' % args
.username
)