2016-08-21 02:21:39 +03:00
|
|
|
<?php
|
|
|
|
namespace api\modules\authserver;
|
|
|
|
|
2016-08-29 02:17:45 +03:00
|
|
|
use Yii;
|
2016-08-21 02:21:39 +03:00
|
|
|
use yii\base\BootstrapInterface;
|
|
|
|
use yii\base\InvalidConfigException;
|
2016-09-07 17:56:30 +03:00
|
|
|
use yii\web\NotFoundHttpException;
|
2016-08-21 02:21:39 +03:00
|
|
|
|
|
|
|
class Module extends \yii\base\Module implements BootstrapInterface {
|
|
|
|
|
|
|
|
public $id = 'authserver';
|
|
|
|
|
|
|
|
public $defaultRoute = 'index';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string базовый домен, запросы на который этот модуль должен обрабатывать
|
|
|
|
*/
|
2016-09-21 11:13:43 +03:00
|
|
|
public $host = 'authserver.ely.by';
|
2016-08-21 02:21:39 +03:00
|
|
|
|
|
|
|
public function init() {
|
|
|
|
parent::init();
|
2016-09-21 11:13:43 +03:00
|
|
|
if ($this->host === null) {
|
2016-08-21 02:21:39 +03:00
|
|
|
throw new InvalidConfigException('base domain must be specified');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-07 17:56:30 +03:00
|
|
|
public function beforeAction($action) {
|
|
|
|
if (!parent::beforeAction($action)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->checkHost();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
/**
|
|
|
|
* @param \yii\base\Application $app the application currently running
|
|
|
|
*/
|
|
|
|
public function bootstrap($app) {
|
|
|
|
$app->getUrlManager()->addRules([
|
2017-04-04 14:40:09 +03:00
|
|
|
"//$this->host/$this->id/auth/<action>" => "$this->id/authentication/<action>",
|
2016-08-21 02:21:39 +03:00
|
|
|
], false);
|
|
|
|
}
|
|
|
|
|
2016-08-29 02:17:45 +03:00
|
|
|
public static function info($message) {
|
|
|
|
Yii::info($message, 'legacy-authserver');
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function error($message) {
|
|
|
|
Yii::info($message, 'legacy-authserver');
|
|
|
|
}
|
|
|
|
|
2016-09-07 17:56:30 +03:00
|
|
|
/**
|
|
|
|
* Поскольку это legacy метод и документации в новой среде для него не будет,
|
|
|
|
* нет смысла выставлять на показ внутренние url, так что ограничиваем доступ
|
|
|
|
* только для заходов по старому домену
|
|
|
|
*
|
|
|
|
* @throws NotFoundHttpException
|
|
|
|
*/
|
|
|
|
protected function checkHost() {
|
2016-09-21 11:13:43 +03:00
|
|
|
if (parse_url(Yii::$app->request->getHostInfo(), PHP_URL_HOST) !== $this->host) {
|
2016-09-07 17:56:30 +03:00
|
|
|
throw new NotFoundHttpException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
}
|