當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Invitation::setConfig方法代碼示例

本文整理匯總了PHP中Invitation::setConfig方法的典型用法代碼示例。如果您正苦於以下問題:PHP Invitation::setConfig方法的具體用法?PHP Invitation::setConfig怎麽用?PHP Invitation::setConfig使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Invitation的用法示例。


在下文中一共展示了Invitation::setConfig方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: register

 /**
  * Register a new user in the system
  * @param username string Username
  * @param password1 string Password
  * @param password2 string Password verification
  * @param pin int 4 digit PIN code
  * @param email1 string Email address
  * @param email2 string Email confirmation
  * @return bool
  **/
 public function register($username, $password1, $password2, $pin, $email1 = '', $email2 = '', $tac = '', $strToken = '')
 {
     $this->debug->append("STA " . __METHOD__, 4);
     if ($tac != 1) {
         $this->setErrorMessage('You need to accept our <a href="' . $_SERVER['SCRIPT_NAME'] . '?page=tac" target="_blank">Terms and Conditions</a>');
         return false;
     }
     if (strlen($username) > 40) {
         $this->setErrorMessage('Username exceeding character limit');
         return false;
     }
     if (preg_match('/[^a-z_\\-0-9]/i', $username)) {
         $this->setErrorMessage('Username may only contain alphanumeric characters');
         return false;
     }
     if ($this->getEmail($email1)) {
         $this->setErrorMessage('This e-mail address is already taken');
         return false;
     }
     if (strlen($password1) < 8) {
         $this->setErrorMessage('Password is too short, minimum of 8 characters required');
         return false;
     }
     if ($password1 !== $password2) {
         $this->setErrorMessage('Password do not match');
         return false;
     }
     if (empty($email1) || !filter_var($email1, FILTER_VALIDATE_EMAIL)) {
         $this->setErrorMessage('Invalid e-mail address');
         return false;
     }
     if ($email1 !== $email2) {
         $this->setErrorMessage('E-mail do not match');
         return false;
     }
     if (!is_numeric($pin) || strlen($pin) > 4 || strlen($pin) < 4) {
         $this->setErrorMessage('Invalid PIN');
         return false;
     }
     if (isset($strToken) && !empty($strToken)) {
         if (!($aToken = $this->token->getToken($strToken, 'invitation'))) {
             $this->setErrorMessage('Unable to find token');
             return false;
         }
         // Circle dependency, so we create our own object here
         $invitation = new Invitation();
         $invitation->setMysql($this->mysqli);
         $invitation->setDebug($this->debug);
         $invitation->setLog($this->log);
         $invitation->setUser($this);
         $invitation->setConfig($this->config);
         if (!$invitation->setActivated($aToken['id'])) {
             $this->setErrorMessage('Unable to activate your invitation');
             return false;
         }
         if (!$this->token->deleteToken($strToken)) {
             $this->setErrorMessage('Unable to remove used token');
             $this->log->log("warn", "{$username} tried to register but failed to delete the invitation token");
             return false;
         }
     }
     if ($this->mysqli->query("SELECT id FROM {$this->table} LIMIT 1")->num_rows > 0) {
         !$this->setting->getValue('accounts_confirm_email_disabled') ? $is_locked = 1 : ($is_locked = 0);
         $is_admin = 0;
         $stmt = $this->mysqli->prepare("\n        INSERT INTO {$this->table} (username, pass, email, signup_timestamp, pin, api_key, is_locked)\n        VALUES (?, ?, ?, ?, ?, ?, ?)\n        ");
     } else {
         $is_locked = 0;
         $is_admin = 1;
         $stmt = $this->mysqli->prepare("\n        INSERT INTO {$this->table} (username, pass, email, signup_timestamp, pin, api_key, is_admin, is_locked)\n        VALUES (?, ?, ?, ?, ?, ?, 1, ?)\n        ");
     }
     // Create hashed strings using original string and salt
     $password_hash = $this->getHash($password1);
     $pin_hash = $this->getHash($pin);
     $apikey_hash = $this->getHash($username);
     $username_clean = strip_tags($username);
     $signup_time = time();
     if ($this->checkStmt($stmt) && $stmt->bind_param('sssissi', $username_clean, $password_hash, $email1, $signup_time, $pin_hash, $apikey_hash, $is_locked) && $stmt->execute()) {
         if (!$this->setting->getValue('accounts_confirm_email_disabled') && $is_admin != 1) {
             if ($token = $this->token->createToken('confirm_email', $stmt->insert_id)) {
                 $aData['username'] = $username_clean;
                 $aData['token'] = $token;
                 $aData['email'] = $email1;
                 $aData['subject'] = 'E-Mail verification';
                 if (!$this->mail->sendMail('register/confirm_email', $aData)) {
                     $this->setErrorMessage('Unable to request email confirmation: ' . $this->mail->getError());
                     return false;
                 }
                 return true;
             } else {
                 $this->setErrorMessage('Failed to create confirmation token');
//.........這裏部分代碼省略.........
開發者ID:xisi,項目名稱:mpos-fusion,代碼行數:101,代碼來源:user.class.php


注:本文中的Invitation::setConfig方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。