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


PHP wfSetupSession函數代碼示例

本文整理匯總了PHP中wfSetupSession函數的典型用法代碼示例。如果您正苦於以下問題:PHP wfSetupSession函數的具體用法?PHP wfSetupSession怎麽用?PHP wfSetupSession使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


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

示例1: __construct

 protected function __construct()
 {
     // Make sure the session is started
     if (session_id() === '') {
         wfSetupSession();
     }
 }
開發者ID:Grprashanthkumar,項目名稱:ColfusionWeb,代碼行數:7,代碼來源:CaptchaStore.php

示例2: startExperiment

 /**
  * Initialize the experiment and set all required tracking things
  *
  * @param string $experimentName
  * @param array $experimentConfig
  */
 private static function startExperiment($experimentName, array $experimentConfig)
 {
     wfDebug(sprintf("%s[%s] using %s class with %s params\n", __METHOD__, $experimentName, $experimentConfig['handler'], json_encode($experimentConfig['params'])));
     new $experimentConfig['handler']($experimentConfig['params'] ?: []);
     // mark a transaction with an experiment name
     \Transaction::getInstance()->set(\Transaction::PARAM_AB_PERFORMANCE_TEST, $experimentName);
     // set a global JS variable with an experiment name
     global $wgHooks;
     $wgHooks['WikiaSkinTopScripts'][] = function (array &$vars, &$scripts) use($experimentName) {
         $vars['wgABPerformanceTest'] = $experimentName;
         return true;
     };
     /*
      * Start the session to bypass CDN cache
      *
      * We don't want to polute the CDN cache with the A/B performance testing tracking data.
      * As the test are run for only a small subset of the traffic, start the session for client
      * that are in the test groups to bypass the CDN cache.
      */
     if (session_id() == '') {
         wfSetupSession();
         wfDebug(__METHOD__ . " - session started\n");
         // log started sessions
         global $wgUser;
         WikiaLogger::instance()->info(__METHOD__, ['experiment' => $experimentName, 'session_id' => session_id(), 'is_anon' => $wgUser->isAnon()]);
     }
 }
開發者ID:Tjorriemorrie,項目名稱:app,代碼行數:33,代碼來源:Hooks.class.php

示例3: execute

 function execute($par)
 {
     global $wgOut, $wgRequest, $wgUser, $wgFBAppId, $wgFBAppSecret, $wgLanguageCode, $wgContLang, $IP;
     require_once "{$IP}/extensions/wikihow/common/facebook-platform/facebook-php-sdk-771862b/src/facebook.php";
     wfLoadExtensionMessages('FBLogin');
     if (session_id() == '') {
         wfSetupSession();
     }
     $this->returnto = $wgLanguageCode == 'en' ? wfMsg('fbc_returnto') : "/" . $wgContLang->getNSText(NS_PROJECT) . ":" . wfMsg('communityportal');
     //$this->returnto = $_COOKIE['wiki_returnto'] ? $_COOKIE['wiki_returnto'] : "/Special:CommunityDashboard";
     $this->userid = $_COOKIE['wiki_fbuser'];
     $userid = $this->userid;
     if (!$userid) {
         $wgOut->addHTML("An error occurred.<!--" . print_r($_COOKIE, true) . "-->");
         return;
     }
     $this->setWgUser();
     $this->facebook = new Facebook(array('appId' => $wgFBAppId, 'secret' => $wgFBAppSecret));
     $accessToken = $_COOKIE['wiki_fbtoken'];
     $this->facebook->setAccessToken($accessToken);
     $result = $this->facebook->api('/me');
     if (!$wgRequest->wasPosted()) {
         // If they still have the FB_* name, show them the registration form with a proposed name
         if (strpos($wgUser->getName(), "FB_") !== false) {
             $this->printRegForm($result);
         } else {
             $this->updateAvatar($result);
             // All logged in. Return them to wherever they're supposed to go
             $this->setCookies();
             $wgOut->redirect($this->returnto);
         }
     } else {
         $this->processRegForm($result);
     }
 }
開發者ID:biribogos,項目名稱:wikihow-src,代碼行數:35,代碼來源:FBLogin.body.php

示例4: startSession

 static function startSession()
 {
     if (session_id() == '') {
         wfSetupSession();
     }
     self::clearCollection();
 }
