/** * Creates a new Role model. * For ajax request will return json object * and for non-ajax request if creation is successful, the browser will be redirected to the 'view' page. * @return mixed */ public function actionCreate() { $request = Yii::$app->request; $model = new Role(null); if ($request->isAjax) { /* * Process for ajax request */ Yii::$app->response->format = Response::FORMAT_JSON; if ($request->isGet) { return ['title' => Yii::t('rbac', "Create new {0}", ["Role"]), 'content' => $this->renderAjax('create', ['model' => $model]), 'footer' => Html::button(Yii::t('rbac', 'Close'), ['class' => 'btn btn-default pull-left', 'data-dismiss' => "modal"]) . Html::button(Yii::t('rbac', 'Save'), ['class' => 'btn btn-primary', 'type' => "submit"])]; } else { if ($model->load($request->post()) && $model->save()) { // \johnitvn\userplus\Helper::dump($model); return ['forceReload' => 'true', 'title' => Yii::t('rbac', "Create new {0}", ["Role"]), 'content' => '<span class="text-success">' . Yii::t('rbac', "Have been create new {0} success", ["Role"]) . '</span>', 'footer' => Html::button(Yii::t('rbac', 'Close'), ['class' => 'btn btn-default pull-left', 'data-dismiss' => "modal"]) . Html::a(Yii::t('rbac', 'Create More'), ['create'], ['class' => 'btn btn-primary', 'role' => 'modal-remote'])]; } else { return ['title' => Yii::t('rbac', "Create new {0}", ["Role"]), 'content' => $this->renderAjax('create', ['model' => $model]), 'footer' => Html::button(Yii::t('rbac', 'Close'), ['class' => 'btn btn-default pull-left', 'data-dismiss' => "modal"]) . Html::button(Yii::t('rbac', 'Save'), ['class' => 'btn btn-primary', 'type' => "submit"])]; } } } else { /* * Process for non-ajax request */ if ($model->load($request->post()) && $model->save()) { return $this->redirect(['view', 'name' => $model->name]); } else { return $this->render('create', ['model' => $model]); } } }
public function save() { if (!parent::save()) { return false; } $auth = Yii::$app->authManager; $role = $auth->getRole($this->item->name); if ($this->permissions != null && is_array($this->permissions)) { foreach ($auth->getPermissions() as $permission) { if (in_array($permission->name, $this->permissions)) { $permission = $auth->getPermission($permission->name); $auth->hasChild($role, $permission) || $auth->addChild($role, $permission); } else { $auth->removeChild($role, $permission); } } } return true; }