<?php namespace backend\controllers; use core\forms\user\ProfileEditForm; use core\forms\user\UserForm; use core\services\user\ProfileService; use core\services\user\UserManageService; use Yii; use core\entities\user\User; use backend\forms\UserSearch; use yii\web\Controller; use yii\web\NotFoundHttpException; use yii\filters\VerbFilter; use yii\filters\AccessControl; use yii\web\UploadedFile; /** * UserController implements the CRUD actions for User model. */ class UserController extends Controller { private $service; private $profile_service; public function __construct($id, $module, UserManageService $service, ProfileService $profile_service, $config = []) { parent::__construct($id, $module, $config); $this->service = $service; $this->profile_service = $profile_service; } /** * @inheritdoc */ public function behaviors() { return [ 'access' => [ 'class' => AccessControl::className(), 'rules' => [ [ 'actions' => ['create','view','index', 'update', 'delete'], 'allow' => true, 'roles' => ['UserManagement'], ], [ 'actions' => ['profile'], 'allow' => true, 'roles' => ['@'], ], [ // all the action are accessible to admin 'allow' => true, 'roles' => ['admin'], ], ], ], 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'delete' => ['POST'], ], ], ]; } /** * 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, ]); } /** * @param $id * * @return string * @throws NotFoundHttpException */ 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 actionCreate() { $form = new UserForm(); if ($form->load(Yii::$app->request->post()) && $form->validate()) { try { $user = $this->service->create($form); return $this->redirect(['view', 'id' => $user->id]); } catch (\DomainException $e) { Yii::$app->errorHandler->logException($e); Yii::$app->session->setFlash('error', $e->getMessage()); } } return $this->render('create', [ 'model' => $form, ]); } /** * @param $id * * @return string|\yii\web\Response * @throws NotFoundHttpException */ public function actionUpdate($id) { $user = $this->findModel($id); $form = new UserForm($user); if ($form->load(Yii::$app->request->post()) && $form->validate()) { try { $this->service->edit($user->id, $form); return $this->redirect(['view', 'id' => $user->id]); } catch (\DomainException $e) { Yii::$app->errorHandler->logException($e); Yii::$app->session->setFlash('error', $e->getMessage()); } } return $this->render('update', [ 'model' => $form, 'user' => $user, ]); } /** * 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) { $this->service->remove($id); return $this->redirect(['index']); } public function actionProfile() { $user = $this->findModel(Yii::$app->user->id); $form = new ProfileEditForm($user); if ($form->load(Yii::$app->request->post()) && $form->validate()) { try { $form->user_pic = UploadedFile::getInstance($form, 'user_pic'); $this->profile_service->edit(Yii::$app->user->id, $form); Yii::$app->session->setFlash('success', Yii::t('user', 'Profile is saved.')); } catch (\DomainException $e) { Yii::$app->errorHandler->logException($e); Yii::$app->session->setFlash('error', $e->getMessage()); } } return $this->render('profile', [ 'model' => $form, 'user' => $user, ]); } /** * 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.'); } } }