Allow changing of Backend user passwords through CLI. (#4836)

Adds an Artisan command "october:passwd" to change the password of a Backend User through CLI. This command may only be run through CLI - it will not work if called through a web handler.

Refs: #3521, #4835. Docs: 1f3bfc719e
This commit is contained in:
Ben Thomson 2019-12-23 08:19:15 +08:00 committed by GitHub
parent 0436165a90
commit a66310bd56
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 113 additions and 0 deletions

View File

@ -247,6 +247,7 @@ class ServiceProvider extends ModuleServiceProvider
$this->registerConsoleCommand('october.fresh', 'System\Console\OctoberFresh');
$this->registerConsoleCommand('october.env', 'System\Console\OctoberEnv');
$this->registerConsoleCommand('october.install', 'System\Console\OctoberInstall');
$this->registerConsoleCommand('october.passwd', 'System\Console\OctoberPasswd');
$this->registerConsoleCommand('plugin.install', 'System\Console\PluginInstall');
$this->registerConsoleCommand('plugin.remove', 'System\Console\PluginRemove');

View File

@ -0,0 +1,112 @@
<?php namespace System\Console;
use Str;
use Backend\Models\User;
use Illuminate\Console\Command;
use Illuminate\Database\Eloquent\ModelNotFoundException;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Question\Question;
/**
* Console command to change the password of a Backend user via CLI.
*
* @package october\system
*/
class OctoberPasswd extends Command
{
/**
* @var string The console command name.
*/
protected $name = 'october:passwd';
/**
* @var string The console command description.
*/
protected $description = 'Change the password of a Backend user.';
/**
* @var bool Was the password automatically generated?
*/
protected $generatedPassword = false;
/**
* Execute the console command.
*/
public function handle()
{
$username = $this->argument('username')
?? $this->ask(
'Which user would you like to change the password for?'
);
// Check that the user exists
try {
$user = User::where('login', $username)
->orWhere('email', $username)
->firstOrFail();
} catch (ModelNotFoundException $e) {
$this->error('The specified user does not exist.');
exit(1);
}
$password = $this->argument('password')
?? (
$this->optionalSecret(
'Enter in a new password, or press ENTER to use a generated password',
false,
false
) ?: $this->generatePassword()
);
// Change password
$user->password = $password;
$user->forceSave();
$this->info('Password successfully changed.');
if (!$this->generatedPassword) {
$this->output->writeLn('The new password is <info>' . $password . '</info>.');
}
exit(0);
}
/**
* Get the console command options.
*/
protected function getArguments()
{
return [
['username', InputArgument::OPTIONAL, 'The username of the Backend user'],
['password', InputArgument::OPTIONAL, 'The new password']
];
}
/**
* Prompt the user for input but hide the answer from the console.
*
* Also allows for a default to be specified.
*
* @param string $question
* @param bool $fallback
* @return string
*/
protected function optionalSecret($question, $fallback = true, $default = null)
{
$question = new Question($question, $default);
$question->setHidden(true)->setHiddenFallback($fallback);
return $this->output->askQuestion($question);
}
/**
* Generate a password and flag it as an automatically-generated password.
*
* @return string
*/
protected function generatePassword()
{
$this->generatedPassword = true;
return Str::random(22);
}
}