You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.6 KiB
Python
50 lines
1.6 KiB
Python
from freeposte.admin import app, db, models, forms, access
|
|
|
|
import flask
|
|
import flask_login
|
|
|
|
|
|
@app.route('/admin/list', methods=['GET'])
|
|
@access.global_admin
|
|
def admin_list():
|
|
admins = models.User.query.filter_by(global_admin=True)
|
|
return flask.render_template('admin/list.html', admins=admins)
|
|
|
|
|
|
@app.route('/admin/create', methods=['GET', 'POST'])
|
|
@access.global_admin
|
|
def admin_create():
|
|
form = forms.AdminForm()
|
|
form.admin.choices = [
|
|
(user.email, user.email)
|
|
for user in
|
|
flask_login.current_user.get_managed_emails(include_aliases=False)
|
|
]
|
|
if form.validate_on_submit():
|
|
user = models.User.query.get(form.admin.data)
|
|
if user:
|
|
user.global_admin = True
|
|
db.session.commit()
|
|
flask.flash('User %s is now admin' % user)
|
|
return flask.redirect(flask.url_for('.admin_list'))
|
|
else:
|
|
flask.flash('No such user', 'error')
|
|
return flask.render_template('admin/create.html', form=form)
|
|
|
|
|
|
@app.route('/admin/delete/<admin>', methods=['GET', 'POST'])
|
|
@access.global_admin
|
|
@access.confirmation_required("delete admin {admin}")
|
|
def admin_delete(admin):
|
|
user = models.User.query.get(admin)
|
|
if user:
|
|
user.global_admin = False
|
|
db.session.commit()
|
|
flask.flash('User %s is no longer admin' % user)
|
|
return flask.redirect(flask.url_for('.admin_list'))
|
|
else:
|
|
flask.flash('No such user', 'error')
|
|
flask.flash('Alias %s deleted' % alias)
|
|
return flask.redirect(
|
|
flask.url_for('.alias_list', domain_name=alias.domain.name))
|