fossasia/engelsystem

View on GitHub
includes/controller/users_controller.php

Summary

Maintainability
D
2 days
Test Coverage
<?php
 
/**
* Route user actions.
*/
function users_controller() {
global $privileges, $user;
 
if (! isset($user))
redirect(page_link_to(''));
 
if (! isset($_REQUEST['action']))
$_REQUEST['action'] = 'list';
 
switch ($_REQUEST['action']) {
default:
case 'list':
return users_list_controller();
case 'view':
return user_controller();
case 'edit':
return user_edit_controller();
case 'delete':
return user_delete_controller();
case 'edit_vouchers':
Avoid too many `return` statements within this method.
return user_edit_vouchers_controller();
}
}
 
/**
* Delete a user, requires to enter own password for reasons.
*/
Function `user_delete_controller` has a Cognitive Complexity of 13 (exceeds 5 allowed). Consider refactoring.
Method `user_delete_controller` has 31 lines of code (exceeds 25 allowed). Consider refactoring.
function user_delete_controller() {
global $privileges, $user;
 
if (isset($_REQUEST['user_id'])) {
$user_source = User($_REQUEST['user_id']);
} else
$user_source = $user;
 
if (! in_array('admin_user', $privileges))
redirect(page_link_to(''));
 
// You cannot delete yourself
if ($user['UID'] == $user_source['UID']) {
error(_("You cannot delete yourself."));
redirect(user_link($user));
}
 
if (isset($_REQUEST['submit'])) {
$ok = true;
 
if (! (isset($_REQUEST['password']) && verify_password($_REQUEST['password'], $user['Passwort'], $user['UID']))) {
$ok = false;
error(_("Your password is incorrect. Please try it again."));
}
 
if ($ok) {
$result = User_delete($user_source['UID']);
if ($result === false)
engelsystem_error('Unable to delete user.');
 
mail_user_delete($user_source);
success(_("User deleted."));
engelsystem_log(sprintf("Deleted %s", User_Nick_render($user_source)));
 
redirect(users_link());
}
}
 
return array(
sprintf(_("Delete %s"), $user_source['Nick']),
User_delete_view($user_source)
);
}
 
function users_link() {
return page_link_to('users');
}
 
function user_edit_link($user) {
return page_link_to('admin_user') . '&user_id=' . $user['UID'];
}
 
function user_delete_link($user) {
return page_link_to('users') . '&action=delete&user_id=' . $user['UID'];
}
 
function user_link($user) {
return page_link_to('users') . '&action=view&user_id=' . $user['UID'];
}
 
Function `user_edit_vouchers_controller` has a Cognitive Complexity of 13 (exceeds 5 allowed). Consider refactoring.
Method `user_edit_vouchers_controller` has 29 lines of code (exceeds 25 allowed). Consider refactoring.
function user_edit_vouchers_controller() {
global $privileges, $user;
 
if (isset($_REQUEST['user_id'])) {
$user_source = User($_REQUEST['user_id']);
} else
$user_source = $user;
 
if (! in_array('admin_user', $privileges))
redirect(page_link_to(''));
 
if (isset($_REQUEST['submit'])) {
$ok = true;
 
if (isset($_REQUEST['vouchers']) && test_request_int('vouchers') && trim($_REQUEST['vouchers']) >= 0)
$vouchers = trim($_REQUEST['vouchers']);
else {
$ok = false;
error(_("Please enter a valid number of vouchers."));
}
 
if ($ok) {
$user_source['got_voucher'] = $vouchers;
 
$result = User_update($user_source);
if ($result === false)
engelsystem_error('Unable to update user.');
 
success(_("Saved the number of vouchers."));
engelsystem_log(User_Nick_render($user_source) . ': ' . sprintf("Got %s vouchers", $user_source['got_voucher']));
 
redirect(user_link($user_source));
}
}
 
return array(
sprintf(_("%s's vouchers"), $user_source['Nick']),
User_edit_vouchers_view($user_source)
);
}
 
