ContentNegotiator::className(), 'formats' => [ 'application/json' => Response::FORMAT_JSON, ], ], 'authenticator' => [ 'class' => CompositeAuth::class, 'authMethods' => [ HttpBearerAuth::class, ], ] ]; return array_merge($parent, $b); } public function actionIndex(): array { $reportsModel = new ReportSearchForm(); $params = Yii::$app->request->get(); if(!isset($params['user_card_id'])){ $userCard = UserCard::find()->where(['id_user' => Yii::$app->user->id])->one(); if($userCard){ $params['user_card_id'] = $userCard->id; } } $reportsModel->attributes = $params; if(!$reportsModel->validate()){ return $reportsModel->errors; } return $reportsModel->byParams(); } public function actionView($id): array{ $report = Reports::findOne($id); return array_merge($report->toArray(), ['tasks' => $report->_task]); } public function actionCreate() { $params = Yii::$app->request->post(); if (!isset($params['tasks'])){ throw new BadRequestHttpException('Нет параметра tasks'); } if(!isset($params['user_card_id'])){ $userCard = UserCard::find()->where(['id_user' => Yii::$app->user->id])->one(); if($userCard){ $params['user_card_id'] = $userCard->id; } } $reportsModel = new Reports(); $reportsModel->attributes = $params; $params['tasks'] = (is_array($params['tasks'])) ? $params['tasks'] : json_decode($params['tasks']); if(!$reportsModel->validate()){ throw new BadRequestHttpException(json_encode($reportsModel->errors)); } $reportsModel->save(); return array_merge($reportsModel->toArray()); } public function actionDelete() { $id = Yii::$app->request->get('id'); $report = Reports::findOne($id); if(null === $report) { throw new NotFoundHttpException('Report not found'); } if(false === ($report->delete())) { throw new JsonException('Report not deleted'); } return true; } public function actionUpdate(): array { $params = Yii::$app->request->get(); $reportsModel = Reports::findone($params['id']); if(!isset($reportsModel)) { throw new NotFoundHttpException('report not found'); } if(isset($params['user_card_id'])) { throw new JsonException('constraint by user_card_id'); } $reportsModel->attributes = $params; if(!$reportsModel->validate()){ throw new BadRequestHttpException(json_encode($reportsModel->errors)); } $reportsModel->save(); return $reportsModel->toArray(); } }