開發者ID:realsoc,項目名稱:mediawiki-extensions,代碼行數:7,代碼來源:Collection.session.php

示例5: execute

 function execute($par)
 {
     global $wgRequest, $wgUser, $wgLanguageCode, $wgContLang, $wgOut;
     wfLoadExtensionMessages('GPlusLogin');
     if (session_id() == '') {
         wfSetupSession();
     }
     //disconnecting?
     if ($wgRequest->getVal('disconnect')) {
         self::userDisco();
         return;
     }
     //returning to the community dashboard
     $this->returnto = $wgLanguageCode == 'en' ? wfMsg('gpl_returnto') : "/" . $wgContLang->getNSText(NS_PROJECT) . ":" . wfMsg('communityportal');
     //set that user (if we can)
     $this->userid = $wgRequest->getVal('gplus_id') ? $wgRequest->getVal('gplus_id') : $wgRequest->getVal('user_id');
     if ($this->userid) {
         $this->setWgUser();
     }
     if ($wgRequest->wasPosted() && $wgRequest->getVal('gplus_id')) {
         self::processForm();
         return;
     }
     //get user's G+ info
     $gp_id = $wgRequest->getVal('user_id');
     $gp_name = $wgRequest->getVal('user_name');
     $gp_email = $wgRequest->getVal('user_email');
     $gp_avatar = $wgRequest->getVal('user_avatar');
     self::showForm($gp_id, $gp_name, $gp_email, $gp_avatar);
 }
開發者ID:biribogos,項目名稱:wikihow-src,代碼行數:30,代碼來源:GPlusLogin.body.php

示例6: attemptAddUser

 /**
  * @param $user User
  * @param $mungedUsername String
  * @return bool
  */
 public static function attemptAddUser($user, $mungedUsername)
 {
     /**
      * @var $wgAuth LdapAuthenticationPlugin
      */
     global $wgAuth;
     if (!$wgAuth->autoCreate()) {
         $wgAuth->printDebug("Cannot automatically create accounts.", NONSENSITIVE);
         return false;
     }
     $wgAuth->printDebug("User does not exist in local database; creating.", NONSENSITIVE);
     // Checks passed, create the user
     $user->loadDefaults($mungedUsername);
     $status = $user->addToDatabase();
     if ($status !== null && !$status->isOK()) {
         $wgAuth->printDebug("Creation failed: " . $status->getWikiText(), NONSENSITIVE);
         return false;
     }
     $wgAuth->initUser($user, true);
     $user->setCookies();
     wfSetupSession();
     # Update user count
     $ssUpdate = new SiteStatsUpdate(0, 0, 0, 0, 1);
     $ssUpdate->doUpdate();
     # Notify hooks (e.g. Newuserlog)
     wfRunHooks('AuthPluginAutoCreate', array($user));
     return true;
 }
開發者ID:nahoj,項目名稱:mediawiki_ynh,代碼行數:33,代碼來源:LdapAutoAuthentication.php

示例7: setUp

 /**
  * Fixture -- run before every test
  */
 protected function setUp()
 {
     parent::setUp();
     $this->setMwGlobals(array('wgEnableUploads' => true, 'wgEnableAPI' => true));
     wfSetupSession();
     $this->clearFakeUploads();
 }
開發者ID:Habatchii,項目名稱:wikibase-for-mediawiki,代碼行數:10,代碼來源:ApiTestCaseUpload.php

示例8: newFromToken

 /**
  * Creates a MediaWiki User object based on the token given in the HTTP request.
  *
  * @param \WebRequest $request the HTTP request data as an object
  *
  * @return \User on successful authentication
  */
 public static function newFromToken(\WebRequest $request)
 {
     // Extract access token from HTTP request data.
     $token = self::getAccessToken($request);
     // Authenticate with the token, if present.
     if ($token) {
         global $wgHeliosBaseUri, $wgHeliosClientId, $wgHeliosClientSecret;
         $heliosClient = new Client($wgHeliosBaseUri, $wgHeliosClientId, $wgHeliosClientSecret);
         // start the session if there's none so far
         // the code is borrowed from SpecialUserlogin
         // @see PLATFORM-1261
         if (session_id() == '') {
             wfSetupSession();
             WikiaLogger::instance()->debug(__METHOD__ . '::startSession');
         }
         try {
             $tokenInfo = $heliosClient->info($token);
             if (!empty($tokenInfo->user_id)) {
                 $user = \User::newFromId($tokenInfo->user_id);
                 // dont return the user object if it's disabled
                 // @see SERVICES-459
                 if ((bool) $user->getGlobalFlag('disabled')) {
                     self::clearAccessTokenCookie();
                     return null;
                 }
                 // return a MediaWiki's User object
                 return $user;
             }
         } catch (ClientException $e) {
             WikiaLogger::instance()->error(__METHOD__, ['exception' => $e]);
         }
     }
     return null;
 }
