user(); $tshirt_sizes = config('tshirt_sizes'); $request = request(); $html = ''; if (!$request->has('id')) { throw_redirect(users_link()); } $user_id = $request->input('id'); if (!$request->has('action')) { $user_source = User::find($user_id); if (!$user_source) { error(__('This user does not exist.')); throw_redirect(users_link()); } $html .= 'Hallo,
' . 'hier kannst du den Eintrag ändern. Unter dem Punkt \'Gekommen\' ' . 'wird der Engel als anwesend markiert, ein Ja bei Aktiv bedeutet, ' . 'dass der Engel aktiv war und damit ein Anspruch auf ein T-Shirt hat. ' . 'Wenn T-Shirt ein \'Ja\' enthält, bedeutet dies, dass der Engel ' . 'bereits sein T-Shirt erhalten hat.

' . "\n"; $html .= '
' . "\n"; $html .= form_csrf(); $html .= '' . "\n"; $html .= '' . "\n"; $html .= ''; $html .= '' . "\n"; $html .= '
' . "\n"; $html .= '' . "\n"; $html .= ' ' . "\n"; $html .= ' ' . "\n"; if (config('enable_user_name')) { $html .= ' ' . "\n"; $html .= ' ' . "\n"; } $html .= ' ' . "\n"; if (config('enable_dect')) { $html .= ' ' . "\n"; } if ($user_source->settings->email_human) { $html .= " ' . "\n"; } $html .= ' ' . "\n"; $options = [ '1' => __('Yes'), '0' => __('No') ]; // Gekommen? $html .= ' ' . "\n"; // Aktiv? $html .= ' ' . "\n"; // Aktiv erzwingen if (auth()->can('admin_active')) { $html .= ' ' . "\n"; } // T-Shirt bekommen? $html .= ' ' . "\n"; $html .= '
Nick' . '
Last login

' . ($user_source->last_login_at ? $user_source->last_login_at->format('Y-m-d H:i') : '-') . '

Name' . '
Vorname' . '
Handy' . '
DECT' . '
email" . '
Size' . html_select_key( 'size', 'eSize', $tshirt_sizes, $user_source->personalData->shirt_size, __('Please select...') ) . '
Gekommen' . "\n"; if ($user_source->state->arrived) { $html .= __('Yes'); } else { $html .= __('No'); } $html .= '
Aktiv' . "\n"; $html .= html_options('eAktiv', $options, $user_source->state->active) . '
' . __('Force active') . '' . "\n"; $html .= html_options('force_active', $options, $user_source->state->force_active) . '
T-Shirt' . "\n"; $html .= html_options('eTshirt', $options, $user_source->state->got_shirt) . '
' . "\n" . '
' . "\n" . '
' . "\n"; $html .= ''; $html .= '
'; $html .= '
'; $html .= form_info('', __('Please visit the angeltypes page or the users profile to manage users angeltypes.')); $html .= 'Hier kannst Du das Passwort dieses Engels neu setzen:
' . "\n"; $html .= form_csrf(); $html .= '' . "\n"; $html .= ' ' . "\n"; $html .= ' ' . "\n"; $html .= '
Passwort' . '
Wiederholung' . '
' . "\n" . '
' . "\n"; $html .= '' . "\n"; $html .= '
'; $html .= '
'; $my_highest_group = DB::selectOne( 'SELECT group_id FROM `UserGroups` WHERE `uid`=? ORDER BY `group_id` LIMIT 1', [$user->id] ); if (!empty($my_highest_group)) { $my_highest_group = $my_highest_group['group_id']; } $his_highest_group = DB::selectOne( 'SELECT `group_id` FROM `UserGroups` WHERE `uid`=? ORDER BY `group_id` LIMIT 1', [$user_id] ); if (!empty($his_highest_group)) { $his_highest_group = $his_highest_group['group_id']; } if ( ($user_id != $user->id || auth()->can('admin_groups')) && ($my_highest_group <= $his_highest_group || is_null($his_highest_group)) ) { $html .= 'Hier kannst Du die Benutzergruppen des Engels festlegen:
' . "\n"; $html .= form_csrf(); $html .= ''; $groups = DB::select(' SELECT * FROM `Groups` LEFT OUTER JOIN `UserGroups` ON ( `UserGroups`.`group_id` = `Groups`.`UID` AND `UserGroups`.`uid` = ? ) WHERE `Groups`.`UID` >= ? ORDER BY `Groups`.`Name` ', [ $user_id, $my_highest_group, ] ); foreach ($groups as $group) { $html .= ''; } $html .= '
' . $group['Name'] . '

