mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-25 14:08:19 +01:00
bc71888249
Summary: Currently, we echo the password as the user types it. This turns out to be a bit of an issue in over-the-shoulder installs. Instead, disable tty echo while the user is typing their password so nothing is shown (like how 'sudo' works). Also show a better error message if the user chooses a duplicate email; without testing for this we just throw a duplicate key exception when saving, which isn't easy to understand. The other duplicate key exception is duplicate username, which is impossible (the script updates rather than creating in this case). There's currently a bug where creating a user and setting their password at the same time doesn't work. This is because we hash the PHID into the password hash, but it's empty if the user hasn't been persisted yet. Make sure the user is persisted before setting their password. Finally, fix an issue where $original would have the new username set, creating a somewhat confusing summary at the end. I'm also going to improve the password behavior/explanation here once I add welcome emails ("Hi Joe, epriestley created an account for you on Phabricator, click here to login..."). Test Plan: - Typed a password and didn't have it echoed. I also tested this on Ubuntu without encountering problems. - Chose a duplicate email, got a useful error message instead of the exception I'd encountered earlier. - Created a new user with a password in one pass and logged in as that user, this worked properly. - Verified summary table does not contain username for new users. Reviewed By: jungejason Reviewers: jungejason, tuomaspelkonen, aran CC: moskov, jr, aran, jungejason Differential Revision: 358
150 lines
4 KiB
PHP
Executable file
150 lines
4 KiB
PHP
Executable file
#!/usr/bin/env php
|
|
<?php
|
|
|
|
/*
|
|
* Copyright 2011 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
$root = dirname(dirname(dirname(__FILE__)));
|
|
require_once $root.'/scripts/__init_script__.php';
|
|
require_once $root.'/scripts/__init_env__.php';
|
|
|
|
phutil_require_module('phutil', 'console');
|
|
phutil_require_module('phutil', 'future/exec');
|
|
|
|
echo "Enter a username to create a new account or edit an existing account.";
|
|
|
|
$username = phutil_console_prompt("Enter a username:");
|
|
if (!strlen($username)) {
|
|
echo "Cancelled.\n";
|
|
exit(1);
|
|
}
|
|
|
|
$user = id(new PhabricatorUser())->loadOneWhere(
|
|
'username = %s',
|
|
$username);
|
|
|
|
if (!$user) {
|
|
$original = new PhabricatorUser();
|
|
|
|
echo "There is no existing user account '{$username}'.\n";
|
|
$ok = phutil_console_confirm(
|
|
"Do you want to create a new '{$username}' account?",
|
|
$default_no = false);
|
|
if (!$ok) {
|
|
echo "Cancelled.\n";
|
|
exit(1);
|
|
}
|
|
$user = new PhabricatorUser();
|
|
$user->setUsername($username);
|
|
} else {
|
|
$original = clone $user;
|
|
|
|
echo "There is an existing user account '{$username}'.\n";
|
|
$ok = phutil_console_confirm(
|
|
"Do you want to edit the existing '{$username}' account?",
|
|
$default_no = false);
|
|
if (!$ok) {
|
|
echo "Cancelled.\n";
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
$user_realname = $user->getRealName();
|
|
if (strlen($user_realname)) {
|
|
$realname_prompt = ' ['.$user_realname.']';
|
|
} else {
|
|
$realname_prompt = '';
|
|
}
|
|
$realname = nonempty(
|
|
phutil_console_prompt("Enter user real name{$realname_prompt}:"),
|
|
$user_realname);
|
|
$user->setRealName($realname);
|
|
|
|
$user_email = $user->getEmail();
|
|
if (strlen($user_email)) {
|
|
$email_prompt = ' ['.$user_email.']';
|
|
} else {
|
|
$email_prompt = '';
|
|
}
|
|
|
|
do {
|
|
$email = nonempty(
|
|
phutil_console_prompt("Enter user email address{$email_prompt}:"),
|
|
$user_email);
|
|
$duplicate = id(new PhabricatorUser())->loadOneWhere(
|
|
'email = %s',
|
|
$email);
|
|
if ($duplicate && $duplicate->getID() != $user->getID()) {
|
|
$duplicate_username = $duplicate->getUsername();
|
|
echo "ERROR: There is already a user with that email address ".
|
|
"({$duplicate_username}). Each user must have a unique email ".
|
|
"address.\n";
|
|
} else {
|
|
break;
|
|
}
|
|
} while (true);
|
|
$user->setEmail($email);
|
|
|
|
$changed_pass = false;
|
|
// This disables local echo, so the user's password is not shown as they type
|
|
// it.
|
|
phutil_passthru('stty -echo');
|
|
$password = phutil_console_prompt(
|
|
"Enter a password for this user [blank to leave unchanged]:");
|
|
phutil_passthru('stty echo');
|
|
if (strlen($password)) {
|
|
$changed_pass = $password;
|
|
}
|
|
|
|
$is_admin = $user->getIsAdmin();
|
|
$set_admin = phutil_console_confirm(
|
|
'Should this user be an administrator?',
|
|
$default_no = !$is_admin);
|
|
$user->setIsAdmin($set_admin);
|
|
|
|
echo "\n\nACCOUNT SUMMARY\n\n";
|
|
$tpl = "%12s %-30s %-30s\n";
|
|
printf($tpl, null, 'OLD VALUE', 'NEW VALUE');
|
|
printf($tpl, 'Username', $original->getUsername(), $user->getUsername());
|
|
printf($tpl, 'Real Name', $original->getRealName(), $user->getRealName());
|
|
printf($tpl, 'Email', $original->getEmail(), $user->getEmail());
|
|
printf($tpl, 'Password', null,
|
|
($changed_pass !== false)
|
|
? 'Updated'
|
|
: 'Unchanged');
|
|
|
|
printf(
|
|
$tpl,
|
|
'Admin',
|
|
$original->getIsAdmin() ? 'Y' : 'N',
|
|
$user->getIsAdmin() ? 'Y' : 'N');
|
|
|
|
echo "\n";
|
|
|
|
if (!phutil_console_confirm("Save these changes?", $default_no = false)) {
|
|
echo "Cancelled.\n";
|
|
exit(1);
|
|
}
|
|
|
|
$user->save();
|
|
if ($changed_pass !== false) {
|
|
// This must happen after saving the user because we use their PHID as a
|
|
// component of the password hash.
|
|
$user->setPassword($changed_pass);
|
|
$user->save();
|
|
}
|
|
|
|
echo "Saved changes.\n";
|