開發者ID:yusufchang,項目名稱:app,代碼行數:41,代碼來源:User.class.php

示例9: execute

 /**
  * Executes the log-in attempt using the parameters passed. If
  * the log-in succeeeds, it attaches a cookie to the session
  * and outputs the user id, username, and session token. If a
  * log-in fails, as the result of a bad password, a nonexistant
  * user, or any other reason, the host is cached with an expiry
  * and no log-in attempts will be accepted until that expiry
  * is reached. The expiry is $this->mLoginThrottle.
  *
  * @access public
  */
 public function execute()
 {
     $name = $password = $domain = null;
     extract($this->extractRequestParams());
     $result = array();
     // Make sure noone is trying to guess the password brut-force
     $nextLoginIn = $this->getNextLoginTimeout();
     if ($nextLoginIn > 0) {
         $result['result'] = 'NeedToWait';
         $result['details'] = "Please wait {$nextLoginIn} seconds before next log-in attempt";
         $result['wait'] = $nextLoginIn;
         $this->getResult()->addValue(null, 'login', $result);
         return;
     }
     $params = new FauxRequest(array('wpName' => $name, 'wpPassword' => $password, 'wpDomain' => $domain, 'wpRemember' => ''));
     // Init session if necessary
     if (session_id() == '') {
         wfSetupSession();
     }
     $loginForm = new LoginForm($params);
     switch ($loginForm->authenticateUserData()) {
         case LoginForm::SUCCESS:
             global $wgUser, $wgCookiePrefix;
             $wgUser->setOption('rememberpassword', 1);
             $wgUser->setCookies();
             $result['result'] = 'Success';
             $result['lguserid'] = $_SESSION['wsUserID'];
             $result['lgusername'] = $_SESSION['wsUserName'];
             $result['lgtoken'] = $_SESSION['wsToken'];
             $result['cookieprefix'] = $wgCookiePrefix;
             $result['sessionid'] = session_id();
             break;
         case LoginForm::NO_NAME:
             $result['result'] = 'NoName';
             break;
         case LoginForm::ILLEGAL:
             $result['result'] = 'Illegal';
             break;
         case LoginForm::WRONG_PLUGIN_PASS:
             $result['result'] = 'WrongPluginPass';
             break;
         case LoginForm::NOT_EXISTS:
             $result['result'] = 'NotExists';
             break;
         case LoginForm::WRONG_PASS:
             $result['result'] = 'WrongPass';
             break;
         case LoginForm::EMPTY_PASS:
             $result['result'] = 'EmptyPass';
             break;
         default:
             ApiBase::dieDebug(__METHOD__, 'Unhandled case value');
     }
     if ($result['result'] != 'Success') {
         $result['wait'] = $this->cacheBadLogin();
         $result['details'] = "Please wait " . self::THROTTLE_TIME . " seconds before next log-in attempt";
     }
     // if we were allowed to try to login, memcache is fine
     $this->getResult()->addValue(null, 'login', $result);
 }
開發者ID:ErdemA,項目名稱:wikihow,代碼行數:71,代碼來源:ApiLogin.php

示例10: __construct

 function __construct()
 {
     SpecialPage::__construct('PromoterAds');
     // Make sure we have a session
     wfSetupSession();
     // Load things that may have been serialized into the session
     $this->adFilterString = $this->getPRSessionVar('adFilterString', '');
 }
開發者ID:kolzchut,項目名稱:mediawiki-extensions-Promoter,代碼行數:8,代碼來源:SpecialPromoterAds.php

示例11: show

 public function show()
 {
     if (session_id() === '') {
         // Send a cookie so anons get talk message notifications
         wfSetupSession();
     }
     parent::show();
 }
開發者ID:MediaWiki-stable,項目名稱:1.26.1,代碼行數:8,代碼來源:SubmitAction.php

