2016-08-21 02:21:39 +03:00
|
|
|
<?php
|
2019-02-20 22:58:52 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
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;
|
2016-09-07 17:56:30 +03:00
|
|
|
use yii\web\NotFoundHttpException;
|
2019-06-18 02:33:20 +03:00
|
|
|
use yii\web\Response;
|
2016-08-21 02:21:39 +03:00
|
|
|
|
|
|
|
class Module extends \yii\base\Module implements BootstrapInterface {
|
|
|
|
|
|
|
|
public $id = 'authserver';
|
|
|
|
|
|
|
|
public $defaultRoute = 'index';
|
|
|
|
|
2019-06-18 02:33:20 +03:00
|
|
|
public function beforeAction($action): bool {
|
2016-09-07 17:56:30 +03:00
|
|
|
if (!parent::beforeAction($action)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->checkHost();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-06-18 02:33:20 +03:00
|
|
|
public function afterAction($action, $result) {
|
|
|
|
if ($result === null) {
|
|
|
|
Yii::$app->response->format = Response::FORMAT_RAW;
|
|
|
|
}
|
|
|
|
|
|
|
|
return parent::afterAction($action, $result);
|
|
|
|
}
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
/**
|
2019-02-20 22:58:52 +03:00
|
|
|
* @param \yii\base\Application $app
|
2016-08-21 02:21:39 +03:00
|
|
|
*/
|
2019-06-18 02:33:20 +03:00
|
|
|
public function bootstrap($app): void {
|
2019-02-20 22:58:52 +03:00
|
|
|
$legacyHost = $app->params['authserverHost'];
|
2016-08-21 02:21:39 +03:00
|
|
|
$app->getUrlManager()->addRules([
|
2019-02-20 22:58:52 +03:00
|
|
|
"//{$legacyHost}/authserver/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() {
|
2019-02-20 22:58:52 +03:00
|
|
|
if (parse_url(Yii::$app->request->getHostInfo(), PHP_URL_HOST) !== Yii::$app->params['authserverHost']) {
|
2016-09-07 17:56:30 +03:00
|
|
|
throw new NotFoundHttpException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-21 02:21:39 +03:00
|
|
|
}
|