diff --git a/app/Http/Controllers/Admin/AccountsController.php b/app/Http/Controllers/Admin/AccountsController.php index 9f7b29465..55af688aa 100644 --- a/app/Http/Controllers/Admin/AccountsController.php +++ b/app/Http/Controllers/Admin/AccountsController.php @@ -2,9 +2,12 @@ namespace Pterodactyl\Http\Controllers\Admin; +use Alert; use Debugbar; -use Pterodactyl\Models\User; +use Hash; +use Uuid; +use Pterodactyl\Models\User; use Pterodactyl\Http\Controllers\Controller; use Illuminate\Http\Request; @@ -32,7 +35,7 @@ class AccountsController extends Controller public function getNew(Request $request) { - // + return view('admin.accounts.new'); } public function getView(Request $request, $id) @@ -40,4 +43,27 @@ class AccountsController extends Controller // } + public function postNew(Request $request) + { + $this->validate($request, [ + 'username' => 'required|min:4|unique:users,username', + 'email' => 'required|email|unique:users,email', + 'password' => 'required|confirmed|regex:((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})', + 'password_confirmation' => 'required' + ]); + + //@TODO: re-generate UUID if conflict + $user = new User; + $user->uuid = Uuid::generate(4); + + $user->username = $request->input('username'); + $user->email = $request->input('email'); + $user->password = Hash::make($request->input('password')); + + $user->save(); + + Alert::success('Account has been successfully created.')->flash(); + return redirect()->route('admin.accounts.view', ['id' => $user->id]); + } + } diff --git a/app/Http/Controllers/Base/IndexController.php b/app/Http/Controllers/Base/IndexController.php index d9ff07fd0..b8599c517 100644 --- a/app/Http/Controllers/Base/IndexController.php +++ b/app/Http/Controllers/Base/IndexController.php @@ -41,6 +41,18 @@ class IndexController extends Controller ]); } + /** + * Generate a random string. + * + * @param \Illuminate\Http\Request $request + * @return string + */ + public function getPassword(Request $request, $length = 16) + { + $length = ($length < 8) ? 8 : $length; + return str_random($length); + } + /** * Returns TOTP Management Page. * diff --git a/app/Http/Routes/AdminRoutes.php b/app/Http/Routes/AdminRoutes.php index 058d3c786..1f5e48e29 100644 --- a/app/Http/Routes/AdminRoutes.php +++ b/app/Http/Routes/AdminRoutes.php @@ -13,8 +13,10 @@ class AdminRoutes { // Account Routes $router->group(['prefix' => 'accounts'], function ($server) use ($router) { $router->get('/', [ 'as' => 'admin.accounts', 'uses' => 'Admin\AccountsController@getIndex' ]); - $router->get('/new', [ 'as' => 'admin.accounts.new', 'uses' => 'Admin\AccountsController@getNew' ]); $router->get('/view/{id}', [ 'as' => 'admin.accounts.view', 'uses' => 'Admin\AccountsController@getView' ]); + + $router->get('/new', [ 'as' => 'admin.accounts.new', 'uses' => 'Admin\AccountsController@getNew' ]); + $router->post('/new', [ 'as' => 'admin.accounts.new', 'uses' => 'Admin\AccountsController@postNew' ]); }); // Server Routes diff --git a/app/Http/Routes/BaseRoutes.php b/app/Http/Routes/BaseRoutes.php index bd12219d4..34638dda0 100644 --- a/app/Http/Routes/BaseRoutes.php +++ b/app/Http/Routes/BaseRoutes.php @@ -14,6 +14,9 @@ class BaseRoutes { return redirect()->route('index'); }); + // Password Generation + $router->get('/password-gen/{length}', [ 'as' => 'password-gen', 'uses' => 'Base\IndexController@getPassword' ]); + // Account Routes $router->get('/account', [ 'as' => 'account', 'uses' => 'Base\IndexController@getAccount' ]); $router->post('/account/password', [ 'uses' => 'Base\IndexController@postAccountPassword' ]); diff --git a/resources/views/admin/accounts/new.blade.php b/resources/views/admin/accounts/new.blade.php new file mode 100644 index 000000000..9bff528b1 --- /dev/null +++ b/resources/views/admin/accounts/new.blade.php @@ -0,0 +1,90 @@ +@extends('layouts.admin') + +@section('title') + New Account +@endsection + +@section('content') +