| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace BookStack\Console\Commands; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-25 19:30:50 +08:00
										 |  |  | use BookStack\Auth\UserRepo; | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  | use Illuminate\Console\Command; | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  | use Illuminate\Support\Facades\Validator; | 
					
						
							|  |  |  | use Illuminate\Validation\Rules\Password; | 
					
						
							|  |  |  | use Illuminate\Validation\Rules\Unique; | 
					
						
							| 
									
										
										
										
											2021-11-06 00:18:06 +08:00
										 |  |  | use Symfony\Component\Console\Command\Command as SymfonyCommand; | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | class CreateAdmin extends Command | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The name and signature of the console command. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $signature = 'bookstack:create-admin | 
					
						
							|  |  |  |                             {--email= : The email address for the new admin user} | 
					
						
							|  |  |  |                             {--name= : The name of the new admin user} | 
					
						
							|  |  |  |                             {--password= : The password to assign to the new admin user}'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * The console command description. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $description = 'Add a new admin user to the system'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected $userRepo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Create a new command instance. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct(UserRepo $userRepo) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->userRepo = $userRepo; | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Execute the console command. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @throws \BookStack\Exceptions\NotFoundException | 
					
						
							| 
									
										
										
										
											2021-06-26 23:23:15 +08:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function handle() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         $details = $this->options(); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         if (empty($details['email'])) { | 
					
						
							|  |  |  |             $details['email'] = $this->ask('Please specify an email address for the new admin user'); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         if (empty($details['name'])) { | 
					
						
							|  |  |  |             $details['name'] = $this->ask('Please specify a name for the new admin user'); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         if (empty($details['password'])) { | 
					
						
							|  |  |  |             $details['password'] = $this->ask('Please specify a password for the new admin user (8 characters min)'); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         $validator = Validator::make($details, [ | 
					
						
							| 
									
										
										
										
											2021-12-19 00:41:42 +08:00
										 |  |  |             'email'    => ['required', 'email', 'min:5', new Unique('users', 'email')], | 
					
						
							|  |  |  |             'name'     => ['required', 'min:2'], | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |             'password' => ['required', Password::default()], | 
					
						
							|  |  |  |         ]); | 
					
						
							| 
									
										
										
										
											2021-11-06 00:27:59 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         if ($validator->fails()) { | 
					
						
							|  |  |  |             foreach ($validator->errors()->all() as $error) { | 
					
						
							|  |  |  |                 $this->error($error); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-12-19 00:41:42 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 00:18:06 +08:00
										 |  |  |             return SymfonyCommand::FAILURE; | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-19 00:31:48 +08:00
										 |  |  |         $user = $this->userRepo->create($validator->validated()); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         $this->userRepo->attachSystemRole($user, 'admin'); | 
					
						
							| 
									
										
										
										
											2018-12-23 03:29:19 +08:00
										 |  |  |         $this->userRepo->downloadAndAssignUserAvatar($user); | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |         $user->email_confirmed = true; | 
					
						
							|  |  |  |         $user->save(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->info("Admin account with email \"{$user->email}\" successfully created!"); | 
					
						
							| 
									
										
										
										
											2021-11-06 00:27:59 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-06 00:18:06 +08:00
										 |  |  |         return SymfonyCommand::SUCCESS; | 
					
						
							| 
									
										
										
										
											2018-01-29 02:09:26 +08:00
										 |  |  |     } | 
					
						
							|  |  |  | } |