updating mw fas plugin with mostly working code to allow users to login to with username or username@fp.o
This commit is contained in:
parent
c761cf1219
commit
c34d9972fe
1 changed files with 54 additions and 4 deletions
|
@ -1,12 +1,24 @@
|
||||||
<?php
|
<?php
|
||||||
require_once('AuthPlugin.php');
|
require_once('AuthPlugin.php');
|
||||||
class Auth_FAS extends AuthPlugin {
|
class Auth_FAS extends AuthPlugin {
|
||||||
function authenticate($username, $password) {
|
|
||||||
|
var $fas_username;
|
||||||
|
|
||||||
|
function setFasUsername($user) {
|
||||||
|
$this->fas_username = $user;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getFasUsername() {
|
||||||
|
return $this->fas_username;
|
||||||
|
}
|
||||||
|
|
||||||
|
function authenticate(&$username, $password) {
|
||||||
|
|
||||||
if ( ucfirst(strtolower($username)) != ucfirst($username) ) {
|
if ( ucfirst(strtolower($username)) != ucfirst($username) ) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$username = strtolower( $username);
|
$username = strtolower($username);
|
||||||
$ch = curl_init();
|
$ch = curl_init();
|
||||||
|
|
||||||
curl_setopt($ch, CURLOPT_URL, 'https://admin.fedoraproject.org/accounts/home');
|
curl_setopt($ch, CURLOPT_URL, 'https://admin.fedoraproject.org/accounts/home');
|
||||||
|
@ -35,6 +47,9 @@ class Auth_FAS extends AuthPlugin {
|
||||||
}
|
}
|
||||||
|
|
||||||
$groups = $response['memberships'];
|
$groups = $response['memberships'];
|
||||||
|
// let's make sure the username is consistent
|
||||||
|
$this->setFasUsername(ucfirst(strtolower($response['person']['username'])));
|
||||||
|
$username = $this->getFasUsername();
|
||||||
|
|
||||||
for ($i = 0, $cnt = count($groups); $i < $cnt; $i++) {
|
for ($i = 0, $cnt = count($groups); $i < $cnt; $i++) {
|
||||||
if ($groups[$i]["name"] == 'cla_done' && $response['person']['status'] == 'active') {
|
if ($groups[$i]["name"] == 'cla_done' && $response['person']['status'] == 'active') {
|
||||||
|
@ -47,68 +62,103 @@ class Auth_FAS extends AuthPlugin {
|
||||||
}
|
}
|
||||||
|
|
||||||
function userExists( $username ) {
|
function userExists( $username ) {
|
||||||
if ( ucfirst(strtolower($username)) != ucfirst($username) ) {
|
error_log("FAS [userExists]: $username, " . $this->getFasUsername(), 0);
|
||||||
|
|
||||||
|
if (ucfirst(strtolower($username)) != $this->getFasUsername()) {
|
||||||
|
error_log("FAS [userExists]: returned false", 0);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
error_log("FAS [userExists]: returned true", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function modifyUITemplate(&$template) {
|
function modifyUITemplate(&$template) {
|
||||||
|
error_log("FAS [modifyUITemplate]: " . $this->getFasUsername(), 0);
|
||||||
$template->set('create', false);
|
$template->set('create', false);
|
||||||
$template->set('useemail', false);
|
$template->set('useemail', false);
|
||||||
$template->set('usedomain', false);
|
$template->set('usedomain', false);
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateUser( &$user ){
|
function updateUser( &$user ){
|
||||||
|
//error_log("FAS [updateUser]: " . $user->getName() . ", " . $this->getFasUsername(), 0);
|
||||||
|
$user->setName($this->getFasUsername());
|
||||||
$user->mEmail = strtolower($user->getName())."@fedoraproject.org";
|
$user->mEmail = strtolower($user->getName())."@fedoraproject.org";
|
||||||
|
//error_log("FAS [updateUser]: " . $user->getName() . ", " . $this->getFasUsername(), 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function autoCreate() {
|
function autoCreate() {
|
||||||
|
//error_log("FAS [autoCreate]: ", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setPassword($password) {
|
function setPassword($password) {
|
||||||
|
//error_log("FAS [setPassword]: $password", 0);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setDomain( $domain ) {
|
function setDomain( $domain ) {
|
||||||
|
//error_log("FAS [setDomain]: $domain", 0);
|
||||||
$this->domain = $domain;
|
$this->domain = $domain;
|
||||||
}
|
}
|
||||||
|
|
||||||
function validDomain( $domain ) {
|
function validDomain( $domain ) {
|
||||||
|
//error_log("FAS [validDomain]: $domain", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateExternalDB($user) {
|
function updateExternalDB($user) {
|
||||||
|
//error_log("FAS [updateExternalDB]: $user", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function canCreateAccounts() {
|
function canCreateAccounts() {
|
||||||
|
//error_log("FAS [canCreateAccounts]:", 0);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
function addUser($user, $password) {
|
function addUser($user, $password) {
|
||||||
|
//error_log("FAS [addUser]: $user, $password", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function strict() {
|
function strict() {
|
||||||
|
//error_log("FAS [strict]:", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function strictUserAuth( $username ) {
|
function strictUserAuth( $username ) {
|
||||||
|
//error_log("FAS [strictUserAuth]: $username", 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function allowPasswordChange() {
|
function allowPasswordChange() {
|
||||||
|
//error_log("FAS [allowPasswordChange]:" . $this->getFasUsername(), 0);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getCanonicalName( $username ) {
|
||||||
|
//error_log("FAS [getCanonicalName]: " . $username, 0);
|
||||||
|
|
||||||
|
$username = str_replace('@fedoraproject.org', '', $username);
|
||||||
|
|
||||||
|
//error_log("FAS [getCanonicalName]: returning... " . $username, 0);
|
||||||
|
return $username;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getUserInstance( &$user ) {
|
||||||
|
//error_log("FAS [getUserInstance]: " . print_r($user), 0);
|
||||||
|
return new AuthPluginUser( $user );
|
||||||
|
}
|
||||||
|
|
||||||
function initUser(&$user) {
|
function initUser(&$user) {
|
||||||
|
//error_log("FAS [initUser]: " . $user->getName() . ", " . $this->getFasUsername(), 0);
|
||||||
|
$user->setName($this->getFasUsername());
|
||||||
$user->mEmail = strtolower($user->getName())."@fedoraproject.org";
|
$user->mEmail = strtolower($user->getName())."@fedoraproject.org";
|
||||||
$user->mEmailAuthenticated = wfTimestampNow();
|
$user->mEmailAuthenticated = wfTimestampNow();
|
||||||
$user->setToken();
|
$user->setToken();
|
||||||
$user->saveSettings();
|
$user->saveSettings();
|
||||||
|
//error_log("FAS [initUser]: " . $user->getName() . ", " . $this->getFasUsername(), 0);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue