You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.4 KiB
59 lines
1.4 KiB
<?php
|
|
|
|
namespace api\controllers;
|
|
|
|
use yii\filters\auth\HttpBearerAuth;
|
|
use yii\helpers\ArrayHelper;
|
|
use yii\rest\ActiveController;
|
|
use yii\web\NotFoundHttpException;
|
|
use Yii;
|
|
/**
|
|
* @author iron
|
|
* @email weiriron@gmail.com
|
|
*/
|
|
class CommonController extends ActiveController
|
|
{
|
|
|
|
public $searchModel;
|
|
|
|
public function behaviors()
|
|
{
|
|
return ArrayHelper::merge(parent::behaviors(), [
|
|
'authenticatior' => [
|
|
'class' => HttpBearerAuth::className(),
|
|
'except' => [],
|
|
]
|
|
]);
|
|
}
|
|
|
|
public function actions()
|
|
{
|
|
$action = parent::actions();
|
|
unset($action['create']);
|
|
unset($action['update']);
|
|
unset($action['index']);
|
|
return $action;
|
|
}
|
|
|
|
protected function getFilter()
|
|
{
|
|
return [];
|
|
}
|
|
|
|
public function checkAccess($action, $model = null, $params = [])
|
|
{
|
|
if ($model && isset($model->user_id) && $model->user_id !== Yii::$app->user->getId()) {
|
|
switch ($action) {
|
|
case 'view':
|
|
$message = '您无权访问该数据';
|
|
break;
|
|
case 'delete':
|
|
$message = '您无权删除该数据';
|
|
break;
|
|
default:
|
|
$message = '无相关权限';
|
|
}
|
|
throw new NotFoundHttpException($message);
|
|
}
|
|
}
|
|
}
|