示例12: execute

 /**
  * Executes the log-in attempt using the parameters passed. If
  * the log-in succeeeds, it attaches a cookie to the session
  * and outputs the user id, username, and session token. If a
  * log-in fails, as the result of a bad password, a nonexistent
  * user, or any other reason, the host is cached with an expiry
  * and no log-in attempts will be accepted until that expiry
  * is reached. The expiry is $this->mLoginThrottle.
  *
  * @access public
  */
 public function execute()
 {
     $params = $this->extractRequestParams();
     $result = array();
     $req = new FauxRequest(array('wpName' => $params['name'], 'wpPassword' => $params['password'], 'wpDomain' => $params['domain'], 'wpRemember' => ''));
     // Init session if necessary
     if (session_id() == '') {
         wfSetupSession();
     }
     $loginForm = new LoginForm($req);
     switch ($authRes = $loginForm->authenticateUserData()) {
         case LoginForm::SUCCESS:
             global $wgUser, $wgCookiePrefix;
             $wgUser->setOption('rememberpassword', 1);
             $wgUser->setCookies();
             // Run hooks. FIXME: split back and frontend from this hook.
             // FIXME: This hook should be placed in the backend
             $injected_html = '';
             wfRunHooks('UserLoginComplete', array(&$wgUser, &$injected_html));
             $result['result'] = 'Success';
             $result['lguserid'] = intval($wgUser->getId());
             $result['lgusername'] = $wgUser->getName();
             $result['lgtoken'] = $wgUser->getToken();
             $result['cookieprefix'] = $wgCookiePrefix;
             $result['sessionid'] = session_id();
             break;
         case LoginForm::NO_NAME:
             $result['result'] = 'NoName';
             break;
         case LoginForm::ILLEGAL:
             $result['result'] = 'Illegal';
             break;
         case LoginForm::WRONG_PLUGIN_PASS:
             $result['result'] = 'WrongPluginPass';
             break;
         case LoginForm::NOT_EXISTS:
             $result['result'] = 'NotExists';
             break;
         case LoginForm::WRONG_PASS:
             $result['result'] = 'WrongPass';
             break;
         case LoginForm::EMPTY_PASS:
             $result['result'] = 'EmptyPass';
             break;
         case LoginForm::CREATE_BLOCKED:
             $result['result'] = 'CreateBlocked';
             $result['details'] = 'Your IP address is blocked from account creation';
             break;
         case LoginForm::THROTTLED:
             global $wgPasswordAttemptThrottle;
             $result['result'] = 'Throttled';
             $result['wait'] = intval($wgPasswordAttemptThrottle['seconds']);
             break;
         default:
             ApiBase::dieDebug(__METHOD__, "Unhandled case value: {$authRes}");
     }
     $this->getResult()->addValue(null, 'login', $result);
 }
開發者ID:josephdye,項目名稱:wikireader,代碼行數:69,代碼來源:ApiLogin.php

示例13: wfSpecialUserlogin

/**
 * constructor
 */
function wfSpecialUserlogin($par = '')
{
    global $wgRequest;
    if (session_id() == '') {
        wfSetupSession();
    }
    $form = new LoginForm($wgRequest, $par);
    $form->execute();
}
開發者ID:josephdye,項目名稱:wikireader,代碼行數:12,代碼來源:SpecialUserlogin.php

示例14: setUp

 /**
  * Fixture -- run before every test
  */
 public function setUp()
 {
     global $wgEnableUploads, $wgEnableAPI;
     parent::setUp();
     $wgEnableUploads = true;
     $wgEnableAPI = true;
     wfSetupSession();
     $this->clearFakeUploads();
 }
開發者ID:Tjorriemorrie,項目名稱:app,代碼行數:12,代碼來源:ApiTestCaseUpload.php

示例15: wfSpecialUserlogin

/**
 * constructor
 */
function wfSpecialUserlogin($par = '')
{
    global $wgRequest, $wgHooks;
    if (session_id() == '') {
        wfSetupSession();
    }
    $form = new LoginForm($wgRequest, $par);
    $form->execute();
    $wgHooks['BeforeTabsLine'][] = array('LoginForm::topContent', $form);
}
開發者ID:ErdemA,項目名稱:wikihow,代碼行數:13,代碼來源:SpecialUserlogin.php


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