Merge pull request #39611 from FedericoHeichou/add-command-user-welcome
commit
62f9c26111
@ -0,0 +1,86 @@ |
|||||||
|
<?php |
||||||
|
/** |
||||||
|
* SPDX-FileCopyrightText: 2023 FedericoHeichou <federicoheichou@gmail.com> |
||||||
|
* SPDX-License-Identifier: AGPL-3.0-or-later |
||||||
|
*/ |
||||||
|
|
||||||
|
namespace OC\Core\Command\User; |
||||||
|
|
||||||
|
use OC\Core\Command\Base; |
||||||
|
use OCA\Settings\Mailer\NewUserMailHelper; |
||||||
|
use OCP\IUserManager; |
||||||
|
use Symfony\Component\Console\Input\InputArgument; |
||||||
|
use Symfony\Component\Console\Input\InputInterface; |
||||||
|
use Symfony\Component\Console\Input\InputOption; |
||||||
|
use Symfony\Component\Console\Output\OutputInterface; |
||||||
|
|
||||||
|
class Welcome extends Base { |
||||||
|
/** @var IUserManager */ |
||||||
|
protected $userManager; |
||||||
|
|
||||||
|
/** @var NewUserMailHelper */ |
||||||
|
private $newUserMailHelper; |
||||||
|
|
||||||
|
/** |
||||||
|
* @param IUserManager $userManager |
||||||
|
* @param NewUserMailHelper $newUserMailHelper |
||||||
|
*/ |
||||||
|
public function __construct( |
||||||
|
IUserManager $userManager, |
||||||
|
NewUserMailHelper $newUserMailHelper |
||||||
|
) { |
||||||
|
parent::__construct(); |
||||||
|
|
||||||
|
$this->userManager = $userManager; |
||||||
|
$this->newUserMailHelper = $newUserMailHelper; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @return void |
||||||
|
*/ |
||||||
|
protected function configure() { |
||||||
|
$this |
||||||
|
->setName('user:welcome') |
||||||
|
->setDescription('Sends the welcome email') |
||||||
|
->addArgument( |
||||||
|
'user', |
||||||
|
InputArgument::REQUIRED, |
||||||
|
'The user to send the email to' |
||||||
|
) |
||||||
|
->addOption( |
||||||
|
'reset-password', |
||||||
|
'r', |
||||||
|
InputOption::VALUE_NONE, |
||||||
|
'Add the reset password link to the email' |
||||||
|
) |
||||||
|
; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* @param InputInterface $input |
||||||
|
* @param OutputInterface $output |
||||||
|
* @return int |
||||||
|
*/ |
||||||
|
protected function execute(InputInterface $input, OutputInterface $output): int { |
||||||
|
$userId = $input->getArgument('user'); |
||||||
|
// check if user exists |
||||||
|
$user = $this->userManager->get($userId); |
||||||
|
if ($user === null) { |
||||||
|
$output->writeln('<error>User does not exist</error>'); |
||||||
|
return 1; |
||||||
|
} |
||||||
|
$email = $user->getEMailAddress(); |
||||||
|
if ($email === '' || $email === null) { |
||||||
|
$output->writeln('<error>User does not have an email address</error>'); |
||||||
|
return 1; |
||||||
|
} |
||||||
|
try { |
||||||
|
$emailTemplate = $this->newUserMailHelper->generateTemplate($user, $input->getOption('reset-password')); |
||||||
|
$this->newUserMailHelper->sendMail($user, $emailTemplate); |
||||||
|
} catch (\Exception $e) { |
||||||
|
$output->writeln('<error>Failed to send email: ' . $e->getMessage() . '</error>'); |
||||||
|
return 1; |
||||||
|
} |
||||||
|
return 0; |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue