clrghouz/app/Http/Controllers/UserController.php

71 lines
1.4 KiB
PHP
Raw Normal View History

<?php
namespace App\Http\Controllers;
use Illuminate\Auth\Events\Registered;
use Illuminate\Http\Request;
2021-11-26 17:19:55 +11:00
use Illuminate\Support\Facades\Auth;
use App\Models\User;
class UserController extends Controller
{
/**
* Add or edit a node
*/
public function add_edit(Request $request,User $o)
{
if ($request->post()) {
$this->authorize('admin',$o);
$request->validate([
'email' => 'required|email|unique:users,email,'.($o->exists ? $o->id : 0),
'name' => 'required|min:3',
'pgp_pubkey' => [
'nullable',
'min:64',
//function ($attribute,$value,$fail) { return $fail('Not this time'); }
],
2021-10-19 22:21:32 +11:00
'alias' => 'nullable|min:1',
'active' => 'required|boolean',
'admin' => 'required|boolean',
]);
2021-10-19 22:21:32 +11:00
foreach (['name','email','pgp_pubkey','active','admin','alias'] as $key)
$o->{$key} = $request->post($key);
if (! $o->exists)
$o->password = base64_encode(random_bytes(20));
$o->save();
if ($o->wasRecentlyCreated)
event(new Registered($o));
return redirect()->action([self::class,'home']);
}
return view('user.addedit')
->with('o',$o);
}
2021-10-26 23:19:55 +11:00
public function dashboard()
{
2021-11-26 17:19:55 +11:00
$user = Auth::user();
$user->load('systems.addresses.zone.domain');
return view('dashboard')
->with('user',$user);
2021-10-26 23:19:55 +11:00
}
public function home()
{
return view('user.home');
}
public function register()
{
return view('user/system/register');
}
}