Source of file LoginAndRedirect.php
Size: 1,850 Bytes - Last Modified: 2021-12-23T10:47:10+00:00
/var/www/docs.ssmods.com/process/src/src/Control/LoginAndRedirect.php
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 | <?php namespace Sunnysideup\TemplateOverview\Control; use SilverStripe\Control\Controller; use SilverStripe\Control\Director; use SilverStripe\Control\Util\IPUtils; use SilverStripe\Core\Config\Config; use SilverStripe\Core\Environment; use SilverStripe\Core\Injector\Injector; use SilverStripe\Security\IdentityStore; use SilverStripe\Security\MemberAuthenticator\CookieAuthenticationHandler; use SilverStripe\Security\Security; class LoginAndRedirect extends Controller { private static $allowed_actions = [ 'login' => '->isDev', ]; private static $allowed_ips = [ '127.0.0.1', ]; public function login($request) { $url = $request->getVar('BackURL'); $member = CheckAllTemplatesResponseController::get_test_user(); Security::setCurrentUser($member); // Injector::inst()->get(IdentityStore::class)->logIn($member, true); Injector::inst()->get(CookieAuthenticationHandler::class) ->logIn($member, $persist = true) ; // die($url); return $this->redirect($url); } public function isDev() { if (Environment::getEnv('SS_ALLOW_SMOKE_TEST')) { $allowedIPs = Config::inst()->get(self::class, 'allowed_ips'); if (IPUtils::checkIP($this->request->getIP(), $allowedIPs)) { return Director::isDev(); } user_error( 'Please include your ip address in LoginAndRedirect.allowed_ips: ' . $this->request->getIP() . '. Currently set are: ' . implode(', ', $allowedIPs), E_USER_ERROR ); return; } user_error( 'Please set SS_ALLOW_SMOKE_TEST in your environment variables to use this service.', E_USER_ERROR ); } } |