2017-09-24 12:00:39 +02:00
|
|
|
from mailu import db, models
|
|
|
|
from mailu.ui import ui, access, forms
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
import flask
|
2016-08-13 20:51:54 +02:00
|
|
|
import flask_login
|
2017-02-02 22:29:33 +01:00
|
|
|
import wtforms
|
2016-03-22 19:47:15 +01:00
|
|
|
import wtforms_components
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/list/<domain_name>', methods=['GET'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.domain_admin(models.Domain, 'domain_name')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_list(domain_name):
|
2016-08-29 19:24:39 +02:00
|
|
|
domain = models.Domain.query.get(domain_name) or flask.abort(404)
|
2016-03-19 20:37:48 +01:00
|
|
|
return flask.render_template('user/list.html', domain=domain)
|
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/create/<domain_name>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.domain_admin(models.Domain, 'domain_name')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_create(domain_name):
|
2016-08-29 19:24:39 +02:00
|
|
|
domain = models.Domain.query.get(domain_name) or flask.abort(404)
|
2016-03-20 15:36:56 +01:00
|
|
|
if domain.max_users and len(domain.users) >= domain.max_users:
|
2016-03-19 20:37:48 +01:00
|
|
|
flask.flash('Too many users for domain %s' % domain, 'error')
|
2016-03-20 15:36:56 +01:00
|
|
|
return flask.redirect(
|
|
|
|
flask.url_for('.user_list', domain_name=domain.name))
|
2016-03-22 19:47:15 +01:00
|
|
|
form = forms.UserForm()
|
2017-02-14 21:37:51 +01:00
|
|
|
if domain.max_quota_bytes:
|
|
|
|
form.quota_bytes.validators = [
|
|
|
|
wtforms.validators.NumberRange(max=domain.max_quota_bytes)]
|
2016-03-19 20:37:48 +01:00
|
|
|
if form.validate_on_submit():
|
2016-05-01 20:04:40 +02:00
|
|
|
if domain.has_email(form.localpart.data):
|
2016-05-01 21:12:08 +02:00
|
|
|
flask.flash('Email is already used', 'error')
|
2016-03-19 20:37:48 +01:00
|
|
|
else:
|
2016-05-01 21:12:08 +02:00
|
|
|
user = models.User(domain=domain)
|
|
|
|
form.populate_obj(user)
|
2016-03-19 20:37:48 +01:00
|
|
|
user.set_password(form.pw.data)
|
|
|
|
db.session.add(user)
|
|
|
|
db.session.commit()
|
|
|
|
flask.flash('User %s created' % user)
|
|
|
|
return flask.redirect(
|
2016-03-20 15:36:56 +01:00
|
|
|
flask.url_for('.user_list', domain_name=domain.name))
|
2016-03-19 20:37:48 +01:00
|
|
|
return flask.render_template('user/create.html',
|
|
|
|
domain=domain, form=form)
|
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/edit/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.domain_admin(models.User, 'user_email')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_edit(user_email):
|
2016-08-29 19:24:39 +02:00
|
|
|
user = models.User.query.get(user_email) or flask.abort(404)
|
2017-02-02 22:29:33 +01:00
|
|
|
# Handle the case where user quota is more than allowed
|
|
|
|
max_quota_bytes = user.domain.max_quota_bytes
|
|
|
|
if max_quota_bytes and user.quota_bytes > max_quota_bytes:
|
|
|
|
max_quota_bytes = user.quota_bytes
|
|
|
|
# Create the form
|
2016-03-22 19:47:15 +01:00
|
|
|
form = forms.UserForm(obj=user)
|
|
|
|
wtforms_components.read_only(form.localpart)
|
|
|
|
form.pw.validators = []
|
2017-01-25 00:05:03 +01:00
|
|
|
form.localpart.validators = []
|
2017-02-14 21:37:51 +01:00
|
|
|
if max_quota_bytes:
|
|
|
|
form.quota_bytes.validators = [
|
|
|
|
wtforms.validators.NumberRange(max=max_quota_bytes)]
|
2016-03-19 20:37:48 +01:00
|
|
|
if form.validate_on_submit():
|
2016-05-01 21:12:08 +02:00
|
|
|
form.populate_obj(user)
|
2016-03-22 21:15:57 +01:00
|
|
|
if form.pw.data:
|
|
|
|
user.set_password(form.pw.data)
|
2016-03-19 20:37:48 +01:00
|
|
|
db.session.commit()
|
|
|
|
flask.flash('User %s updated' % user)
|
|
|
|
return flask.redirect(
|
2016-03-20 15:36:56 +01:00
|
|
|
flask.url_for('.user_list', domain_name=user.domain.name))
|
2017-02-02 22:29:33 +01:00
|
|
|
return flask.render_template('user/edit.html', form=form, user=user,
|
|
|
|
domain=user.domain, max_quota_bytes=max_quota_bytes)
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/delete/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.domain_admin(models.User, 'user_email')
|
2016-08-29 19:35:09 +02:00
|
|
|
@access.confirmation_required("delete {user_email}")
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_delete(user_email):
|
2016-08-29 19:24:39 +02:00
|
|
|
user = models.User.query.get(user_email) or flask.abort(404)
|
2016-11-12 15:47:48 +01:00
|
|
|
domain = user.domain
|
2016-03-19 20:37:48 +01:00
|
|
|
db.session.delete(user)
|
|
|
|
db.session.commit()
|
|
|
|
flask.flash('User %s deleted' % user)
|
2016-03-20 15:36:56 +01:00
|
|
|
return flask.redirect(
|
2016-11-12 15:47:48 +01:00
|
|
|
flask.url_for('.user_list', domain_name=domain.name))
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/settings', methods=['GET', 'POST'], defaults={'user_email': None})
|
|
|
|
@ui.route('/user/usersettings/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.owner(models.User, 'user_email')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_settings(user_email):
|
2016-10-02 10:14:53 +02:00
|
|
|
user_email_or_current = user_email or flask_login.current_user.email
|
|
|
|
user = models.User.query.get(user_email_or_current) or flask.abort(404)
|
2016-03-20 11:14:27 +01:00
|
|
|
form = forms.UserSettingsForm(obj=user)
|
2016-03-20 11:09:06 +01:00
|
|
|
if form.validate_on_submit():
|
2016-05-01 21:12:08 +02:00
|
|
|
form.populate_obj(user)
|
2016-03-20 11:09:06 +01:00
|
|
|
db.session.commit()
|
|
|
|
flask.flash('Settings updated for %s' % user)
|
|
|
|
if user_email:
|
|
|
|
return flask.redirect(
|
2016-03-20 15:36:56 +01:00
|
|
|
flask.url_for('.user_list', domain_name=user.domain.name))
|
2016-03-20 11:09:06 +01:00
|
|
|
return flask.render_template('user/settings.html', form=form, user=user)
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/password', methods=['GET', 'POST'], defaults={'user_email': None})
|
|
|
|
@ui.route('/user/password/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.owner(models.User, 'user_email')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_password(user_email):
|
2016-10-02 10:14:53 +02:00
|
|
|
user_email_or_current = user_email or flask_login.current_user.email
|
|
|
|
user = models.User.query.get(user_email_or_current) or flask.abort(404)
|
2016-03-19 20:37:48 +01:00
|
|
|
form = forms.UserPasswordForm()
|
|
|
|
if form.validate_on_submit():
|
|
|
|
if form.pw.data != form.pw2.data:
|
|
|
|
flask.flash('Passwords do not match', 'error')
|
|
|
|
else:
|
|
|
|
user.set_password(form.pw.data)
|
|
|
|
db.session.commit()
|
|
|
|
flask.flash('Password updated for %s' % user)
|
|
|
|
if user_email:
|
2016-03-20 15:36:56 +01:00
|
|
|
return flask.redirect(flask.url_for('.user_list',
|
|
|
|
domain_name=user.domain.name))
|
2016-03-19 20:37:48 +01:00
|
|
|
return flask.render_template('user/password.html', form=form, user=user)
|
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/forward', methods=['GET', 'POST'], defaults={'user_email': None})
|
|
|
|
@ui.route('/user/forward/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.owner(models.User, 'user_email')
|
2016-03-19 20:37:48 +01:00
|
|
|
def user_forward(user_email):
|
2016-10-02 10:14:53 +02:00
|
|
|
user_email_or_current = user_email or flask_login.current_user.email
|
|
|
|
user = models.User.query.get(user_email_or_current) or flask.abort(404)
|
2016-03-20 11:14:27 +01:00
|
|
|
form = forms.UserForwardForm(obj=user)
|
2016-03-19 20:37:48 +01:00
|
|
|
if form.validate_on_submit():
|
2016-05-29 17:06:06 +02:00
|
|
|
form.populate_obj(user)
|
2016-03-19 20:37:48 +01:00
|
|
|
db.session.commit()
|
|
|
|
flask.flash('Forward destination updated for %s' % user)
|
|
|
|
if user_email:
|
|
|
|
return flask.redirect(
|
2016-03-20 15:36:56 +01:00
|
|
|
flask.url_for('.user_list', domain_name=user.domain.name))
|
2016-03-20 11:00:01 +01:00
|
|
|
return flask.render_template('user/forward.html', form=form, user=user)
|
2016-03-19 20:37:48 +01:00
|
|
|
|
|
|
|
|
2017-09-24 12:00:39 +02:00
|
|
|
@ui.route('/user/reply', methods=['GET', 'POST'], defaults={'user_email': None})
|
|
|
|
@ui.route('/user/reply/<user_email>', methods=['GET', 'POST'])
|
2016-08-29 19:24:39 +02:00
|
|
|
@access.owner(models.User, 'user_email')
|
2016-03-20 11:00:01 +01:00
|
|
|
def user_reply(user_email):
|
2016-10-02 10:14:53 +02:00
|
|
|
user_email_or_current = user_email or flask_login.current_user.email
|
|
|
|
user = models.User.query.get(user_email_or_current) or flask.abort(404)
|
2016-03-20 11:14:27 +01:00
|
|
|
form = forms.UserReplyForm(obj=user)
|
2016-03-20 11:00:01 +01:00
|
|
|
if form.validate_on_submit():
|
2016-05-01 21:12:08 +02:00
|
|
|
form.populate_obj(user)
|
2016-03-20 11:00:01 +01:00
|
|
|
db.session.commit()
|
|
|
|
flask.flash('Auto-reply message updated for %s' % user)
|
|
|
|
if user_email:
|
|
|
|
return flask.redirect(
|
2016-03-20 15:36:56 +01:00
|
|
|
flask.url_for('.user_list', domain_name=user.domain.name))
|
2016-03-20 11:00:01 +01:00
|
|
|
return flask.render_template('user/reply.html', form=form, user=user)
|