Как правильно запретить редактирование чужих записей

Общие вопросы по использованию второй версии фреймворка. Если не знаете как что-то сделать и это про Yii 2, вам сюда.
Ответить
alexa777
Сообщения: 299
Зарегистрирован: 2016.03.01, 17:38

Как правильно запретить редактирование чужих записей

Сообщение alexa777 »

Привет, пытаюсь (учусь) кипячу))) научится Как правильно запретить редактирование чужих записей

получилось вот так, как думаете это правильно, или есть гораздо лаконичные решения?

Код: Выделить всё

  public function actionUpdate($id)
    {
         $model = $this->findModel($id);
         if ($model->user_id !== Yii::$app->user->id){
            throw new HttpException('404', 'Acess denied');
        } else {
        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            return $this->redirect(['view', 'id' => $model->id]);
        } else {
            return $this->render('update', [
                'model' => $model,
            ]);
        }
        }
    }
    public function actionDelete($id)
    {
        $model = $this->findModel($id);
        if ($model->user_id !== Yii::$app->user->id){
            throw new HttpException('404', 'Acess denied');
        } else {
        $model->delete();

        return $this->redirect(['index']);
        }
    }
    
    
andku83
Сообщения: 988
Зарегистрирован: 2016.07.01, 10:24
Откуда: Харьков

Re: Как правильно запретить редактирование чужих записей

Сообщение andku83 »

Код: Выделить всё

    public function actionDelete($id)
    {
        $model = $this->findModel($id);
        $this->checkAccess($model);
        
        $model->delete();

        return $this->redirect(['index']);
        }
    }
    
    protected function checkAccess($model)
    {
        if ($model->user_id !== Yii::$app->user->id){
            throw new HttpException('404', 'Acess denied');
        }
    }
someweb
Сообщения: 552
Зарегистрирован: 2017.03.09, 10:12

Re: Как правильно запретить редактирование чужих записей

Сообщение someweb »

Почти, только вынесите проверку условия в метод

Код: Выделить всё

   protected function findModel($id)
Чтобы правильно задать вопрос, нужно знать бо́льшую часть ответа. Роберт Шекли.
alexa777
Сообщения: 299
Зарегистрирован: 2016.03.01, 17:38

Re: Как правильно запретить редактирование чужих записей

Сообщение alexa777 »

Спасибо вам люди добрые)))
andku83
Сообщения: 988
Зарегистрирован: 2016.07.01, 10:24
Откуда: Харьков

Re: Как правильно запретить редактирование чужих записей

Сообщение andku83 »

или еще вариант если редактирование может происходить из нескольких мест, тогда прямо в модели:

Код: Выделить всё

    public function beforeDelete()
    {
        $this->checkAccess();
        return parent::beforeDelete();
    }
    public function beforeSave($insert)
    {
        $this->checkAccess();
        return parent::beforeSave($insert);
    }
    protected function checkAccess()
    {
        if ($this->user_id !== Yii::$app->user->id){
            throw new HttpException('404', 'Acess denied');
        }
    }
alexa777
Сообщения: 299
Зарегистрирован: 2016.03.01, 17:38

Re: Как правильно запретить редактирование чужих записей

Сообщение alexa777 »

shnir писал(а): 2018.02.20, 14:16 или еще вариант если редактирование может происходить из нескольких мест, тогда прямо в модели:

Код: Выделить всё

    public function beforeDelete()
    {
        $this->checkAccess();
        return parent::beforeDelete();
    }
    public function beforeSave($insert)
    {
        $this->checkAccess();
        return parent::beforeSave($insert);
    }
    protected function checkAccess()
    {
        if ($this->user_id !== Yii::$app->user->id){
            throw new HttpException('404', 'Acess denied');
        }
    }
Спасибо еще за вариант возьму на вооружение.
А сейчас у меня все попростому и я сделал просто вот так

Код: Выделить всё

protected function findModel($id)
    {
        if (($model = Board::findOne($id)) !== null && $model->user_id == Yii::$app->user->id) {
            return $model;
        } else {
            throw new NotFoundHttpException('The requested page does not exist.');
        }
    }
Ответить