Summary: Revisit of D1254. Don't require lowercase, just standardize the logic. The current implementation has nonuniform logic -- PeopleEditController forbids uppercase. Test Plan: Ran unit tests, see also D1254. Reviewers: btrahan, jungejason, aran Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D1415
177 lines
5.2 KiB
PHP
177 lines
5.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2012 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.
|
|
*/
|
|
|
|
class PhabricatorOAuthDefaultRegistrationController
|
|
extends PhabricatorOAuthRegistrationController {
|
|
|
|
public function processRequest() {
|
|
$provider = $this->getOAuthProvider();
|
|
$oauth_info = $this->getOAuthInfo();
|
|
$request = $this->getRequest();
|
|
|
|
$errors = array();
|
|
$e_username = true;
|
|
$e_email = true;
|
|
$e_realname = true;
|
|
|
|
$user = new PhabricatorUser();
|
|
|
|
$user->setUsername($provider->retrieveUserAccountName());
|
|
$user->setRealName($provider->retrieveUserRealName());
|
|
$user->setEmail($provider->retrieveUserEmail());
|
|
|
|
if ($request->isFormPost()) {
|
|
|
|
$user->setUsername($request->getStr('username'));
|
|
$username = $user->getUsername();
|
|
if (!strlen($user->getUsername())) {
|
|
$e_username = 'Required';
|
|
$errors[] = 'Username is required.';
|
|
} else if (!PhabricatorUser::validateUsername($username)) {
|
|
$e_username = 'Invalid';
|
|
$errors[] = 'Username must consist of only numbers and letters.';
|
|
} else {
|
|
$e_username = null;
|
|
}
|
|
|
|
if ($user->getEmail() === null) {
|
|
$user->setEmail($request->getStr('email'));
|
|
if (!strlen($user->getEmail())) {
|
|
$e_email = 'Required';
|
|
$errors[] = 'Email is required.';
|
|
} else {
|
|
$e_email = null;
|
|
}
|
|
}
|
|
|
|
if (!strlen($user->getRealName())) {
|
|
$user->setRealName($request->getStr('realname'));
|
|
if (!strlen($user->getRealName())) {
|
|
$e_realname = 'Required';
|
|
$errors[] = 'Real name is required.';
|
|
} else {
|
|
$e_realname = null;
|
|
}
|
|
}
|
|
|
|
if (!$errors) {
|
|
$image = $provider->retrieveUserProfileImage();
|
|
if ($image) {
|
|
$file = PhabricatorFile::newFromFileData(
|
|
$image,
|
|
array(
|
|
'name' => $provider->getProviderKey().'-profile.jpg',
|
|
'authorPHID' => $user->getPHID(),
|
|
));
|
|
$user->setProfileImagePHID($file->getPHID());
|
|
}
|
|
|
|
try {
|
|
$user->save();
|
|
|
|
$oauth_info->setUserID($user->getID());
|
|
$oauth_info->save();
|
|
|
|
$session_key = $user->establishSession('web');
|
|
$request->setCookie('phusr', $user->getUsername());
|
|
$request->setCookie('phsid', $session_key);
|
|
return id(new AphrontRedirectResponse())->setURI('/');
|
|
} catch (AphrontQueryDuplicateKeyException $exception) {
|
|
|
|
$same_username = id(new PhabricatorUser())->loadOneWhere(
|
|
'userName = %s',
|
|
$user->getUserName());
|
|
|
|
$same_email = id(new PhabricatorUser())->loadOneWhere(
|
|
'email = %s',
|
|
$user->getEmail());
|
|
|
|
if ($same_username) {
|
|
$e_username = 'Duplicate';
|
|
$errors[] = 'That username or email is not unique.';
|
|
} else if ($same_email) {
|
|
$e_email = 'Duplicate';
|
|
$errors[] = 'That email is not unique.';
|
|
} else {
|
|
throw $exception;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$error_view = null;
|
|
if ($errors) {
|
|
$error_view = new AphrontErrorView();
|
|
$error_view->setTitle('Registration Failed');
|
|
$error_view->setErrors($errors);
|
|
}
|
|
|
|
$form = new AphrontFormView();
|
|
$form
|
|
->addHiddenInput('token', $provider->getAccessToken())
|
|
->addHiddenInput('expires', $oauth_info->getTokenExpires())
|
|
->addHiddenInput('state', $this->getOAuthState())
|
|
->setUser($request->getUser())
|
|
->setAction($provider->getRedirectURI())
|
|
->appendChild(
|
|
id(new AphrontFormTextControl())
|
|
->setLabel('Username')
|
|
->setName('username')
|
|
->setValue($user->getUsername())
|
|
->setError($e_username));
|
|
|
|
if ($provider->retrieveUserEmail() === null) {
|
|
$form->appendChild(
|
|
id(new AphrontFormTextControl())
|
|
->setLabel('Email')
|
|
->setName('email')
|
|
->setValue($request->getStr('email'))
|
|
->setError($e_email));
|
|
}
|
|
|
|
if ($provider->retrieveUserRealName () === null) {
|
|
$form->appendChild(
|
|
id(new AphrontFormTextControl())
|
|
->setLabel('Real Name')
|
|
->setName('realname')
|
|
->setValue($request->getStr('realname'))
|
|
->setError($e_realname));
|
|
}
|
|
|
|
$form
|
|
->appendChild(
|
|
id(new AphrontFormSubmitControl())
|
|
->setValue('Create Account'));
|
|
|
|
$panel = new AphrontPanelView();
|
|
$panel->setHeader('Create New Account');
|
|
$panel->setWidth(AphrontPanelView::WIDTH_FORM);
|
|
$panel->appendChild($form);
|
|
|
|
return $this->buildStandardPageResponse(
|
|
array(
|
|
$error_view,
|
|
$panel,
|
|
),
|
|
array(
|
|
'title' => 'Create New Account',
|
|
));
|
|
}
|
|
|
|
}
|