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


PHP wfCanIPUseHTTPS函數代碼示例

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


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

示例1: execute

 /**
  * @param string|null $subPage
  */
 public function execute($subPage)
 {
     $authManager = AuthManager::singleton();
     $session = SessionManager::getGlobalSession();
     // Session data is used for various things in the authentication process, so we must make
     // sure a session cookie or some equivalent mechanism is set.
     $session->persist();
     $this->load($subPage);
     $this->setHeaders();
     $this->checkPermissions();
     // Make sure it's possible to log in
     if (!$this->isSignup() && !$session->canSetUser()) {
         throw new ErrorPageError('cannotloginnow-title', 'cannotloginnow-text', [$session->getProvider()->describe(RequestContext::getMain()->getLanguage())]);
     }
     /*
      * In the case where the user is already logged in, and was redirected to
      * the login form from a page that requires login, do not show the login
      * page. The use case scenario for this is when a user opens a large number
      * of tabs, is redirected to the login page on all of them, and then logs
      * in on one, expecting all the others to work properly.
      *
      * However, do show the form if it was visited intentionally (no 'returnto'
      * is present). People who often switch between several accounts have grown
      * accustomed to this behavior.
      *
      * Also make an exception when force=<level> is set in the URL, which means the user must
      * reauthenticate for security reasons.
      */
     if (!$this->isSignup() && !$this->mPosted && !$this->securityLevel && ($this->mReturnTo !== '' || $this->mReturnToQuery !== '') && $this->getUser()->isLoggedIn()) {
         $this->successfulAction();
     }
     // If logging in and not on HTTPS, either redirect to it or offer a link.
     global $wgSecureLogin;
     if ($this->getRequest()->getProtocol() !== 'https') {
         $title = $this->getFullTitle();
         $query = $this->getPreservedParams(false) + ['title' => null, $this->mEntryErrorType === 'error' ? 'error' : 'warning' => $this->mEntryError] + $this->getRequest()->getQueryValues();
         $url = $title->getFullURL($query, false, PROTO_HTTPS);
         if ($wgSecureLogin && !$this->mFromHTTP && wfCanIPUseHTTPS($this->getRequest()->getIP())) {
             // Avoid infinite redirect
             $url = wfAppendQuery($url, 'fromhttp=1');
             $this->getOutput()->redirect($url);
             // Since we only do this redir to change proto, always vary
             $this->getOutput()->addVaryHeader('X-Forwarded-Proto');
             return;
         } else {
             // A wiki without HTTPS login support should set $wgServer to
             // http://somehost, in which case the secure URL generated
             // above won't actually start with https://
             if (substr($url, 0, 8) === 'https://') {
                 $this->mSecureLoginUrl = $url;
             }
         }
     }
     if (!$this->isActionAllowed($this->authAction)) {
         // FIXME how do we explain this to the user? can we handle session loss better?
         // messages used: authpage-cannot-login, authpage-cannot-login-continue,
         // authpage-cannot-create, authpage-cannot-create-continue
         $this->mainLoginForm([], 'authpage-cannot-' . $this->authAction);
         return;
     }
     $status = $this->trySubmit();
     if (!$status || !$status->isGood()) {
         $this->mainLoginForm($this->authRequests, $status ? $status->getMessage() : '', 'error');
         return;
     }
     /** @var AuthenticationResponse $response */
     $response = $status->getValue();
     $returnToUrl = $this->getPageTitle('return')->getFullURL($this->getPreservedParams(true), false, PROTO_HTTPS);
     switch ($response->status) {
         case AuthenticationResponse::PASS:
             $this->logAuthResult(true);
             $this->proxyAccountCreation = $this->isSignup() && !$this->getUser()->isAnon();
             $this->targetUser = User::newFromName($response->username);
             if (!$this->proxyAccountCreation && $response->loginRequest && $authManager->canAuthenticateNow()) {
                 // successful registration; log the user in instantly
                 $response2 = $authManager->beginAuthentication([$response->loginRequest], $returnToUrl);
                 if ($response2->status !== AuthenticationResponse::PASS) {
                     LoggerFactory::getInstance('login')->error('Could not log in after account creation');
                     $this->successfulAction(true, Status::newFatal('createacct-loginerror'));
                     break;
                 }
             }
             if (!$this->proxyAccountCreation) {
                 // Ensure that the context user is the same as the session user.
                 $this->setSessionUserForCurrentRequest();
             }
             $this->successfulAction(true);
             break;
         case AuthenticationResponse::FAIL:
             // fall through
         // fall through
         case AuthenticationResponse::RESTART:
             unset($this->authForm);
             if ($response->status === AuthenticationResponse::FAIL) {
                 $action = $this->getDefaultAction($subPage);
                 $messageType = 'error';
             } else {
//.........這裏部分代碼省略.........
開發者ID:claudinec,項目名稱:galan-wiki,代碼行數:101,代碼來源:LoginSignupSpecialPage.php

示例2: profilePreferences


//.........這裏部分代碼省略.........

		// Actually changeable stuff
		$defaultPreferences['realname'] = array(
			// (not really "private", but still shouldn't be edited without permission)
			'type' => $canEditPrivateInfo && $wgAuth->allowPropChange( 'realname' ) ? 'text' : 'info',
			'default' => $user->getRealName(),
			'section' => 'personal/info',
			'label-message' => 'yourrealname',
			'help-message' => 'prefs-help-realname',
		);

		if ( $canEditPrivateInfo && $wgAuth->allowPasswordChange() ) {
			$link = Linker::link( SpecialPage::getTitleFor( 'ChangePassword' ),
				$context->msg( 'prefs-resetpass' )->escaped(), array(),
				array( 'returnto' => SpecialPage::getTitleFor( 'Preferences' )->getPrefixedText() ) );

			$defaultPreferences['password'] = array(
				'type' => 'info',
				'raw' => true,
				'default' => $link,
				'label-message' => 'yourpassword',
				'section' => 'personal/info',
			);
		}
		if ( $wgCookieExpiration > 0 ) {
			$defaultPreferences['rememberpassword'] = array(
				'type' => 'toggle',
				'label' => $context->msg( 'tog-rememberpassword' )->numParams(
					ceil( $wgCookieExpiration / ( 3600 * 24 ) ) )->text(),
				'section' => 'personal/info',
			);
		}
		// Only show preferhttps if secure login is turned on
		if ( $wgSecureLogin && wfCanIPUseHTTPS( $context->getRequest()->getIP() ) ) {
			$defaultPreferences['prefershttps'] = array(
				'type' => 'toggle',
				'label-message' => 'tog-prefershttps',
				'help-message' => 'prefs-help-prefershttps',
				'section' => 'personal/info'
			);
		}

		// Language
		$languages = Language::fetchLanguageNames( null, 'mw' );
		if ( !array_key_exists( $wgLanguageCode, $languages ) ) {
			$languages[$wgLanguageCode] = $wgLanguageCode;
		}
		ksort( $languages );

		$options = array();
		foreach ( $languages as $code => $name ) {
			$display = wfBCP47( $code ) . ' - ' . $name;
			$options[$display] = $code;
		}
		$defaultPreferences['language'] = array(
			'type' => 'select',
			'section' => 'personal/i18n',
			'options' => $options,
			'label-message' => 'yourlanguage',
		);

		$defaultPreferences['gender'] = array(
			'type' => 'radio',
			'section' => 'personal/i18n',
			'options' => array(
				$context->msg( 'parentheses',
開發者ID:nahoj,項目名稱:mediawiki_ynh,代碼行數:67,代碼來源:Preferences.php

示例3: requiresHTTPS

 /**
  * Determine based on the wiki configuration and the user's options,
  * whether this user must be over HTTPS no matter what.
  *
  * @return bool
  */
 public function requiresHTTPS()
 {
     global $wgSecureLogin;
     if (!$wgSecureLogin) {
         return false;
     } else {
         $https = $this->getBoolOption('prefershttps');
         Hooks::run('UserRequiresHTTPS', array($this, &$https));
         if ($https) {
             $https = wfCanIPUseHTTPS($this->getRequest()->getIP());
         }
         return $https;
     }
 }
開發者ID:jpena88,項目名稱:mediawiki-dokku-deploy,代碼行數:20,代碼來源:User.php

示例4: execute

 /**
  * @param string|null $subPage
  */
 public function execute($subPage)
 {
     if (session_id() == '') {
         wfSetupSession();
     }
     $this->load();
     // Check for [[Special:Userlogin/signup]]. This affects form display and
     // page title.
     if ($subPage == 'signup') {
         $this->mType = 'signup';
     }
     $this->setHeaders();
     // In the case where the user is already logged in, and was redirected to the login form from a
     // page that requires login, do not show the login page. The use case scenario for this is when
     // a user opens a large number of tabs, is redirected to the login page on all of them, and then
     // logs in on one, expecting all the others to work properly.
     //
     // However, do show the form if it was visited intentionally (no 'returnto' is present). People
     // who often switch between several accounts have grown accustomed to this behavior.
     if ($this->mType !== 'signup' && !$this->mPosted && $this->getUser()->isLoggedIn() && ($this->mReturnTo !== '' || $this->mReturnToQuery !== '')) {
         $this->successfulLogin();
     }
     // If logging in and not on HTTPS, either redirect to it or offer a link.
     global $wgSecureLogin;
     if ($this->mRequest->getProtocol() !== 'https') {
         $title = $this->getFullTitle();
         $query = array('returnto' => $this->mReturnTo !== '' ? $this->mReturnTo : null, 'returntoquery' => $this->mReturnToQuery !== '' ? $this->mReturnToQuery : null, 'title' => null, $this->mEntryErrorType === 'error' ? 'error' : 'warning' => $this->mEntryError) + $this->mRequest->getQueryValues();
         $url = $title->getFullURL($query, false, PROTO_HTTPS);
         if ($wgSecureLogin && wfCanIPUseHTTPS($this->getRequest()->getIP()) && !$this->mFromHTTP) {
             $url = wfAppendQuery($url, 'fromhttp=1');
             $this->getOutput()->redirect($url);
             // Since we only do this redir to change proto, always vary
             $this->getOutput()->addVaryHeader('X-Forwarded-Proto');
             return;
         } else {
             // A wiki without HTTPS login support should set $wgServer to
             // http://somehost, in which case the secure URL generated
             // above won't actually start with https://
             if (substr($url, 0, 8) === 'https://') {
                 $this->mSecureLoginUrl = $url;
             }
         }
     }
     if (!is_null($this->mCookieCheck)) {
         $this->onCookieRedirectCheck($this->mCookieCheck);
         return;
     } elseif ($this->mPosted) {
         if ($this->mCreateaccount) {
             $this->addNewAccount();
             return;
         } elseif ($this->mCreateaccountMail) {
             $this->addNewAccountMailPassword();
             return;
         } elseif ('submitlogin' == $this->mAction || $this->mLoginattempt) {
             $this->processLogin();
             return;
         }
     }
     $this->mainLoginForm($this->mEntryError, $this->mEntryErrorType);
 }
開發者ID:natebrunette,項目名稱:sphericalcow,代碼行數:63,代碼來源:SpecialUserlogin.php

示例5: doCentralLoginRedirect

 /**
  * @param User $user
  * @param CentralAuthUser $centralUser
  * @param string $inject_html
  * @return bool
  */
 protected static function doCentralLoginRedirect(User $user, CentralAuthUser $centralUser, &$inject_html)
 {
     global $wgCentralAuthLoginWiki, $wgMemc, $wgSecureLogin;
     $context = RequestContext::getMain();
     $request = $context->getRequest();
     if (!$wgCentralAuthLoginWiki || defined('MW_API')) {
         // Mark the session to include edge login imgs on the next pageview
         $request->setSessionData('CentralAuthDoEdgeLogin', true);
         return true;
     }
     // Check that this is actually for a special login page view
     if ($context->getTitle()->isSpecial('Userlogin') && $request->wasPosted()) {
         // User will be redirected to Special:CentralLogin/start (central wiki),
         // then redirected back to Special:CentralLogin/complete (this wiki).
         // Sanity check that "returnto" is not one of the central login pages. If it
         // is, then clear the "returnto" options (LoginForm will use the main page).
         $returnTo = $request->getVal('returnto', '');
         $returnToQuery = $request->getVal('returntoquery', '');
         $returnToTitle = Title::newFromText($returnTo);
         if ($returnToTitle && $returnToTitle->isSpecial('CentralLogin')) {
             $returnTo = '';
             $returnToQuery = '';
         }
         // Determine the final protocol of page, after login
         $finalProto = $request->detectProtocol();
         $secureCookies = $finalProto === 'https';
         if ($wgSecureLogin) {
             $finalProto = 'http';
             if ($request->getBool('wpForceHttps', false) || $user->getBoolOption('prefershttps') && wfCanIPUseHTTPS($request->getIP())) {
                 $finalProto = 'https';
             }
             $secureCookies = $finalProto === 'https' && $user->getBoolOption('prefershttps');
         }
         // When POSTs triggered from Special:CentralLogin/start are sent back to
         // this wiki, the token will be checked to see if it was signed with this.
         // This is needed as Special:CentralLogin/start only takes a token argument
         // and we need to make sure an agent requesting such a URL actually initiated
         // the login request that spawned that token server-side.
         $secret = MWCryptRand::generateHex(32);
         $_SESSION['CentralAuth:autologin:current-attempt'] = array('secret' => $secret, 'remember' => $request->getCheck('wpRemember'), 'returnTo' => $returnTo, 'returnToQuery' => $returnToQuery, 'stickHTTPS' => $secureCookies, 'finalProto' => $finalProto, 'type' => $request->getText('type'));
         // Create a new token to pass to Special:CentralLogin/start (central wiki)
         $token = MWCryptRand::generateHex(32);
         $key = CentralAuthUser::memcKey('central-login-start-token', $token);
         $data = array('secret' => $secret, 'name' => $centralUser->getName(), 'guid' => $centralUser->getId(), 'wikiId' => wfWikiId(), 'secureCookies' => $secureCookies, 'finalProto' => $finalProto, 'currentProto' => $request->detectProtocol());
         Hooks::run('CentralAuthLoginRedirectData', array($centralUser, &$data));
         $wgMemc->set($key, $data, 60);
         $wiki = WikiMap::getWiki($wgCentralAuthLoginWiki);
         // Use WikiReference::getFullUrl(), returns a protocol-relative URL if needed
         $context->getOutput()->redirect(wfAppendQuery($wiki->getFullUrl('Special:CentralLogin/start'), "token={$token}"));
         // Set $inject_html to some text to bypass the LoginForm redirection
         $inject_html .= '<!-- do CentralAuth redirect -->';
     } else {
         // Mark the session to include edge login imgs on the next pageview
         $request->setSessionData('CentralAuthDoEdgeLogin', true);
     }
     return true;
 }
開發者ID:NDKilla,項目名稱:mediawiki-extensions-CentralAuth,代碼行數:63,代碼來源:CentralAuthHooks.php

示例6: execute

 public function execute($subPage)
 {
     if (session_id() == '') {
         wfSetupSession();
     }
     $this->load();
     // Check for [[Special:Userlogin/signup]]. This affects form display and
     // page title.
     if ($subPage == 'signup') {
         $this->mType = 'signup';
     }
     $this->setHeaders();
     // If logging in and not on HTTPS, either redirect to it or offer a link.
     global $wgSecureLogin;
     if ($this->mRequest->getProtocol() !== 'https') {
         $title = $this->getFullTitle();
         $query = array('returnto' => $this->mReturnTo, 'returntoquery' => $this->mReturnToQuery, 'title' => null) + $this->mRequest->getQueryValues();
         $url = $title->getFullURL($query, false, PROTO_HTTPS);
         if ($wgSecureLogin && wfCanIPUseHTTPS($this->getRequest()->getIP())) {
             $url = wfAppendQuery($url, 'fromhttp=1');
             $this->getOutput()->redirect($url);
             // Since we only do this redir to change proto, always vary
             $this->getOutput()->addVaryHeader('X-Forwarded-Proto');
             return;
         } else {
             // A wiki without HTTPS login support should set $wgServer to
             // http://somehost, in which case the secure URL generated
             // above won't actually start with https://
             if (substr($url, 0, 8) === 'https://') {
                 $this->mSecureLoginUrl = $url;
             }
         }
     }
     if (!is_null($this->mCookieCheck)) {
         $this->onCookieRedirectCheck($this->mCookieCheck);
         return;
     } elseif ($this->mPosted) {
         if ($this->mCreateaccount) {
             $this->addNewAccount();
             return;
         } elseif ($this->mCreateaccountMail) {
             $this->addNewAccountMailPassword();
             return;
         } elseif ('submitlogin' == $this->mAction || $this->mLoginattempt) {
             $this->processLogin();
             return;
         }
     }
     $this->mainLoginForm('');
 }
開發者ID:biribogos,項目名稱:wikihow-src,代碼行數:50,代碼來源:SpecialUserlogin.php

示例7: getCentralSession

 /**
  * @param CentralAuthUser $centralUser
  * @param User $user
  * @return array
  */
 private function getCentralSession($centralUser, $user)
 {
     $centralSession = $centralUser->getSession();
     $request = $this->getRequest();
     // If there's no "finalProto", check if one was passed, and otherwise
     // assume the current.
     if (!isset($centralSession['finalProto'])) {
         $centralSession['finalProto'] = $request->getVal('proto', $request->detectProtocol());
     }
     // If there's no "remember", pull from the user preference.
     if (!isset($centralSession['remember'])) {
         $centralSession['remember'] = $user->getBoolOption('rememberpassword');
     }
     // Make sure there's a value for secureCookies
     if (!isset($centralSession['secureCookies'])) {
         $centralSession['secureCookies'] = $user->getBoolOption('prefershttps') && wfCanIPUseHTTPS($request->getIP());
     }
     // Make sure there's a session id by creating a session if necessary.
     if (!isset($centralSession['sessionId'])) {
         $centralSession['sessionId'] = $centralUser->setSession($centralSession);
     }
     return $centralSession;
 }
開發者ID:NDKilla,項目名稱:mediawiki-extensions-CentralAuth,代碼行數:28,代碼來源:SpecialCentralAutoLogin.php


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