mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2024-11-10 07:30:26 +00:00
0ac33aa3c4
Update user management feature to allow editing user details directly in the admin user interface. Also added an option to reset the two factor authentication data of a user, for when that's needed (lost device, technical issues etc). (cherry picked from commit 3139616282a18c11463c6ecf78888417b2ac1c35)
154 lines
7.9 KiB
HTML
154 lines
7.9 KiB
HTML
{% extends "base.html" %}
|
|
{% block title %}<title>DNS Control Panel - Edit User</title>{% endblock %}
|
|
|
|
{% block dashboard_stat %}
|
|
<!-- Content Header (Page header) -->
|
|
<section class="content-header">
|
|
<h1>
|
|
User
|
|
<small>{% if create %}New user{% else %}{{ user.username }}{% endif %}</small>
|
|
</h1>
|
|
<ol class="breadcrumb">
|
|
<li><a href="{{ url_for('dashboard') }}"><i class="fa fa-dashboard"></i>Home</a></li>
|
|
<li><a href="{{ url_for('dashboard') }}">Admin</a></li>
|
|
<li class="active">{% if create %}Add{% else %}Edit{% endif %} user</li>
|
|
</ol>
|
|
</section>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<section class="content">
|
|
<div class="row">
|
|
<div class="col-md-4">
|
|
<div class="box box-primary">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title">{% if create %}Add{% else %}Edit{% endif %} user</h3>
|
|
</div>
|
|
<!-- /.box-header -->
|
|
<!-- form start -->
|
|
<form role="form" method="post" action="{% if create %}{{ url_for('admin_edituser') }}{% else %}{{ url_for('admin_edituser', user_username=user.username) }}{% endif %}">
|
|
<input type="hidden" name="create" value="{{ create }}">
|
|
<div class="box-body">
|
|
{% if error %}
|
|
<div class="alert alert-danger alert-dismissible">
|
|
<button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button>
|
|
<h4><i class="icon fa fa-ban"></i> Error!</h4>
|
|
{{ error }}
|
|
</div>
|
|
<span class="help-block">{{ error }}</span>
|
|
{% endif %}
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="firstname">First Name</label>
|
|
<input type="text" class="form-control" placeholder="First Name"
|
|
name="firstname" {% if user %}value={{ user.firstname }}{% endif %}> <span
|
|
class="glyphicon glyphicon-user form-control-feedback"></span>
|
|
</div>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="lastname">Last Name</label>
|
|
<input type="text" class="form-control" placeholder="Last name"
|
|
name="lastname" {% if user %}value={{ user.lastname }}{% endif %}> <span
|
|
class="glyphicon glyphicon-user form-control-feedback"></span>
|
|
</div>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="email">E-mail address</label>
|
|
<input type="email" class="form-control" placeholder="Email"
|
|
name="email" id="email" {% if user %}value={{ user.email }}{% endif %}> <span
|
|
class="glyphicon glyphicon-envelope form-control-feedback"></span>
|
|
</div>
|
|
<p class="login-box-msg">Enter the account details below</p>
|
|
<div class="form-group has-feedback">
|
|
<label class="control-label" for="username">Username</label>
|
|
<input type="text" class="form-control" placeholder="Username"
|
|
name="username" {% if user %}value={{ user.username }}{% endif %} {% if not create %}disabled{% endif %}> <span
|
|
class="glyphicon glyphicon-user form-control-feedback"></span>
|
|
</div>
|
|
<div class="form-group has-feedback {% if blank_password %}has-error{% endif %}">
|
|
<label class="control-label" for="username">Password</label>
|
|
<input type="password" class="form-control" placeholder="Password {% if create %}(Required){% else %}(Leave blank to keep unchanged){% endif %}"
|
|
name="password"> <span
|
|
class="glyphicon glyphicon-lock form-control-feedback"></span>
|
|
{% if blank_password %}
|
|
<span class="help-block">The password cannot be blank.</span>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
<div class="box-footer">
|
|
<button type="submit" class="btn btn-flat btn-primary">{% if create %}Create{% else %}Update{% endif %} User</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
{% if not create %}
|
|
<div class="box box-secondary">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title">Two Factor Authentication</h3>
|
|
</div>
|
|
<div class="box-body">
|
|
<p>If two factor authentication was configured and is causing problems due to a lost device or technical issue, it can be disabled here.</p>
|
|
<p>The user will need to reconfigure two factor authentication, to re-enable it.</p>
|
|
<p><strong>Beware: This could compromise security!</strong></p>
|
|
</div>
|
|
<div class="box-footer">
|
|
<button type="button" class="btn btn-flat btn-warning button_otp_disable" id="{{ user.username }}" {% if user.otp_secret == "" %}disabled{% endif %}>Disable Two Factor Authentication</button>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
<div class="col-md-8">
|
|
<div class="box box-primary">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title">Help with {% if create %}creating a new{% else%}updating a{% endif %} user</h3>
|
|
</div>
|
|
<div class="box-body">
|
|
<p>Fill in all the fields to the in the form to the left.</p>
|
|
{% if create %}
|
|
<p><strong>Newly created users do not have access to any domains.</strong> You will need to grant access to the user once it is created via the domain management buttons on the dashboard.</p>
|
|
{% else %}
|
|
<p><strong>Password</strong> can be left empty to keep the current password.</p>
|
|
<p><strong>Username</strong> cannot be changed.</p>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
{% endblock %}
|
|
{% block extrascripts %}
|
|
<script>
|
|
// handle disabling two factor authentication
|
|
$(document.body).on('click', '.button_otp_disable', function() {
|
|
var modal = $("#modal_otp_disable");
|
|
var username = $(this).prop('id');
|
|
var info = "Are you sure you want to disable two factor authentication for user " + username + "?";
|
|
modal.find('.modal-body p').text(info);
|
|
modal.find('#button_otp_disable_confirm').click(function() {
|
|
var postdata = {'action': 'user_otp_disable', 'data': username}
|
|
applyChanges(postdata, $SCRIPT_ROOT + '/admin/manageuser', false, true);
|
|
})
|
|
modal.modal('show');
|
|
});
|
|
</script>
|
|
{% endblock %}
|
|
{% block modals %}
|
|
<div class="modal fade modal-warning" id="modal_otp_disable">
|
|
<div class="modal-dialog">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<button type="button" class="close" data-dismiss="modal"
|
|
aria-label="Close">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
<h4 class="modal-title">Confirmation</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<p></p>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-flat btn-default pull-left"
|
|
data-dismiss="modal">Close</button>
|
|
<button type="button" class="btn btn-flat btn-danger" id="button_otp_disable_confirm">Disable Two Factor Authentication</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|