'; $html .= '' . "\n"; $html .= '
'; $html .= '
'; } $html .= buttons([ button(user_delete_link($user_source->id), glyph('lock') . __('delete'), 'btn-danger') ]); $html .= "
"; } else { switch ($request->input('action')) { case 'save_groups': if ($user_id != $user->id || auth()->can('admin_groups')) { $my_highest_group = DB::selectOne( 'SELECT * FROM `UserGroups` WHERE `uid`=? ORDER BY `group_id`', [$user->id] ); $his_highest_group = DB::selectOne( 'SELECT * FROM `UserGroups` WHERE `uid`=? ORDER BY `group_id`', [$user_id] ); if ( count($my_highest_group) > 0 && ( empty($his_highest_group) || ($my_highest_group['group_id'] <= $his_highest_group['group_id']) ) ) { $groups_source = DB::select(' SELECT * FROM `Groups` LEFT OUTER JOIN `UserGroups` ON ( `UserGroups`.`group_id` = `Groups`.`UID` AND `UserGroups`.`uid` = ? ) WHERE `Groups`.`UID` >= ? ORDER BY `Groups`.`Name` ', [ $user_id, $my_highest_group['group_id'], ] ); $groups = []; $grouplist = []; foreach ($groups_source as $group) { $groups[$group['UID']] = $group; $grouplist[] = $group['UID']; } $groupsRequest = $request->input('groups'); if (!is_array($groupsRequest)) { $groupsRequest = []; } DB::delete('DELETE FROM `UserGroups` WHERE `uid`=?', [$user_id]); $user_groups_info = []; foreach ($groupsRequest as $group) { if (in_array($group, $grouplist)) { DB::insert( 'INSERT INTO `UserGroups` (`uid`, `group_id`) VALUES (?, ?)', [$user_id, $group] ); $user_groups_info[] = $groups[$group]['Name']; } } $user_source = User::find($user_id); engelsystem_log( 'Set groups of ' . User_Nick_render($user_source, true) . ' to: ' . join(', ', $user_groups_info) ); $html .= success('Benutzergruppen gespeichert.', true); } else { $html .= error('Du kannst keine Engel mit mehr Rechten bearbeiten.', true); } } else { $html .= error('Du kannst Deine eigenen Rechte nicht bearbeiten.', true); } break; case 'save': $force_active = $user->state->force_active; $user_source = User::find($user_id); if (auth()->can('admin_active')) { $force_active = $request->input('force_active'); } if ($user_source->settings->email_human) { $user_source->email = $request->postData('eemail'); } $nickValidation = User_validate_Nick($request->postData('eNick')); if ($nickValidation->isValid()) { $user_source->name = $nickValidation->getValue(); } $user_source->save(); if (config('enable_user_name')) { $user_source->personalData->first_name = $request->postData('eVorname'); $user_source->personalData->last_name = $request->postData('eName'); } $user_source->personalData->shirt_size = $request->postData('eSize'); $user_source->personalData->save(); $user_source->contact->mobile = $request->postData('eHandy'); $user_source->contact->dect = $request->postData('eDECT'); $user_source->contact->save(); $user_source->state->active = $request->postData('eAktiv'); $user_source->state->force_active = $force_active; $user_source->state->got_shirt = $request->postData('eTshirt'); $user_source->state->save(); engelsystem_log( 'Updated user: ' . $user_source->name . ' (' . $user_source->id . ')' . ', t-shirt: ' . $user_source->personalData->shirt_size . ', active: ' . $user_source->state->active . ', force-active: ' . $user_source->state->force_active . ', tshirt: ' . $user_source->state->got_shirt ); $html .= success('Änderung wurde gespeichert...' . "\n", true); break; case 'change_pw': if ( $request->postData('new_pw') != '' && $request->postData('new_pw') == $request->postData('new_pw2') ) { $user_source = User::find($user_id); auth()->setPassword($user_source, $request->postData('new_pw')); engelsystem_log('Set new password for ' . User_Nick_render($user_source, true)); $html .= success('Passwort neu gesetzt.', true); } else { $html .= error( 'Die Eingaben müssen übereinstimmen und dürfen nicht leer sein!', true ); } break; } } return page_with_title(__('Edit user'), [ $html ]); }