Add list to manage with an account associated domains

This commit is contained in:
AdvanticGmbH 2022-06-28 11:15:43 +02:00
parent e6f6f9cea4
commit 6a2ba1b1c3
2 changed files with 95 additions and 40 deletions

View File

@ -610,14 +610,24 @@ def manage_user():
@operator_role_required @operator_role_required
def edit_account(account_name=None): def edit_account(account_name=None):
users = User.query.all() users = User.query.all()
account = Account.query.filter(
Account.name == account_name).first()
all_accounts = Account.query.all()
accounts = {}
domains = Domain.query.all()
for acc in all_accounts:
accounts[acc.id] = acc
if request.method == 'GET': if request.method == 'GET':
if account_name is None: if account_name is None or not account:
return render_template('admin_edit_account.html', return render_template('admin_edit_account.html',
account=None,
account_user_ids=[], account_user_ids=[],
users=users, users=users,
domains=domains,
accounts=accounts,
create=1) create=1)
else: else:
account = Account.query.filter( account = Account.query.filter(
Account.name == account_name).first() Account.name == account_name).first()
@ -626,11 +636,14 @@ def edit_account(account_name=None):
account=account, account=account,
account_user_ids=account_user_ids, account_user_ids=account_user_ids,
users=users, users=users,
domains=domains,
accounts=accounts,
create=0) create=0)
if request.method == 'POST': if request.method == 'POST':
fdata = request.form fdata = request.form
new_user_list = request.form.getlist('account_multi_user') new_user_list = request.form.getlist('account_multi_user')
new_domain_list = request.form.getlist('account_domains')
# on POST, synthesize account and account_user_ids from form data # on POST, synthesize account and account_user_ids from form data
if not account_name: if not account_name:
@ -654,6 +667,8 @@ def edit_account(account_name=None):
account=account, account=account,
account_user_ids=account_user_ids, account_user_ids=account_user_ids,
users=users, users=users,
domains=domains,
accounts=accounts,
create=create, create=create,
invalid_accountname=True) invalid_accountname=True)
@ -662,19 +677,33 @@ def edit_account(account_name=None):
account=account, account=account,
account_user_ids=account_user_ids, account_user_ids=account_user_ids,
users=users, users=users,
domains=domains,
accounts=accounts,
create=create, create=create,
duplicate_accountname=True) duplicate_accountname=True)
result = account.create_account() result = account.create_account()
history = History(msg='Create account {0}'.format(account.name),
created_by=current_user.username)
else: else:
result = account.update_account() result = account.update_account()
history = History(msg='Update account {0}'.format(account.name),
created_by=current_user.username)
if result['status']: if result['status']:
account = Account.query.filter(
Account.name == account_name).first()
old_domains = Domain.query.filter(Domain.account_id == account.id).all()
for domain_name in new_domain_list:
domain = Domain.query.filter(
Domain.name == domain_name).first()
if account.id != domain.account_id:
Domain(name=domain_name).assoc_account(account.id)
for domain in old_domains:
if domain.name not in new_domain_list:
Domain(name=domain.name).assoc_account(None)
history = History(msg='{0} account {1}'.format('Create' if create else 'Update', account.name),
created_by=current_user.username)
account.grant_privileges(new_user_list) account.grant_privileges(new_user_list)
history.add() history.add()
return redirect(url_for('admin.manage_account')) return redirect(url_for('admin.manage_account'))

View File

@ -90,6 +90,28 @@
</select> </select>
</div> </div>
</div> </div>
<div class="box-body">
<p>Domains on the right are associated with the account. Red marked domain names are already associated with other accounts.
Moving already associated domains to this account will overwrite the previous associated account.
</p>
<p>Hover over the red domain names to show the associated account. Click on domains to move between columns.</p>
<div class="form-group col-xs-2">
<select multiple="multiple" class="form-control" id="account_domains"
name="account_domains">
{% for domain in domains %}
{% if account != None and domain.account_id != None and account.id != domain.account_id %}
{% with account_id=domain.account_id %}
<option style="color: red" data-toggle="tooltip" title="Associated with: {{ accounts[account_id].name }}"
value="{{ domain.name }}">{{ domain.name }}</option>
{% endwith %}
{% else %}
<option {% if account.id == domain.account_id %}selected{% endif %}
value="{{ domain.name }}">{{ domain.name }}</option>
{% endif %}
{% endfor %}
</select>
</div>
</div>
<div class="box-footer"> <div class="box-footer">
<button type="submit" <button type="submit"
class="btn btn-flat btn-primary">{% if create %}Create{% else %}Update{% endif %} class="btn btn-flat btn-primary">{% if create %}Create{% else %}Update{% endif %}
@ -127,9 +149,10 @@
{% endblock %} {% endblock %}
{% block extrascripts %} {% block extrascripts %}
<script> <script>
$("#account_multi_user").multiSelect({ function addMultiSelect(id, placeholder) {
selectableHeader: "<input type='text' class='search-input' autocomplete='off' placeholder='Username'>", $(id).multiSelect({
selectionHeader: "<input type='text' class='search-input' autocomplete='off' placeholder='Username'>", selectableHeader: `<input type='text' class='search-input' autocomplete='off' placeholder='${placeholder}'>`,
selectionHeader: `<input type='text' class='search-input' autocomplete='off' placeholder='${placeholder}'>`,
afterInit: function (ms) { afterInit: function (ms) {
var that = this, var that = this,
$selectableSearch = that.$selectableUl.prev(), $selectableSearch = that.$selectableUl.prev(),
@ -162,5 +185,8 @@
this.qs2.cache(); this.qs2.cache();
} }
}); });
}
addMultiSelect("#account_multi_user", "Username")
addMultiSelect("#account_domains", "Domain")
</script> </script>
{% endblock %} {% endblock %}