mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-09 20:05:39 +00:00
Add list to manage with an account associated domains
This commit is contained in:
parent
e6f6f9cea4
commit
6a2ba1b1c3
@ -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'))
|
||||||
|
@ -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,40 +149,44 @@
|
|||||||
{% 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}'>`,
|
||||||
afterInit: function (ms) {
|
selectionHeader: `<input type='text' class='search-input' autocomplete='off' placeholder='${placeholder}'>`,
|
||||||
var that = this,
|
afterInit: function (ms) {
|
||||||
$selectableSearch = that.$selectableUl.prev(),
|
var that = this,
|
||||||
$selectionSearch = that.$selectionUl.prev(),
|
$selectableSearch = that.$selectableUl.prev(),
|
||||||
selectableSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selectable:not(.ms-selected)',
|
$selectionSearch = that.$selectionUl.prev(),
|
||||||
selectionSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selection.ms-selected';
|
selectableSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selectable:not(.ms-selected)',
|
||||||
|
selectionSearchString = '#' + that.$container.attr('id') + ' .ms-elem-selection.ms-selected';
|
||||||
|
|
||||||
that.qs1 = $selectableSearch.quicksearch(selectableSearchString)
|
that.qs1 = $selectableSearch.quicksearch(selectableSearchString)
|
||||||
.on('keydown', function (e) {
|
.on('keydown', function (e) {
|
||||||
if (e.which === 40) {
|
if (e.which === 40) {
|
||||||
that.$selectableUl.focus();
|
that.$selectableUl.focus();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
that.qs2 = $selectionSearch.quicksearch(selectionSearchString)
|
that.qs2 = $selectionSearch.quicksearch(selectionSearchString)
|
||||||
.on('keydown', function (e) {
|
.on('keydown', function (e) {
|
||||||
if (e.which == 40) {
|
if (e.which == 40) {
|
||||||
that.$selectionUl.focus();
|
that.$selectionUl.focus();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
afterSelect: function () {
|
afterSelect: function () {
|
||||||
this.qs1.cache();
|
this.qs1.cache();
|
||||||
this.qs2.cache();
|
this.qs2.cache();
|
||||||
},
|
},
|
||||||
afterDeselect: function () {
|
afterDeselect: function () {
|
||||||
this.qs1.cache();
|
this.qs1.cache();
|
||||||
this.qs2.cache();
|
this.qs2.cache();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
addMultiSelect("#account_multi_user", "Username")
|
||||||
|
addMultiSelect("#account_domains", "Domain")
|
||||||
</script>
|
</script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
Loading…
Reference in New Issue
Block a user