summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorVincent Petry <vincent@nextcloud.com>2022-03-11 11:55:01 +0100
committerGitHub <noreply@github.com>2022-03-11 11:55:01 +0100
commitcec00df21c8d212c4eb07836972d2ac73aa1b59c (patch)
tree215ad0281b5c8f2c9fbd8ab773c2556464473213 /core
parent2cf0edf03ce02e4a813abce262a4f60abaab4855 (diff)
parent50ccf7e2cff8dfe6345d32e5c3b69a544eef52ea (diff)
downloadnextcloud-server-cec00df21c8d212c4eb07836972d2ac73aa1b59c.tar.gz
nextcloud-server-cec00df21c8d212c4eb07836972d2ac73aa1b59c.zip
Merge pull request #31519 from nextcloud/bugfix/noid/fix-occ-user-add-apppassword
Fix occ user:add-app-password
Diffstat (limited to 'core')
-rw-r--r--core/Command/User/AddAppPassword.php23
-rw-r--r--core/register_command.php2
2 files changed, 16 insertions, 9 deletions
diff --git a/core/Command/User/AddAppPassword.php b/core/Command/User/AddAppPassword.php
index a29692df045..4f636c406fb 100644
--- a/core/Command/User/AddAppPassword.php
+++ b/core/Command/User/AddAppPassword.php
@@ -23,10 +23,11 @@
*/
namespace OC\Core\Command\User;
+use OC\Authentication\Events\AppPasswordCreatedEvent;
use OC\Authentication\Token\IProvider;
use OC\Authentication\Token\IToken;
+use OCP\EventDispatcher\IEventDispatcher;
use OCP\IUserManager;
-use OCP\Security\ICrypto;
use OCP\Security\ISecureRandom;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Helper\QuestionHelper;
@@ -44,17 +45,17 @@ class AddAppPassword extends Command {
protected $tokenProvider;
/** @var ISecureRandom */
private $random;
- /** @var ICrypto */
- private $crypto;
+ /** @var IEventDispatcher */
+ private $eventDispatcher;
public function __construct(IUserManager $userManager,
IProvider $tokenProvider,
ISecureRandom $random,
- ICrypto $crypto) {
+ IEventDispatcher $eventDispatcher) {
$this->tokenProvider = $tokenProvider;
$this->userManager = $userManager;
$this->random = $random;
- $this->crypto = $crypto;
+ $this->eventDispatcher = $eventDispatcher;
parent::__construct();
}
@@ -108,11 +109,13 @@ class AddAppPassword extends Command {
return 1;
}
- $output->writeln('<info>The password is not validated so what you provide is what gets recorded in the token</info>');
-
+ if (!$this->userManager->checkPassword($user->getUID(), $password)) {
+ $output->writeln('<error>The provided password is invalid</error>');
+ return 1;
+ }
$token = $this->random->generate(72, ISecureRandom::CHAR_UPPER.ISecureRandom::CHAR_LOWER.ISecureRandom::CHAR_DIGITS);
- $this->tokenProvider->generateToken(
+ $generatedToken = $this->tokenProvider->generateToken(
$token,
$user->getUID(),
$user->getUID(),
@@ -122,6 +125,10 @@ class AddAppPassword extends Command {
IToken::DO_NOT_REMEMBER
);
+ $this->eventDispatcher->dispatchTyped(
+ new AppPasswordCreatedEvent($generatedToken)
+ );
+
$output->writeln('app password:');
$output->writeln($token);
diff --git a/core/register_command.php b/core/register_command.php
index c7d3b073b91..5a708510568 100644
--- a/core/register_command.php
+++ b/core/register_command.php
@@ -187,7 +187,7 @@ if (\OC::$server->getConfig()->getSystemValue('installed', false)) {
$application->add(new OC\Core\Command\User\Setting(\OC::$server->getUserManager(), \OC::$server->getConfig()));
$application->add(new OC\Core\Command\User\ListCommand(\OC::$server->getUserManager(), \OC::$server->getGroupManager()));
$application->add(new OC\Core\Command\User\Info(\OC::$server->getUserManager(), \OC::$server->getGroupManager()));
- $application->add(new OC\Core\Command\User\AddAppPassword(\OC::$server->get(\OCP\IUserManager::class), \OC::$server->get(\OC\Authentication\Token\IProvider::class), \OC::$server->get(\OCP\Security\ISecureRandom::class), \OC::$server->get(\OCP\Security\ICrypto::class)));
+ $application->add(new OC\Core\Command\User\AddAppPassword(\OC::$server->get(\OCP\IUserManager::class), \OC::$server->get(\OC\Authentication\Token\IProvider::class), \OC::$server->get(\OCP\Security\ISecureRandom::class), \OC::$server->get(\OCP\EventDispatcher\IEventDispatcher::class)));
$application->add(new OC\Core\Command\Group\Add(\OC::$server->getGroupManager()));
$application->add(new OC\Core\Command\Group\Delete(\OC::$server->getGroupManager()));