diff options
author | Philip Häusler <msquare@notrademark.de> | 2014-12-26 01:50:08 +0100 |
---|---|---|
committer | Philip Häusler <msquare@notrademark.de> | 2014-12-26 01:50:08 +0100 |
commit | 4ce9c7da87dda149447086796f16f545431f5f2f (patch) | |
tree | ba3c7ce9cf21dfcb2927f4a3b59086979dd41fae /includes/controller/users_controller.php | |
parent | e89acc0c1d1188662da7490e3a75a4a5c3950a75 (diff) | |
parent | 8ed077bcece00bd056a878c86a9cf2c672d4306e (diff) |
Merge branch 'feature-voucher'
Diffstat (limited to 'includes/controller/users_controller.php')
-rw-r--r-- | includes/controller/users_controller.php | 38 |
1 files changed, 35 insertions, 3 deletions
diff --git a/includes/controller/users_controller.php b/includes/controller/users_controller.php index 3a23835c..a282c1c7 100644 --- a/includes/controller/users_controller.php +++ b/includes/controller/users_controller.php @@ -22,10 +22,16 @@ function users_controller() { return user_edit_controller(); case 'delete': return user_delete_controller(); + case 'got_voucher': + return user_got_voucher_controller(); } } -function user_controller() { +function user_link($user) { + return page_link_to('users') . '&action=view&user_id=' . $user['UID']; +} + +function user_got_voucher_controller() { global $privileges, $user; if (isset($_REQUEST['user_id'])) { @@ -35,6 +41,32 @@ function user_controller() { $admin_user_privilege = in_array('admin_user', $privileges); + if (! in_array('admin_user', $privileges)) + redirect(page_link_to('')); + + if (! isset($_REQUEST['got_voucher'])) + redirect(page_link_to('')); + + $user_source['got_voucher'] = $_REQUEST['got_voucher'] == 'true'; + + $result = User_update($user_source); + if ($result === false) + engelsystem_error('Unable to update user.'); + + success($user_source['got_voucher'] ? _('User got vouchers.') : _('User didnt got vouchers.')); + engelsystem_log(User_Nick_render($user_source) . ($user_source['got_voucher'] ? ' got vouchers' : ' didnt got vouchers')); + + redirect(user_link($user_source)); +} + +function user_controller() { + global $privileges, $user; + + if (isset($_REQUEST['user_id'])) { + $user_source = User($_REQUEST['user_id']); + } else + $user_source = $user; + $shifts = Shifts_by_user($user_source); foreach ($shifts as &$shift) { // TODO: Move queries to model @@ -54,7 +86,7 @@ function user_controller() { return array( $user_source['Nick'], - User_view($user_source, $admin_user_privilege, User_is_freeloader($user_source), User_angeltypes($user_source), User_groups($user_source), $shifts, $user['UID'] == $user_source['UID']) + 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']) ); } @@ -80,7 +112,7 @@ function users_list_controller() { 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()) + 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()) ); } |