Allows the admin to modify password related stuff.
This commit is contained in:
parent
3192098ff5
commit
15c57eeb37
@ -24,7 +24,7 @@ use Framadate\Services\LogService;
|
|||||||
use Framadate\Services\MailService;
|
use Framadate\Services\MailService;
|
||||||
use Framadate\Services\PollService;
|
use Framadate\Services\PollService;
|
||||||
use Framadate\Services\NotificationService;
|
use Framadate\Services\NotificationService;
|
||||||
use Framadate\Utils;
|
use Framadate\Security\PasswordHasher;
|
||||||
|
|
||||||
include_once __DIR__ . '/app/inc/init.php';
|
include_once __DIR__ . '/app/inc/init.php';
|
||||||
|
|
||||||
@ -71,7 +71,8 @@ if ($poll) {
|
|||||||
|
|
||||||
if (isset($_POST['update_poll_info'])) {
|
if (isset($_POST['update_poll_info'])) {
|
||||||
$updated = false;
|
$updated = false;
|
||||||
$field = $inputService->filterAllowedValues($_POST['update_poll_info'], ['title', 'admin_mail', 'description', 'rules', 'expiration_date', 'name', 'hidden']);
|
$field = $inputService->filterAllowedValues($_POST['update_poll_info'], ['title', 'admin_mail', 'description',
|
||||||
|
'rules', 'expiration_date', 'name', 'hidden', 'removePassword', 'password']);
|
||||||
|
|
||||||
// Update the right poll field
|
// Update the right poll field
|
||||||
if ($field == 'title') {
|
if ($field == 'title') {
|
||||||
@ -135,6 +136,24 @@ if (isset($_POST['update_poll_info'])) {
|
|||||||
$poll->hidden = $hidden;
|
$poll->hidden = $hidden;
|
||||||
$updated = true;
|
$updated = true;
|
||||||
}
|
}
|
||||||
|
} elseif ($field == 'removePassword') {
|
||||||
|
$removePassword = isset($_POST['removePassword']) ? $inputService->filterBoolean($_POST['removePassword']) : false;
|
||||||
|
if ($removePassword) {
|
||||||
|
$poll->results_publicly_visible = false;
|
||||||
|
$poll->password_hash = null;
|
||||||
|
$updated = true;
|
||||||
|
}
|
||||||
|
} elseif ($field == 'password') {
|
||||||
|
$password = isset($_POST['password']) ? $_POST['password'] : null;
|
||||||
|
$resultsPubliclyVisible = isset($_POST['resultsPubliclyVisible']) ? $inputService->filterBoolean($_POST['resultsPubliclyVisible']) : false;
|
||||||
|
if (!empty($password)) {
|
||||||
|
$poll->password_hash = PasswordHasher::hash($password);
|
||||||
|
$updated = true;
|
||||||
|
}
|
||||||
|
if ($resultsPubliclyVisible != $poll->results_publicly_visible) {
|
||||||
|
$poll->results_publicly_visible = $resultsPubliclyVisible;
|
||||||
|
$updated = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update poll in database
|
// Update poll in database
|
||||||
|
@ -48,9 +48,9 @@ class PollRepository extends AbstractRepository {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function update($poll) {
|
function update($poll) {
|
||||||
$prepared = $this->prepare('UPDATE `' . Utils::table('poll') . '` SET title=?, admin_name=?, admin_mail=?, description=?, end_date=?, active=?, editable=?, hidden=? WHERE id = ?');
|
$prepared = $this->prepare('UPDATE `' . Utils::table('poll') . '` SET title=?, admin_name=?, admin_mail=?, description=?, end_date=?, active=?, editable=?, hidden=?, password_hash=?, results_publicly_visible=? WHERE id = ?');
|
||||||
|
|
||||||
return $prepared->execute([$poll->title, $poll->admin_name, $poll->admin_mail, $poll->description, $poll->end_date, $poll->active, $poll->editable, $poll->hidden, $poll->id]);
|
return $prepared->execute([$poll->title, $poll->admin_name, $poll->admin_mail, $poll->description, $poll->end_date, $poll->active, $poll->editable, $poll->hidden, $poll->password_hash, $poll->results_publicly_visible, $poll->id]);
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteById($poll_id) {
|
function deleteById($poll_id) {
|
||||||
|
@ -167,6 +167,7 @@ caption {
|
|||||||
#poll-rules-form .btn-edit,
|
#poll-rules-form .btn-edit,
|
||||||
#poll-hidden-form .btn-edit,
|
#poll-hidden-form .btn-edit,
|
||||||
#expiration-form .btn-edit,
|
#expiration-form .btn-edit,
|
||||||
|
#password-form .btn-edit,
|
||||||
#name-form .btn-edit {
|
#name-form .btn-edit {
|
||||||
position:absolute;
|
position:absolute;
|
||||||
left:-2000px;
|
left:-2000px;
|
||||||
@ -184,6 +185,8 @@ caption {
|
|||||||
#poll-hidden-form:hover .btn-edit,
|
#poll-hidden-form:hover .btn-edit,
|
||||||
#expiration-form .btn-edit:focus,
|
#expiration-form .btn-edit:focus,
|
||||||
#expiration-form:hover .btn-edit,
|
#expiration-form:hover .btn-edit,
|
||||||
|
#password-form .btn-edit:focus,
|
||||||
|
#password-form:hover .btn-edit,
|
||||||
#name-form .btn-edit:focus,
|
#name-form .btn-edit:focus,
|
||||||
#name-form:hover .btn-edit {
|
#name-form:hover .btn-edit {
|
||||||
position:relative !important;
|
position:relative !important;
|
||||||
@ -495,3 +498,7 @@ table.results > tbody > tr:hover > td .glyphicon {
|
|||||||
padding-top: 15px;
|
padding-top: 15px;
|
||||||
padding-bottom: 15px;
|
padding-bottom: 15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#password-form .btn-cancel {
|
||||||
|
float: right;
|
||||||
|
}
|
29
js/core.js
29
js/core.js
@ -104,6 +104,35 @@ $(document).ready(function() {
|
|||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
$('#password-form .btn-edit').on('click', function() {
|
||||||
|
$('#password-form p').hide();
|
||||||
|
$('#password-form .js-password').removeClass('hidden');
|
||||||
|
$('#password').focus();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#password-form .btn-cancel').on('click', function() {
|
||||||
|
$('#password-form p').show();
|
||||||
|
$('#password-form .js-password').addClass('hidden');
|
||||||
|
$('.js-password .btn-edit').focus();
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Hiding other field when the admin wants to remove the password protection
|
||||||
|
var removePassword = $('#removePassword');
|
||||||
|
removePassword.on('click', function() {
|
||||||
|
var removeButton = removePassword.siblings('button');
|
||||||
|
if (removePassword.is(":checked")) {
|
||||||
|
$('#password_information').addClass('hidden');
|
||||||
|
removeButton.removeClass('hidden');
|
||||||
|
} else {
|
||||||
|
$('#password_information').removeClass('hidden');
|
||||||
|
removeButton.addClass('hidden');
|
||||||
|
}
|
||||||
|
removeButton.focus();
|
||||||
|
});
|
||||||
|
|
||||||
// Horizontal scroll buttons
|
// Horizontal scroll buttons
|
||||||
if($('.results').width() > $('.container').width()) {
|
if($('.results').width() > $('.container').width()) {
|
||||||
$('.scroll-buttons').removeClass('hidden');
|
$('.scroll-buttons').removeClass('hidden');
|
||||||
|
@ -125,7 +125,11 @@
|
|||||||
"Save the new rules": "Neue Regeln speichern",
|
"Save the new rules": "Neue Regeln speichern",
|
||||||
"Cancel the rules edit": "Abbruch, Regeln nicht ändern",
|
"Cancel the rules edit": "Abbruch, Regeln nicht ändern",
|
||||||
"Results are hidden.": "Ergebnisse werden ausgeblendet.",
|
"Results are hidden.": "Ergebnisse werden ausgeblendet.",
|
||||||
"Results are visible.": "Ergebnisse sind sichtbar."
|
"Results are visible.": "Ergebnisse sind sichtbar.",
|
||||||
|
"Password protected.": "DE_Protégé par mot de passe.",
|
||||||
|
"Votes protected by password.": "DE_Votes protégés par mot de passe.",
|
||||||
|
"No password.": "DE_Pas de mot de passe",
|
||||||
|
"Remove password.": "DE_Supprimer le mot de passe."
|
||||||
},
|
},
|
||||||
"Poll results": {
|
"Poll results": {
|
||||||
"Votes of the poll": "Stimmabgaben zur Umfrage",
|
"Votes of the poll": "Stimmabgaben zur Umfrage",
|
||||||
|
@ -125,7 +125,11 @@
|
|||||||
"Save the new rules": "Save the new rules",
|
"Save the new rules": "Save the new rules",
|
||||||
"Cancel the rules edit": "Cancel the rules edit",
|
"Cancel the rules edit": "Cancel the rules edit",
|
||||||
"Results are hidden.": "Results are hidden.",
|
"Results are hidden.": "Results are hidden.",
|
||||||
"Results are visible.": "Results are visible."
|
"Results are visible.": "Results are visible.",
|
||||||
|
"Password protected.": "Password protected.",
|
||||||
|
"Votes protected by password.": "Votes protected by password.",
|
||||||
|
"No password.": "No password.",
|
||||||
|
"Remove password.": "Remove password."
|
||||||
},
|
},
|
||||||
"Poll results": {
|
"Poll results": {
|
||||||
"Votes of the poll": "Votes",
|
"Votes of the poll": "Votes",
|
||||||
|
@ -125,7 +125,11 @@
|
|||||||
"Save the new rules": "ES_Enregistrer les nouvelles permissions",
|
"Save the new rules": "ES_Enregistrer les nouvelles permissions",
|
||||||
"Cancel the rules edit": "ES_Annuler le changement de permissions",
|
"Cancel the rules edit": "ES_Annuler le changement de permissions",
|
||||||
"Results are hidden.": "ES_Les résultats sont cachés.",
|
"Results are hidden.": "ES_Les résultats sont cachés.",
|
||||||
"Results are visible.": "ES_Les résultats sont visibles."
|
"Results are visible.": "ES_Les résultats sont visibles.",
|
||||||
|
"Password protected.": "ES_Protégé par mot de passe.",
|
||||||
|
"Votes protected by password.": "ES_Votes protégés par mot de passe.",
|
||||||
|
"No password.": "ES_Pas de mot de passe",
|
||||||
|
"Remove password.": "ES_Supprimer le mot de passe."
|
||||||
},
|
},
|
||||||
"Poll results": {
|
"Poll results": {
|
||||||
"Votes of the poll": "ES_Votes du sondage",
|
"Votes of the poll": "ES_Votes du sondage",
|
||||||
|
@ -125,7 +125,11 @@
|
|||||||
"Save the new rules": "Enregistrer les nouvelles permissions",
|
"Save the new rules": "Enregistrer les nouvelles permissions",
|
||||||
"Cancel the rules edit": "Annuler le changement de permissions",
|
"Cancel the rules edit": "Annuler le changement de permissions",
|
||||||
"Results are hidden.": "Les résultats sont cachés.",
|
"Results are hidden.": "Les résultats sont cachés.",
|
||||||
"Results are visible.": "Les résultats sont visibles."
|
"Results are visible.": "Les résultats sont visibles.",
|
||||||
|
"Password protected.": "Protégé par mot de passe.",
|
||||||
|
"Votes protected by password.": "Votes protégés par mot de passe.",
|
||||||
|
"No password.": "Pas de mot de passe",
|
||||||
|
"Remove password.": "Supprimer le mot de passe."
|
||||||
},
|
},
|
||||||
"Poll results": {
|
"Poll results": {
|
||||||
"Votes of the poll": "Votes du sondage",
|
"Votes of the poll": "Votes du sondage",
|
||||||
|
@ -125,7 +125,11 @@
|
|||||||
"Save the new rules": "Salvare i nuovi permessi",
|
"Save the new rules": "Salvare i nuovi permessi",
|
||||||
"Cancel the rules edit": "Annullare le modifica dei permessi",
|
"Cancel the rules edit": "Annullare le modifica dei permessi",
|
||||||
"Results are hidden.": "I risultati sono nascosti.",
|
"Results are hidden.": "I risultati sono nascosti.",
|
||||||
"Results are visible.": "I risultati sono visibili."
|
"Results are visible.": "I risultati sono visibili.",
|
||||||
|
"Password protected.": "IT_Protégé par mot de passe.",
|
||||||
|
"Votes protected by password.": "IT_Votes protégés par mot de passe.",
|
||||||
|
"No password.": "IT_Pas de mot de passe",
|
||||||
|
"Remove password.": "IT_Supprimer le mot de passe."
|
||||||
},
|
},
|
||||||
"Poll results": {
|
"Poll results": {
|
||||||
"Votes of the poll": "Voti del sondaggio ",
|
"Votes of the poll": "Voti del sondaggio ",
|
||||||
|
@ -120,7 +120,42 @@
|
|||||||
</div>
|
</div>
|
||||||
{if $admin}
|
{if $admin}
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4 col-md-offset-4" >
|
<div class="col-md-4">
|
||||||
|
<div id="password-form">
|
||||||
|
{if !empty($poll->password_hash) && !$poll->results_publicly_visible}
|
||||||
|
{$password_text = __('PollInfo', 'Password protected.')}
|
||||||
|
{elseif !empty($poll->password_hash) && $poll->results_publicly_visible}
|
||||||
|
{$password_text = __('PollInfo', 'Votes protected by password.')}
|
||||||
|
{else}
|
||||||
|
{$password_text = __('PollInfo', 'No password.')}
|
||||||
|
{/if}
|
||||||
|
<p class=""><span class="glyphicon glyphicon-lock"> </span> {$password_text}<button class="btn btn-link btn-sm btn-edit" title="{__('PollInfo', 'Edit the poll rules')}"><span class="glyphicon glyphicon-pencil"></span><span class="sr-only">{__('Generic', 'Edit')}</span></button></p>
|
||||||
|
<div class="hidden js-password">
|
||||||
|
<button class="btn btn-link btn-cancel" title="{__('PollInfo', 'Cancel the rules edit')}"><span class="glyphicon glyphicon-remove"></span><span class="sr-only">{__('Generic', 'Cancel')}</span></button>
|
||||||
|
{if !empty($poll->password_hash)}
|
||||||
|
<div class="input-group">
|
||||||
|
<input type="checkbox" id="removePassword" name="removePassword"/>
|
||||||
|
<label for="removePassword">{__('PollInfo', 'Remove password.')}</label>
|
||||||
|
<button type="submit" name="update_poll_info" value="removePassword" class="btn btn-success hidden" title="{__('PollInfo', 'Save the new rules')}"><span class="glyphicon glyphicon-ok"></span><span class="sr-only">{__('Generic', 'Remove password.')}</span></button>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
<div id="password_information">
|
||||||
|
<div class="input-group">
|
||||||
|
<input type="checkbox" id="resultsPubliclyVisible" name="resultsPubliclyVisible" {if $poll->results_publicly_visible}checked="checked"{/if}/>
|
||||||
|
<label for="resultsPubliclyVisible">{__('PollInfo', 'Results are visible.')}</label>
|
||||||
|
</div>
|
||||||
|
<div class="input-group">
|
||||||
|
<input type="text" class="form-control" id="password" name="password"/>
|
||||||
|
<span class="input-group-btn">
|
||||||
|
<button type="submit" name="update_poll_info" value="password" class="btn btn-success" title="{__('PollInfo', 'Save the new rules')}"><span class="glyphicon glyphicon-ok"></span><span class="sr-only">{__('Generic', 'Save')}</span></button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="col-md-4 ">
|
||||||
<div id="poll-hidden-form">
|
<div id="poll-hidden-form">
|
||||||
{if $poll->hidden}
|
{if $poll->hidden}
|
||||||
{$hidden_icon = "glyphicon-eye-close"}
|
{$hidden_icon = "glyphicon-eye-close"}
|
||||||
|
@ -4,7 +4,9 @@
|
|||||||
|
|
||||||
<h3>
|
<h3>
|
||||||
{__('Poll results', 'Votes of the poll')} {if $hidden}<i>({__('PollInfo', 'Results are hidden.')})</i>{/if}
|
{__('Poll results', 'Votes of the poll')} {if $hidden}<i>({__('PollInfo', 'Results are hidden.')})</i>{/if}
|
||||||
<a href="" data-toggle="modal" data-target="#hint_modal"><i class="glyphicon glyphicon-info-sign"></i></a>
|
{if $accessGranted}
|
||||||
|
<a href="" data-toggle="modal" data-target="#hint_modal"><i class="glyphicon glyphicon-info-sign"></i></a>
|
||||||
|
{/if}
|
||||||
</h3>
|
</h3>
|
||||||
|
|
||||||
<div id="tableContainer" class="tableContainer">
|
<div id="tableContainer" class="tableContainer">
|
||||||
|
@ -4,7 +4,9 @@
|
|||||||
|
|
||||||
<h3>
|
<h3>
|
||||||
{__('Poll results', 'Votes of the poll')} {if $hidden}<i>({__('PollInfo', 'Results are hidden.')})</i>{/if}
|
{__('Poll results', 'Votes of the poll')} {if $hidden}<i>({__('PollInfo', 'Results are hidden.')})</i>{/if}
|
||||||
<a href="" data-toggle="modal" data-target="#hint_modal"><i class="glyphicon glyphicon-info-sign"></i></a>
|
{if $accessGranted}
|
||||||
|
<a href="" data-toggle="modal" data-target="#hint_modal"><i class="glyphicon glyphicon-info-sign"></i></a>
|
||||||
|
{/if}
|
||||||
</h3>
|
</h3>
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user