Skip to content

Commit

Permalink
Do not change the old behavior of user creation
Browse files Browse the repository at this point in the history
  • Loading branch information
karakayasemi committed Dec 12, 2019
1 parent 46dcb47 commit 5cc92c9
Show file tree
Hide file tree
Showing 8 changed files with 60 additions and 49 deletions.
2 changes: 1 addition & 1 deletion apps/provisioning_api/lib/Users.php
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ public function addUser() {
return new Result(null, 102, 'User already exists');
}

if (\is_array($groups) && (\count($groups) > 0)) {
if (\is_array($groups)) {
foreach ($groups as $group) {
if (!$this->groupManager->groupExists($group)) {
return new Result(null, 104, 'group '.$group.' does not exist');
Expand Down
19 changes: 15 additions & 4 deletions core/Command/User/Add.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\ConsoleOutputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Question\Question;
Expand Down Expand Up @@ -91,7 +92,17 @@ protected function configure() {
);
}

/**
* @param InputInterface $input
* @param OutputInterface $output
* @return int
*/
protected function execute(InputInterface $input, OutputInterface $output) {
$stdErr = $output;
if ($output instanceof ConsoleOutputInterface) {
// If it's available, get stdErr output
$stdErr = $output->getErrorOutput();
}
$uid = $input->getArgument('uid');
$email = $input->getOption('email');
$displayName = $input->getOption('display-name');
Expand Down Expand Up @@ -134,20 +145,20 @@ protected function execute(InputInterface $input, OutputInterface $output) {
try {
$user = $this->createUserService->createUser(['username' => $uid, 'password' => $password, 'email' => $email]);
} catch (InvalidEmailException $e) {
$output->writeln('<error>Invalid email address supplied</error>');
$stdErr->writeln('<error>Invalid email address supplied</error>');
return 1;
} catch (CannotCreateUserException $e) {
$output->writeln("<error>" . $e->getMessage() . "</error>");
$stdErr->writeln("<error>" . $e->getMessage() . "</error>");
return 1;
} catch (UserAlreadyExistsException $e) {
$output->writeln("<error>" . $e->getMessage() . "</error>");
$stdErr->writeln("<error>" . $e->getMessage() . "</error>");
return 1;
}

if ($user instanceof IUser) {
$output->writeln('<info>The user "' . $user->getUID() . '" was created successfully</info>');
} else {
$output->writeln('<error>An error occurred while creating the user</error>');
$stdErr->writeln('<error>An error occurred while creating the user</error>');
return 1;
}

Expand Down
2 changes: 1 addition & 1 deletion core/Controller/LostController.php
Original file line number Diff line number Diff line change
Expand Up @@ -253,7 +253,7 @@ public function setPassword($token, $userId, $password, $proceed) {
}

\OC_Hook::emit('\OC\Core\LostPassword\Controller\LostController', 'post_passwordReset', ['uid' => $userId, 'password' => $password]);
@\OC_User::unsetMagicInCookie();
$this->userSession->unsetMagicInCookie();
} catch (\Exception $e) {
return $this->error($e->getMessage());
}
Expand Down
22 changes: 12 additions & 10 deletions core/Controller/UserController.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
namespace OC\Core\Controller;

use OC\User\Service\UserSendMailService;
use OC\User\Session;
use \OCP\AppFramework\Controller;
use OCP\AppFramework\Http;
use \OCP\AppFramework\Http\JSONResponse;
Expand All @@ -38,14 +39,10 @@
use OCP\User\Exceptions\UserTokenExpiredException;

class UserController extends Controller {
/**
* @var \OCP\IUserManager
*/
/** @var \OCP\IUserManager */
protected $userManager;

/**
* @var \OC_Defaults
*/
/** @var \OC_Defaults */
protected $defaults;

/** @var UserSendMailService */
Expand All @@ -60,6 +57,9 @@ class UserController extends Controller {
/** @var IL10N */
private $l10n;

/** @var Session */
private $session;

/**
* UserController constructor.
*
Expand All @@ -70,15 +70,16 @@ class UserController extends Controller {
* @param UserSendMailService $userSendMailService
* @param IURLGenerator $urlGenerator
* @param ILogger $logger
* @param IL10N $l10n
* @param IL10N $l10n,
* @param Session $session
*/
public function __construct($appName,
IRequest $request,
$userManager,
$defaults,
UserSendMailService $userSendMailService,
IURLGenerator $urlGenerator, ILogger $logger,
IL10N $l10n
IL10N $l10n, Session $session
) {
parent::__construct($appName, $request);
$this->userManager = $userManager;
Expand All @@ -87,6 +88,7 @@ public function __construct($appName,
$this->urlGenerator = $urlGenerator;
$this->logger = $logger;
$this->l10n = $l10n;
$this->session = $session;
}

/**
Expand Down Expand Up @@ -173,7 +175,7 @@ public function resendToken($userId) {
$user = $this->userManager->get($userId);

if ($user === null) {
$this->logger->error('User: ' . $userId . ' does not exist', ['app' => 'core']);
$this->logger->error("Failed to create activation link. User $userId does not exists", ['app' => 'core']);
return new TemplateResponse(
'core', 'error',
[
Expand Down Expand Up @@ -252,7 +254,7 @@ public function setPassword($token, $userId, $password) {
}

\OC_Hook::emit('\OC\Core\LostPassword\Controller\LostController', 'post_passwordReset', ['uid' => $userId, 'password' => $password]);
@\OC_User::unsetMagicInCookie();
$this->session->unsetMagicInCookie();
} catch (UserTokenException $e) {
$this->logger->logException($e, ['app' => 'core']);
return new JSONResponse(
Expand Down
22 changes: 10 additions & 12 deletions core/js/setpassword.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,20 +23,19 @@
passwordObj.val('');
retypePasswordObj.val('');
passwordObj.parent().addClass('shake');
$('#message').addClass('warning');
$('#message').text('Passwords do not match');
$('#message').show();
$('#message').addClass('warning')
.text('Passwords do not match')
.show();
passwordObj.focus();
}
},

_onSetPasswordFail: function(result) {
var responseObj = JSON.parse(result.responseText);
var response = JSON.parse(result.responseText);
var errorObject = $('#error-message');
var showErrorMessage = false;

var errorMessage;
errorMessage = responseObj.message;
errorMessage = response.message;

if (!errorMessage) {
errorMessage = t('core', 'Failed to set password. Please contact your administrator.');
Expand All @@ -49,15 +48,15 @@

_resetDone : function(result){
if (result && result.status === 'success') {
var getRootPath = OC.getRootPath();
if (getRootPath === '') {
var rootPath = OC.getRootPath();
if (rootPath === '') {
/**
* If owncloud is not run inside subfolder, the getRootPath
* will return empty string
*/
getRootPath = "/";
rootPath = "/";
}
OC.redirect(getRootPath);
OC.redirect(rootPath);
}
}
};
Expand All @@ -76,8 +75,7 @@ $(document).ready(function () {
Else it should not.
*/
if (($('#password').val().length >= 0) && ($('#retypepassword').val().length === 0)) {
$('#message').removeClass('warning');
$('#message').text('');
$('#message').removeClass('warning').text('');
}
});
});
17 changes: 9 additions & 8 deletions lib/private/User/Service/CreateUserService.php
Original file line number Diff line number Diff line change
Expand Up @@ -92,12 +92,17 @@ public function __construct(IUserSession $userSession, IGroupManager $groupManag
* @throws UserAlreadyExistsException
*/
public function createUser($arguments) {
$username = $password = $email = '';
if (\array_key_exists('username', $arguments)) {
$password = $email = '';
if (isset($arguments['username'])) {
$username = $arguments['username'];
} else {
throw new CannotCreateUserException("Unable to create user due to missing user name");
}

if ($this->userManager->userExists($username)) {
throw new UserAlreadyExistsException('A user with that name already exists.');
}

if (\array_key_exists('password', $arguments)) {
$password = $arguments['password'];
}
Expand All @@ -109,10 +114,6 @@ public function createUser($arguments) {
throw new InvalidEmailException("Invalid mail address");
}

if ($this->userManager->userExists($username)) {
throw new UserAlreadyExistsException('A user with that name already exists.');
}

try {
$oldPassword = $password;
if (($password === '') && ($email !== '')) {
Expand All @@ -125,7 +126,7 @@ public function createUser($arguments) {
}
$user = $this->userManager->createUser($username, $password);
} catch (\Exception $exception) {
throw new CannotCreateUserException("Unable to create user due to exception: {$exception->getMessage()}");
throw new CannotCreateUserException($exception->getMessage());
}

if ($user === false) {
Expand Down Expand Up @@ -169,7 +170,7 @@ public function createUser($arguments) {
public function addUserToGroups(IUser $user, array $groups, $checkInGroup = true) {
$failedToAdd = [];

if (\is_array($groups) && \count($groups) > 0) {
if (\count($groups) > 0) {
foreach ($groups as $groupName) {
$groupObject = $this->groupManager->get($groupName);

Expand Down
21 changes: 10 additions & 11 deletions lib/private/User/Service/UserSendMailService.php
Original file line number Diff line number Diff line change
Expand Up @@ -153,18 +153,17 @@ public function sendNotificationMail(IUser $user) {
$fromMailAddress = Util::getDefaultEmailAddress('no-reply');

if ($email !== '') {
$tmpl = new \OC_Template('core', 'lostpassword/notify');
$msg = $tmpl->fetchPage();
$tmplAlt = new \OC_Template('core', 'lostpassword/altnotify');
$msgAlt = $tmplAlt->fetchPage();
$message = $this->mailer->createMessage();
$message->setTo([$email => $user->getUID()]);
$message->setSubject($this->l10n->t('%s password changed successfully', [$this->defaults->getName()]));
$message->setHtmlBody($msg);
$message->setPlainBody($msgAlt);
$message->setFrom([$fromMailAddress => $this->defaults->getName()]);
try {
$tmpl = new \OC_Template('core', 'lostpassword/notify');
$msg = $tmpl->fetchPage();
$tmplAlt = new \OC_Template('core', 'lostpassword/altnotify');
$msgAlt = $tmplAlt->fetchPage();

$message = $this->mailer->createMessage();
$message->setTo([$email => $user->getUID()]);
$message->setSubject($this->l10n->t('%s password changed successfully', [$this->defaults->getName()]));
$message->setHtmlBody($msg);
$message->setPlainBody($msgAlt);
$message->setFrom([$fromMailAddress => $this->defaults->getName()]);
$this->mailer->send($message);
return true;
} catch (\Exception $exception) {
Expand Down
4 changes: 2 additions & 2 deletions tests/lib/User/Service/CreateUserServiceTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ public function testAlreadyExistingUser() {
}

/**
* @expectedExceptionMessage Unable to create user due to exception:
* @expectedExceptionMessage Exception Message
* @expectedException \OCP\User\Exceptions\CannotCreateUserException
*/
public function testUserCreateException() {
Expand All @@ -151,7 +151,7 @@ public function testUserCreateException() {
->willReturn(false);

$this->userManager->method('createUser')
->willThrowException(new \Exception());
->willThrowException(new \Exception("Exception Message"));
$this->createUserService->createUser(['username' => 'foo', 'password' => '', 'email' => '[email protected]']);
}

Expand Down

0 comments on commit 5cc92c9

Please sign in to comment.