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.
		
		
		
		
		
			
		
			
				
					
					
						
							192 lines
						
					
					
						
							5.1 KiB
						
					
					
				
			
		
		
	
	
							192 lines
						
					
					
						
							5.1 KiB
						
					
					
				| <?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.'); | |
|         } | |
|     } | |
| }
 | |
| 
 |