Merge pull request #13 from DDynamic/development
Account Creation in AdminCP
This commit is contained in:
commit
9c9d33c127
5 changed files with 136 additions and 3 deletions
|
@ -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]);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -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.
|
||||
*
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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' ]);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue