You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
505 lines
21 KiB
PHTML
505 lines
21 KiB
PHTML
12 years ago
|
<?php
|
||
11 years ago
|
/**
|
||
|
* handles basic user registration & management functions (shard related).
|
||
|
* The Users class is the basis class of WebUsers, this class provides functions being used by all CMS's and our own www version. The WebUsers class however needs to be reimplemented
|
||
|
* by using the CMS's it's funcionality. This class handles the writing to the shard db mainly, and in case it's offline: writing to the ams_querycache.
|
||
|
* @author Daan Janssens, mentored by Matthew Lagoe
|
||
|
*/
|
||
12 years ago
|
class Users{
|
||
11 years ago
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* checks if entered values before registering are valid.
|
||
11 years ago
|
* @param $values array with Username,Password, ConfirmPass and Email.
|
||
12 years ago
|
* @return string Info: Returns a string, if input data is valid then "success" is returned, else an array with errors
|
||
11 years ago
|
*/
|
||
12 years ago
|
public function check_Register($values){
|
||
12 years ago
|
// check values
|
||
12 years ago
|
if ( isset( $values["Username"] ) and isset( $values["Password"] ) and isset( $values["ConfirmPass"] ) and isset( $values["Email"] ) ){
|
||
12 years ago
|
$user = Users::checkUser( $values["Username"] );
|
||
|
$pass = Users::checkPassword( $values["Password"] );
|
||
12 years ago
|
$cpass = Users::confirmPassword($pass,$values["Password"],$values["ConfirmPass"]);
|
||
12 years ago
|
$email = Users::checkEmail( $values["Email"] );
|
||
12 years ago
|
}else{
|
||
|
$user = "";
|
||
|
$pass = "";
|
||
|
$cpass = "";
|
||
|
$email = "";
|
||
|
}
|
||
10 years ago
|
|
||
11 years ago
|
if ( helpers :: check_if_game_client() or isset($FORCE_INGAME) ) {
|
||
|
if ( isset( $_POST["TaC"] )) {
|
||
|
$tac="success";
|
||
|
}
|
||
|
} else {
|
||
|
$tac="success";
|
||
|
}
|
||
12 years ago
|
|
||
11 years ago
|
if ( ( $user == "success" ) and ( $pass == "success" ) and ( $cpass == "success" ) and ( $email == "success" ) and ($tac=="success") ){
|
||
12 years ago
|
return "success";
|
||
|
}else{
|
||
11 years ago
|
global $TOS_URL;
|
||
12 years ago
|
$pageElements = array(
|
||
|
//'GAME_NAME' => $GAME_NAME,
|
||
|
// 'WELCOME_MESSAGE' => $WELCOME_MESSAGE,
|
||
|
'USERNAME' => $user,
|
||
|
'PASSWORD' => $pass,
|
||
|
'CPASSWORD' => $cpass,
|
||
11 years ago
|
'EMAIL' => $email,
|
||
|
'TOS_URL' => $TOS_URL
|
||
12 years ago
|
);
|
||
|
if ( $user != "success" ){
|
||
|
$pageElements['USERNAME_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['USERNAME_ERROR'] = 'FALSE';
|
||
|
}
|
||
11 years ago
|
|
||
12 years ago
|
if ( $pass != "success" ){
|
||
|
$pageElements['PASSWORD_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['PASSWORD_ERROR'] = 'FALSE';
|
||
|
}
|
||
|
if ( $cpass != "success" ){
|
||
|
$pageElements['CPASSWORD_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['CPASSWORD_ERROR'] = 'FALSE';
|
||
|
}
|
||
|
if ( $email != "success" ){
|
||
|
$pageElements['EMAIL_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['EMAIL_ERROR'] = 'FALSE';
|
||
|
}
|
||
|
if ( isset( $_POST["TaC"] ) ){
|
||
|
$pageElements['TAC_ERROR'] = 'FALSE';
|
||
|
}else{
|
||
|
$pageElements['TAC_ERROR'] = 'TRUE';
|
||
|
}
|
||
|
return $pageElements;
|
||
|
}
|
||
|
|
||
|
}
|
||
11 years ago
|
|
||
|
|
||
11 years ago
|
/**
|
||
|
* checks if entered username is valid.
|
||
|
* @param $username the username that the user wants to use.
|
||
12 years ago
|
* @return string Info: Returns a string based on if the username is valid, if valid then "success" is returned
|
||
11 years ago
|
*/
|
||
12 years ago
|
public function checkUser( $username )
|
||
12 years ago
|
{
|
||
|
if ( isset( $username ) ){
|
||
|
if ( strlen( $username ) > 12 ){
|
||
|
return "Username must be no more than 12 characters.";
|
||
|
}else if ( strlen( $username ) < 5 ){
|
||
|
return "Username must be 5 or more characters.";
|
||
|
}else if ( !preg_match( '/^[a-z0-9\.]*$/', $username ) ){
|
||
|
return "Username can only contain numbers and letters.";
|
||
|
}else if ( $username == "" ){
|
||
|
return "You have to fill in a username";
|
||
12 years ago
|
}elseif ($this->checkUserNameExists($username)){
|
||
|
return "Username " . $username . " is in use.";
|
||
12 years ago
|
}else{
|
||
|
return "success";
|
||
|
}
|
||
|
}
|
||
|
return "fail";
|
||
|
}
|
||
11 years ago
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* check if username already exists.
|
||
|
* This is the base function, it should be overwritten by the WebUsers class.
|
||
|
* @param $username the username
|
||
12 years ago
|
* @return string Info: Returns true or false if the user is in the www db.
|
||
|
*/
|
||
|
protected function checkUserNameExists($username){
|
||
|
//You should overwrite this method with your own version!
|
||
|
print('this is the base class!');
|
||
11 years ago
|
|
||
12 years ago
|
}
|
||
11 years ago
|
|
||
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* checks if the password is valid.
|
||
|
* @param $pass the password willing to be used.
|
||
12 years ago
|
* @return string Info: Returns a string based on if the password is valid, if valid then "success" is returned
|
||
|
*/
|
||
12 years ago
|
public function checkPassword( $pass )
|
||
12 years ago
|
{
|
||
|
if ( isset( $pass ) ){
|
||
|
if ( strlen( $pass ) > 20 ){
|
||
|
return "Password must be no more than 20 characters.";
|
||
|
}elseif ( strlen( $pass ) < 5 ){
|
||
|
return "Password must be more than 5 characters.";
|
||
12 years ago
|
}elseif ( $pass == ""){
|
||
|
return "You have to fill in a password";
|
||
12 years ago
|
}else{
|
||
|
return "success";
|
||
|
}
|
||
12 years ago
|
}
|
||
|
return "fail";
|
||
|
}
|
||
11 years ago
|
|
||
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* checks if the confirmPassword matches the original.
|
||
|
* @param $pass_result the result of the previous password check.
|
||
|
* @param $pass the original pass.
|
||
|
* @param $confirmpass the confirmation password.
|
||
12 years ago
|
* @return string Info: Verify's $_POST["Password"] is the same as $_POST["ConfirmPass"]
|
||
|
*/
|
||
12 years ago
|
private function confirmPassword($pass_result,$pass,$confirmpass)
|
||
12 years ago
|
{
|
||
12 years ago
|
if ($confirmpass==""){
|
||
12 years ago
|
return "You have to fill in the confirmation password.";
|
||
12 years ago
|
}
|
||
|
else if ( ( $pass ) != ( $confirmpass ) ){
|
||
|
return "Passwords do not match.";
|
||
12 years ago
|
}else if($pass_result != "success"){
|
||
|
return;
|
||
|
}else{
|
||
12 years ago
|
return "success";
|
||
12 years ago
|
}
|
||
|
return "fail";
|
||
|
}
|
||
11 years ago
|
|
||
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* wrapper to check if the email address is valid.
|
||
|
* @param $email the email address
|
||
|
* @return "success", else in case it isn't valid an error will be returned.
|
||
12 years ago
|
*/
|
||
12 years ago
|
public function checkEmail( $email )
|
||
12 years ago
|
{
|
||
|
if ( isset( $email ) ){
|
||
12 years ago
|
if ( !Users::validEmail( $email ) ){
|
||
|
return "Email address is not valid.";
|
||
|
}else if($email == ""){
|
||
|
return "You have to fill in an email address";
|
||
12 years ago
|
}else if ($this->checkEmailExists($email)){
|
||
|
return "Email is in use.";
|
||
|
}else{
|
||
12 years ago
|
return "success";
|
||
12 years ago
|
}
|
||
12 years ago
|
}
|
||
|
return "fail";
|
||
|
}
|
||
|
|
||
|
|
||
12 years ago
|
/**
|
||
11 years ago
|
* check if email already exists.
|
||
|
* This is the base function, it should be overwritten by the WebUsers class.
|
||
|
* @param $email the email address
|
||
|
* @return string Info: Returns true or false if the email is in the www db.
|
||
12 years ago
|
*/
|
||
|
protected function checkEmailExists($email){
|
||
|
//TODO: You should overwrite this method with your own version!
|
||
|
print('this is the base class!');
|
||
11 years ago
|
|
||
12 years ago
|
}
|
||
11 years ago
|
|
||
|
|
||
11 years ago
|
/**
|
||
|
* check if the emailaddress structure is valid.
|
||
|
* @param $email the email address
|
||
|
* @return true or false
|
||
12 years ago
|
*/
|
||
11 years ago
|
public static function validEmail( $email ){
|
||
12 years ago
|
$isValid = true;
|
||
|
$atIndex = strrpos( $email, "@" );
|
||
|
if ( is_bool( $atIndex ) && !$atIndex ){
|
||
|
$isValid = false;
|
||
|
}else{
|
||
|
$domain = substr( $email, $atIndex + 1 );
|
||
|
$local = substr( $email, 0, $atIndex );
|
||
|
$localLen = strlen( $local );
|
||
|
$domainLen = strlen( $domain );
|
||
|
if ( $localLen < 1 || $localLen > 64 ){
|
||
|
// local part length exceeded
|
||
|
$isValid = false;
|
||
|
}else if ( $domainLen < 1 || $domainLen > 255 ){
|
||
|
// domain part length exceeded
|
||
|
$isValid = false;
|
||
|
}else if ( $local[0] == '.' || $local[$localLen - 1] == '.' ){
|
||
|
// local part starts or ends with '.'
|
||
|
$isValid = false;
|
||
|
}else if ( preg_match( '/\\.\\./', $local ) ){
|
||
|
// local part has two consecutive dots
|
||
|
$isValid = false;
|
||
|
}else if ( !preg_match( '/^[A-Za-z0-9\\-\\.]+$/', $domain ) ){
|
||
|
// character not valid in domain part
|
||
|
$isValid = false;
|
||
|
}else if ( preg_match( '/\\.\\./', $domain ) ){
|
||
|
// domain part has two consecutive dots
|
||
|
$isValid = false;
|
||
|
}else if ( !preg_match( '/^(\\\\.|[A-Za-z0-9!#%&`_=\\/$\'*+?^{}|~.-])+$/', str_replace( "\\\\", "", $local ) ) ){
|
||
|
// character not valid in local part unless
|
||
|
// local part is quoted
|
||
|
if ( !preg_match( '/^"(\\\\"|[^"])+"$/', str_replace( "\\\\", "", $local ) ) ){
|
||
|
$isValid = false;
|
||
12 years ago
|
}
|
||
12 years ago
|
}
|
||
|
if ( $isValid && !( checkdnsrr( $domain, "MX" ) || checkdnsrr( $domain, "A" ) ) ){
|
||
|
// domain not found in DNS
|
||
|
$isValid = false;
|
||
|
}
|
||
|
}
|
||
|
return $isValid;
|
||
|
}
|
||
12 years ago
|
|
||
12 years ago
|
|
||
|
|
||
|
/**
|
||
11 years ago
|
* generate a SALT.
|
||
11 years ago
|
* @param $length the length of the SALT which is by default 2
|
||
12 years ago
|
* @return a random salt of 2 chars
|
||
|
*/
|
||
10 years ago
|
public static function generateSALT( $length = 16 )
|
||
|
{
|
||
12 years ago
|
// start with a blank salt
|
||
|
$salt = "";
|
||
|
// define possible characters - any character in this string can be
|
||
|
// picked for use in the salt, so if you want to put vowels back in
|
||
|
// or add special characters such as exclamation marks, this is where
|
||
|
// you should do it
|
||
|
$possible = "2346789bcdfghjkmnpqrtvwxyzBCDFGHJKLMNPQRTVWXYZ";
|
||
|
// we refer to the length of $possible a few times, so let's grab it now
|
||
|
$maxlength = strlen( $possible );
|
||
|
// check for length overflow and truncate if necessary
|
||
|
if ( $length > $maxlength ){
|
||
|
$length = $maxlength;
|
||
|
}
|
||
|
// set up a counter for how many characters are in the salt so far
|
||
|
$i = 0;
|
||
|
// add random characters to $salt until $length is reached
|
||
|
while ( $i < $length ){
|
||
|
// pick a random character from the possible ones
|
||
|
$char = substr( $possible, mt_rand( 0, $maxlength - 1 ), 1 );
|
||
|
// have we already used this character in $salt?
|
||
|
if ( !strstr( $salt, $char ) ){
|
||
|
// no, so it's OK to add it onto the end of whatever we've already got...
|
||
|
$salt .= $char;
|
||
|
// ... and increase the counter by one
|
||
|
$i++;
|
||
12 years ago
|
}
|
||
12 years ago
|
}
|
||
|
// done!
|
||
10 years ago
|
if ($length > 2)
|
||
|
{
|
||
|
$salt = '$6$'.$salt;
|
||
|
}
|
||
12 years ago
|
return $salt;
|
||
12 years ago
|
}
|
||
11 years ago
|
|
||
12 years ago
|
|
||
12 years ago
|
|
||
11 years ago
|
/**
|
||
|
* creates a user in the shard.
|
||
11 years ago
|
* incase the shard is offline it will place it in the ams_querycache. You have to create a user first in the CMS/WWW and use the id for this function.
|
||
11 years ago
|
* @param $values with name,pass and mail
|
||
11 years ago
|
* @param $user_id the extern id of the user (the id given by the www/CMS)
|
||
12 years ago
|
* @return ok if it's get correctly added to the shard, else return lib offline and put in libDB, if libDB is also offline return liboffline.
|
||
|
*/
|
||
11 years ago
|
public static function createUser($values, $user_id) {
|
||
|
ticket_user::createTicketUser($user_id, 1);
|
||
12 years ago
|
try {
|
||
|
//make connection with and put into shard db
|
||
11 years ago
|
$values["UId"] = $user_id;
|
||
12 years ago
|
$dbs = new DBLayer("shard");
|
||
11 years ago
|
$dbs->insert("user", $values);
|
||
11 years ago
|
/*
|
||
11 years ago
|
$dbr = new DBLayer("ring");
|
||
11 years ago
|
$valuesRing['user_id'] =$user_id;
|
||
|
$valuesRing['user_name'] = $values['Login'];
|
||
|
$valuesRing['user_type'] = 'ut_pioneer';
|
||
11 years ago
|
$dbr->insert("ring_users", $valuesRing);
|
||
|
*/
|
||
12 years ago
|
return "ok";
|
||
|
}
|
||
|
catch (PDOException $e) {
|
||
|
//oh noooz, the shard is offline! Put in query queue at ams_lib db!
|
||
12 years ago
|
try {
|
||
11 years ago
|
$dbl = new DBLayer("lib");
|
||
11 years ago
|
$dbl->insert("ams_querycache", array("type" => "createUser",
|
||
11 years ago
|
"query" => json_encode(array($values["Login"], $values["Password"], $values["Email"])), "db" => "shard"));
|
||
12 years ago
|
return "shardoffline";
|
||
11 years ago
|
} catch (PDOException $e) {
|
||
12 years ago
|
print_r($e);
|
||
|
return "liboffline";
|
||
12 years ago
|
}
|
||
11 years ago
|
}
|
||
12 years ago
|
}
|
||
11 years ago
|
|
||
11 years ago
|
/**
|
||
|
* creates permissions in the shard db for a user.
|
||
|
* incase the shard is offline it will place it in the ams_querycache.
|
||
|
* @param $pvalues with username
|
||
|
*/
|
||
12 years ago
|
public static function createPermissions($pvalues) {
|
||
11 years ago
|
|
||
12 years ago
|
try {
|
||
9 years ago
|
// bind to the shard database (guess so :p)
|
||
12 years ago
|
$dbs = new DBLayer("shard");
|
||
9 years ago
|
|
||
|
// retrieve the user UId
|
||
|
$values = array('username' => $pvalues[0]);
|
||
|
$statement = $dbs->selectWithParameter("UId", "user", $values, "Login= :username");
|
||
|
$result = $statement->fetchAll();
|
||
10 years ago
|
$UId = $result['0']['UId'];
|
||
|
|
||
9 years ago
|
// retrieve the default access privileges (don't understand what exactly is done)
|
||
|
$dbl = new DBLayer("lib");
|
||
|
$statement = $dbl->execute("SELECT Value FROM `settings` WHERE `Setting` = :setting", Array('setting' => 'Domain_Auto_Add'));
|
||
|
//$statement = $dbl->execute("SELECT * FROM `settings` WHERE `Setting` = :setting", Array('setting' => 'Domain_Auto_Add'));
|
||
|
$json = $statement->fetch();
|
||
|
$accessPriv = $json['Value'];
|
||
|
//$accessPriv = json_decode($json['Value'],true);
|
||
|
|
||
|
// get all shardIds and domain_ids
|
||
|
$statement = $dbs -> executeWithoutParams( "SELECT ShardId, domain_id FROM shard" );
|
||
|
$shardIds = $statement -> fetchAll();
|
||
10 years ago
|
|
||
9 years ago
|
foreach($shardIds as $shardId) { // add default access privileges to the user for each shard
|
||
|
$ins_values = array('UId' => $UId, 'DomainId' => $shardId['domain_id'], 'ShardId' => $shardId['ShardId'], 'AccessPrivilege' => $accessPriv);
|
||
|
$dbs->insert("permission", $ins_values);
|
||
|
}
|
||
12 years ago
|
}
|
||
|
catch (PDOException $e) {
|
||
|
//oh noooz, the shard is offline! Put it in query queue at ams_lib db!
|
||
|
$dbl = new DBLayer("lib");
|
||
11 years ago
|
$dbl->insert("ams_querycache", array("type" => "createPermissions",
|
||
11 years ago
|
"query" => json_encode(array($pvalues[0])), "db" => "shard"));
|
||
|
}
|
||
12 years ago
|
return true;
|
||
|
}
|
||
11 years ago
|
|
||
|
|
||
11 years ago
|
/**
|
||
|
* check if username and password matches.
|
||
|
* This is the base function, it should be overwritten by the WebUsers class.
|
||
|
* @param $user the inserted username
|
||
|
* @param $pass the inserted password
|
||
|
*/
|
||
11 years ago
|
protected static function checkLoginMatch($user,$pass){
|
||
12 years ago
|
print('This is the base class!');
|
||
|
}
|
||
11 years ago
|
|
||
11 years ago
|
/**
|
||
|
* check if the changing of a password is valid.
|
||
|
* a mod/admin doesn't has to fill in the previous password when he wants to change the password, however for changing his own password he has to fill it in.
|
||
|
* @param $values an array containing the CurrentPass, ConfirmNewPass, NewPass and adminChangesOthers
|
||
|
* @return if it is valid "success will be returned, else an array with errors will be returned.
|
||
|
*/
|
||
12 years ago
|
public function check_change_password($values){
|
||
12 years ago
|
//if admin isn't changing others
|
||
|
if(!$values['adminChangesOther']){
|
||
|
if ( isset( $values["user"] ) and isset( $values["CurrentPass"] ) and isset( $values["ConfirmNewPass"] ) and isset( $values["NewPass"] ) ){
|
||
|
$match = $this->checkLoginMatch($values["user"],$values["CurrentPass"]);
|
||
|
$newpass = $this->checkPassword($values["NewPass"]);
|
||
|
$confpass = $this->confirmPassword($newpass,$values["NewPass"],$values["ConfirmNewPass"]);
|
||
|
}else{
|
||
|
$match = "";
|
||
|
$newpass = "";
|
||
|
$confpass = "";
|
||
|
}
|
||
12 years ago
|
}else{
|
||
12 years ago
|
//if admin is indeed changing someone!
|
||
|
if ( isset( $values["user"] ) and isset( $values["ConfirmNewPass"] ) and isset( $values["NewPass"] ) ){
|
||
|
$newpass = $this->checkPassword($values["NewPass"]);
|
||
|
$confpass = $this->confirmPassword($newpass,$values["NewPass"],$values["ConfirmNewPass"]);
|
||
|
}else{
|
||
|
$newpass = "";
|
||
|
$confpass = "";
|
||
|
}
|
||
12 years ago
|
}
|
||
12 years ago
|
if ( !$values['adminChangesOther'] and ( $match != "fail" ) and ( $newpass == "success" ) and ( $confpass == "success" ) ){
|
||
|
return "success";
|
||
|
}else if($values['adminChangesOther'] and ( $newpass == "success" ) and ( $confpass == "success" ) ){
|
||
12 years ago
|
return "success";
|
||
|
}else{
|
||
|
$pageElements = array(
|
||
|
'newpass_error_message' => $newpass,
|
||
|
'confirmnewpass_error_message' => $confpass
|
||
|
);
|
||
12 years ago
|
if(!$values['adminChangesOther']){
|
||
|
$pageElements['match_error_message'] = $match;
|
||
|
if ( $match != "fail" ){
|
||
|
$pageElements['MATCH_ERROR'] = 'FALSE';
|
||
|
}else{
|
||
|
$pageElements['MATCH_ERROR'] = 'TRUE';
|
||
|
}
|
||
12 years ago
|
}
|
||
|
if ( $newpass != "success" ){
|
||
|
$pageElements['NEWPASSWORD_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['NEWPASSWORD_ERROR'] = 'FALSE';
|
||
|
}
|
||
|
if ( $confpass != "success" ){
|
||
|
$pageElements['CNEWPASSWORD_ERROR'] = 'TRUE';
|
||
|
}else{
|
||
|
$pageElements['CNEWPASSWORD_ERROR'] = 'FALSE';
|
||
|
}
|
||
|
return $pageElements;
|
||
|
}
|
||
|
}
|
||
11 years ago
|
|
||
11 years ago
|
/**
|
||
|
* sets the shards password.
|
||
|
* in case the shard is offline, the entry will be stored in the ams_querycache.
|
||
|
* @param $user the usersname of the account of which we want to change the password.
|
||
|
* @param $pass the new password.
|
||
|
* @return ok if it worked, if the lib or shard is offline it will return liboffline or shardoffline.
|
||
|
*/
|
||
11 years ago
|
protected static function setAmsPassword($user, $pass){
|
||
11 years ago
|
|
||
11 years ago
|
$values = Array('Password' => $pass);
|
||
11 years ago
|
|
||
12 years ago
|
try {
|
||
|
//make connection with and put into shard db
|
||
12 years ago
|
$dbs = new DBLayer("shard");
|
||
10 years ago
|
$dbs->update("user", $values, "Login = '$user'");
|
||
12 years ago
|
return "ok";
|
||
|
}
|
||
|
catch (PDOException $e) {
|
||
|
//oh noooz, the shard is offline! Put in query queue at ams_lib db!
|
||
12 years ago
|
try {
|
||
12 years ago
|
$dbl = new DBLayer("lib");
|
||
11 years ago
|
$dbl->insert("ams_querycache", array("type" => "change_pass",
|
||
11 years ago
|
"query" => json_encode(array($user,$pass)), "db" => "shard"));
|
||
12 years ago
|
return "shardoffline";
|
||
|
}catch (PDOException $e) {
|
||
|
return "liboffline";
|
||
|
}
|
||
11 years ago
|
}
|
||
12 years ago
|
}
|
||
11 years ago
|
|
||
11 years ago
|
/**
|
||
|
* sets the shards email.
|
||
|
* in case the shard is offline, the entry will be stored in the ams_querycache.
|
||
|
* @param $user the usersname of the account of which we want to change the emailaddress.
|
||
|
* @param $mail the new email address
|
||
|
* @return ok if it worked, if the lib or shard is offline it will return liboffline or shardoffline.
|
||
|
*/
|
||
11 years ago
|
protected static function setAmsEmail($user, $mail){
|
||
11 years ago
|
|
||
11 years ago
|
$values = Array('Email' => $mail);
|
||
11 years ago
|
|
||
12 years ago
|
try {
|
||
|
//make connection with and put into shard db
|
||
12 years ago
|
$dbs = new DBLayer("shard");
|
||
11 years ago
|
$dbs->update("user", $values, "Login = '$user'");
|
||
12 years ago
|
return "ok";
|
||
|
}
|
||
|
catch (PDOException $e) {
|
||
|
//oh noooz, the shard is offline! Put in query queue at ams_lib db!
|
||
|
try {
|
||
11 years ago
|
error_log($e);
|
||
12 years ago
|
$dbl = new DBLayer("lib");
|
||
11 years ago
|
$dbl->insert("ams_querycache", array("type" => "change_mail",
|
||
11 years ago
|
"query" => json_encode(array($user,$mail)), "db" => "shard"));
|
||
12 years ago
|
return "shardoffline";
|
||
|
}catch (PDOException $e) {
|
||
|
return "liboffline";
|
||
12 years ago
|
}
|
||
11 years ago
|
}
|
||
12 years ago
|
}
|
||
12 years ago
|
}
|