Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
| Total | |
0.00% |
0 / 1 |
|
11.11% |
1 / 9 |
CRAP | |
18.60% |
8 / 43 |
| UserController | |
0.00% |
0 / 1 |
|
11.11% |
1 / 9 |
258.81 | |
18.60% |
8 / 43 |
| behaviors | |
100.00% |
1 / 1 |
1 | |
100.00% |
2 / 2 |
|||
| actionLogin | |
0.00% |
0 / 1 |
4.05 | |
85.71% |
6 / 7 |
|||
| actionLogout | |
0.00% |
0 / 1 |
2.00 | |
0.00% |
0 / 2 |
|||
| actionIndex | |
0.00% |
0 / 1 |
2.00 | |
0.00% |
0 / 5 |
|||
| actionView | |
0.00% |
0 / 1 |
2.00 | |
0.00% |
0 / 2 |
|||
| disabledActionCreate | |
0.00% |
0 / 1 |
12.00 | |
0.00% |
0 / 5 |
|||
| actionUpdate | |
0.00% |
0 / 1 |
30.00 | |
0.00% |
0 / 9 |
|||
| actionDelete | |
0.00% |
0 / 1 |
12.00 | |
0.00% |
0 / 8 |
|||
| findModel | |
0.00% |
0 / 1 |
6.00 | |
0.00% |
0 / 3 |
|||
| <?php | |
| namespace backend\controllers; | |
| use Yii; | |
| use backend\models\UserForm; | |
| use backend\models\UserSearch; | |
| use common\models\User; | |
| use common\models\LoginForm; | |
| use yii\web\Controller; | |
| use yii\web\NotFoundHttpException; | |
| use yii\filters\AccessControl; | |
| use yii\filters\VerbFilter; | |
| /** | |
| * UserController implements the CRUD actions for User model. | |
| */ | |
| class UserController extends Controller | |
| { | |
| /** | |
| * @inheritdoc | |
| */ | |
| public function behaviors() | |
| { | |
| return [ | |
| 'access' => [ | |
| 'class' => AccessControl::className(), | |
| 'rules' => [ | |
| [ | |
| 'actions' => ['login'], | |
| 'allow' => true, | |
| ], | |
| [ | |
| 'actions' => ['logout'], | |
| 'allow' => true, | |
| 'roles' => ['@'], | |
| ], | |
| [ | |
| 'actions' => ['index', 'view', 'create', 'update', 'delete'], | |
| 'allow' => true, | |
| 'roles' => ['admin'], | |
| ], | |
| ], | |
| ], | |
| 'verbs' => [ | |
| 'class' => VerbFilter::className(), | |
| 'actions' => [ | |
| 'logout' => ['post'], | |
| 'delete' => ['post'], | |
| ], | |
| ], | |
| ]; | |
| } | |
| public function actionLogin() | |
| { | |
| if (!\Yii::$app->user->isGuest) { | |
| return $this->goHome(); | |
| } | |
| $model = new LoginForm(); | |
| if ($model->load(Yii::$app->request->post()) && $model->login()) { | |
| return $this->goBack(); | |
| } else { | |
| return $this->render('login', [ | |
| 'model' => $model, | |
| ]); | |
| } | |
| } | |
| public function actionLogout() | |
| { | |
| Yii::$app->user->logout(); | |
| return $this->goHome(); | |
| } | |
| /** | |
| * Lists all User models. | |
| * @return mixed | |
| */ | |
| public function actionIndex() | |
| { | |
| $searchModel = new UserSearch(); | |
| $dataProvider = $searchModel->search(Yii::$app->request->queryParams); | |
| return $this->render('index', [ | |
| 'searchModel' => $searchModel, | |
| 'dataProvider' => $dataProvider, | |
| ]); | |
| } | |
| /** | |
| * Displays a single User model. | |
| * @param integer $id | |
| * @return mixed | |
| */ | |
| public function actionView($id) | |
| { | |
| return $this->render('view', [ | |
| 'model' => $this->findModel($id), | |
| ]); | |
| } | |
| /** | |
| * Creates a new User model. | |
| * If creation is successful, the browser will be redirected to the 'view' page. | |
| * @return mixed | |
| */ | |
| public function disabledActionCreate() | |
| { | |
| $model = new UserForm(); | |
| if ($model->load(Yii::$app->request->post()) && $user = $model->save(true)) { | |
| return $this->redirect(['view', 'id' => $user->id]); | |
| } else { | |
| return $this->render('create', [ | |
| 'model' => $model, | |
| ]); | |
| } | |
| } | |
| /** | |
| * Updates an existing User model. | |
| * If update is successful, the browser will be redirected to the 'view' page. | |
| * @param integer $id | |
| * @return mixed | |
| */ | |
| public function actionUpdate($id) | |
| { | |
| $model = $this->findModel($id); | |
| if($model->participant){ | |
| return $this->run('organization-participant/update', ['id' => $model->participant->id]); | |
| } | |
| if($model->supervisor){ | |
| return $this->run('supervisor/update', ['id' => $model->supervisor->id]); | |
| } | |
| if ($model->load(Yii::$app->request->post()) && $model->save()) { | |
| return $this->redirect(['view', 'id' => $model->id]); | |
| } else { | |
| return $this->render('update', [ | |
| 'model' => $model, | |
| ]); | |
| } | |
| } | |
| /** | |
| * Deletes an existing User model. | |
| * If deletion is successful, the browser will be redirected to the 'index' page. | |
| * @param integer $id | |
| * @return mixed | |
| */ | |
| public function actionDelete($id) | |
| { | |
| $model = $this->findModel($id); | |
| $auth = Yii::$app->authManager; | |
| if(!$auth->checkAccess($model->id, 'admin')){ | |
| if(!$auth->checkAccess($model->id, 'supervisor')){ | |
| $model->delete(); | |
| }else{ | |
| Yii::$app->session->setFlash('warning', Yii::t('app', 'You can not remove superisor account.')); | |
| } | |
| }else{ | |
| Yii::$app->session->setFlash('warning', Yii::t('app', 'You can not remove administrator account.')); | |
| } | |
| return $this->redirect(['index']); | |
| } | |
| /** | |
| * Finds the User model based on its primary key value. | |
| * If the model is not found, a 404 HTTP exception will be thrown. | |
| * @param integer $id | |
| * @return User the loaded model | |
| * @throws NotFoundHttpException if the model cannot be found | |
| */ | |
| protected function findModel($id) | |
| { | |
| if (($model = User::findOne($id)) !== null) { | |
| return $model; | |
| } else { | |
| throw new NotFoundHttpException('The requested page does not exist.'); | |
| } | |
| } | |
| } |