Function `user_controller` has a Cognitive Complexity of 10 (exceeds 5 allowed). Consider refactoring.
function user_controller() {
global $privileges, $user;
 
if (isset($_REQUEST['user_id'])) {
$user_source = User($_REQUEST['user_id']);
if ($user_source === false)
engelsystem_error("Unable to load user.");
if ($user_source == null) {
error(_("User not found."));
redirect('?');
}
} else
$user_source = $user;
 
$shifts = Shifts_by_user($user_source);
foreach ($shifts as &$shift) {
// TODO: Move queries to model
$shift['needed_angeltypes'] = shift_needed_angeltypes($shift['SID']);
foreach ($shift['needed_angeltypes'] as &$needed_angeltype) {
$needed_angeltype['users'] = needed_angeltype_by_shift($shift['SID'], $needed_angeltype['id']);
}
}
 
if ($user_source['api_key'] == "")
User_reset_api_key($user_source, false);
 
return array(
$user_source['Nick'],
User_view($user_source, in_array('admin_user', $privileges), User_is_freeloader($user_source), User_angeltypes($user_source), User_groups($user_source), $shifts, $user['UID'] == $user_source['UID'])
);
}
 
/**
* List all users.
*/
function users_list_controller() {
global $privileges;
 
if (! in_array('admin_user', $privileges))
redirect(page_link_to(''));
 
$order_by = 'Nick';
if (isset($_REQUEST['OrderBy']) && in_array($_REQUEST['OrderBy'], User_sortable_columns()))
$order_by = $_REQUEST['OrderBy'];
 
$users = Users($order_by);
if ($users === false)
engelsystem_error('Unable to load users.');
 
foreach ($users as &$user)
$user['freeloads'] = count(ShiftEntries_freeloaded_by_user($user));
 
return array(
_('All users'),
Users_view($users, $order_by, User_arrived_count(), User_active_count(), User_force_active_count(), ShiftEntries_freeleaded_count(), User_tshirts_count(), User_got_voucher_count())
);
}
 
/**
* User password recovery.
* (By email)
*/
Function `user_password_recovery_controller` has a Cognitive Complexity of 56 (exceeds 5 allowed). Consider refactoring.
Method `user_password_recovery_controller` has 62 lines of code (exceeds 25 allowed). Consider refactoring.
function user_password_recovery_controller() {
if (isset($_REQUEST['token'])) {
$user_source = User_by_password_recovery_token($_REQUEST['token']);
if ($user_source === false)
engelsystem_error("Unable to load user.");
if ($user_source == null) {
error(_("Token is not correct."));
redirect(page_link_to('login'));
}
 
if (isset($_REQUEST['submit'])) {
$ok = true;
 
if (isset($_REQUEST['password']) && strlen($_REQUEST['password']) >= MIN_PASSWORD_LENGTH) {
if ($_REQUEST['password'] != $_REQUEST['password2']) {
$ok = false;
error(_("Your passwords don't match."));
}
} else {
$ok = false;
error(_("Your password is to short (please use at least 6 characters)."));
}
 
if ($ok) {
$result = set_password($user_source['UID'], $_REQUEST['password']);
if ($result === false)
engelsystem_error(_("Password could not be updated."));
 
success(_("Password saved."));
redirect(page_link_to('login'));
}
}
 
return User_password_set_view();
} else {
if (isset($_REQUEST['submit'])) {
$ok = true;
 
if (isset($_REQUEST['email']) && strlen(strip_request_item('email')) > 0) {
$email = strip_request_item('email');
if (check_email($email)) {
$user_source = User_by_email($email);
if ($user_source === false)
engelsystem_error("Unable to load user.");
if ($user_source == null) {
$ok = false;
error(_("E-mail address is not correct."));
}
} else {
$ok = false;
error(_("E-mail address is not correct."));
}
} else {
$ok = false;
error(_("Please enter your e-mail."));
}
 
if ($ok) {
$token = User_generate_password_recovery_token($user_source);
if ($token === false)
engelsystem_error("Unable to generate password recovery token.");
$result = engelsystem_email_to_user($user_source, _("Password recovery"), sprintf(_("Please visit %s to recover your password."), page_link_to_absolute('user_password_recovery') . '&token=' . $token));
if ($result === false)
engelsystem_error("Unable to send password recovery email.");
 
success(_("We sent an email containing your password recovery link."));
redirect(page_link_to('login'));
}
}
 
return User_password_recovery_view();
}
}
 
/**
* Menu title for password recovery.
*/
function user_password_recovery_title() {
return _("Password recovery");
}
 
?>