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


PHP UserMapper::getUserByUsername方法代碼示例

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


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

示例1: passwordReset

 public function passwordReset($request, $db)
 {
     $user_mapper = new UserMapper($db, $request);
     $username = filter_var($request->getParameter("username"), FILTER_SANITIZE_STRING);
     if (empty($username)) {
         throw new Exception("A username must be supplied", 400);
     } else {
         $list = $user_mapper->getUserByUsername($username);
         if (is_array($list['users']) && count($list['users'])) {
             $user = $list['users'][0];
             // neither user_id nor email are in the user resource returned by the mapper
             $user_id = $user_mapper->getUserIdFromUsername($username);
             $email = $user_mapper->getEmailByUserId($user_id);
             $recipients = array($email);
             // we need a token to send so we know it is a valid reset
             $token = $user_mapper->generatePasswordResetTokenForUserId($user_id);
             if (!$token) {
                 throw new Exception("Unable to generate a reset token", 400);
             }
             $emailService = new UserPasswordResetEmailService($this->config, $recipients, $user, $token);
             $emailService->sendEmail();
             header("Content-Length: 0", NULL, 202);
             exit;
         }
         throw new Exception("Can't find that user", 400);
     }
 }
開發者ID:e3betht,項目名稱:joindin-api,代碼行數:27,代碼來源:EmailsController.php

示例2: postAction

 public function postAction($request, $db)
 {
     // check element 3, there's no user associated with the not-logged-in collections
     if (isset($request->url_elements[3])) {
         switch ($request->url_elements[3]) {
             case 'verifications':
                 $user_mapper = new UserMapper($db, $request);
                 $token = filter_var($request->getParameter("token"), FILTER_SANITIZE_STRING);
                 if (empty($token)) {
                     throw new Exception("Verification token must be supplied", 400);
                 } else {
                     $success = $user_mapper->verifyUser($token);
                     if ($success) {
                         header("Content-Length: 0", null, 204);
                         exit;
                         // no more content
                     } else {
                         throw new Exception("Verification failed", 400);
                     }
                 }
                 break;
             default:
                 throw new InvalidArgumentException('Unknown Subrequest', 404);
                 break;
         }
     } else {
         $user = array();
         $errors = array();
         $user_mapper = new UserMapper($db, $request);
         // Required Fields
         $user['username'] = filter_var(trim($request->getParameter("username")), FILTER_SANITIZE_STRING);
         if (empty($user['username'])) {
             $errors[] = "'username' is a required field";
         } else {
             // does anyone else have this username?
             $existing_user = $user_mapper->getUserByUsername($user['username']);
             if ($existing_user['users']) {
                 $errors[] = "That username is already in use. Choose another";
             }
         }
         $user['full_name'] = filter_var(trim($request->getParameter("full_name")), FILTER_SANITIZE_STRING);
         if (empty($user['full_name'])) {
             $errors[] = "'full_name' is a required field";
         }
         $user['email'] = filter_var(trim($request->getParameter("email")), FILTER_VALIDATE_EMAIL);
         if (empty($user['email'])) {
             $errors[] = "A valid entry for 'email' is required";
         } else {
             // does anyone else have this email?
             $existing_user = $user_mapper->getUserByEmail($user['email']);
             if ($existing_user['users']) {
                 $errors[] = "That email is already associated with another account";
             }
         }
         $password = $request->getParameter("password");
         if (empty($password)) {
             $errors[] = "'password' is a required field";
         } else {
             // check it's sane
             $validity = $user_mapper->checkPasswordValidity($password);
             if (true === $validity) {
                 // OK good, go ahead
                 $user['password'] = $password;
             } else {
                 // the password wasn't acceptable, tell the user why
                 $errors = array_merge($errors, $validity);
             }
         }
         // Optional Fields
         $user['twitter_username'] = filter_var(trim($request->getParameter("twitter_username")), FILTER_SANITIZE_STRING);
         // How does it look?  With no errors, we can proceed
         if ($errors) {
             throw new Exception(implode(". ", $errors), 400);
         } else {
             $user_id = $user_mapper->createUser($user);
             header("Location: " . $request->base . $request->path_info . '/' . $user_id, null, 201);
             // autoverify for test platforms
             if (isset($this->config['features']['allow_auto_verify_users']) && $this->config['features']['allow_auto_verify_users']) {
                 if ($request->getParameter("auto_verify_user") == "true") {
                     // the test suite sends this extra field, if we got
                     // this far then this platform supports this
                     $user_mapper->verifyThisTestUser($user_id);
                 }
             }
             // Generate a verification token and email it to the user
             $token = $user_mapper->generateEmailVerificationTokenForUserId($user_id);
             $recipients = array($user['email']);
             $emailService = new UserRegistrationEmailService($this->config, $recipients, $token);
             $emailService->sendEmail();
             exit;
         }
     }
 }
開發者ID:asgrim,項目名稱:joindin-api,代碼行數:93,代碼來源:UsersController.php


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