ContentNegotiator::className(), 'formats' => [ 'application/json' => Response::FORMAT_JSON, ], ], // 'corsFilter' => [ // 'class' => GsCors::class, // 'cors' => [ // 'Origin' => ['*'], // //'Access-Control-Allow-Credentials' => true, // 'Access-Control-Allow-Headers' => [ // 'Content-Type', // 'Access-Control-Allow-Headers', // 'Authorization', // 'X-Requested-With' // ], // ] // ], 'authenticator' => [ 'class' => CompositeAuth::class, 'authMethods' => [ HttpBearerAuth::class, ], ] ]; } public function actionIndex(): array { $reportsModel = new ReportSearchForm(); $params = Yii::$app->request->get(); $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'); } $reportsModel = new Reports(); $reportsModel->attributes = $params; if(!$reportsModel->validate()){ throw new BadRequestHttpException(json_encode($reportsModel->errors)); } $tasks = []; foreach (json_decode($params['tasks'], true) as $jsonTask){ $task = new ReportsTask(); $task->scenario = ReportsTask::SCENARIO_WITHOUT_REPORT_ID; $task->attributes = $jsonTask; if (!$task->validate()) { throw new BadRequestHttpException(json_encode($task->errors)); } $tasks []= $task->attributes; } $attributes = $task->attributes(); $reportsModel->save(); $tasks = array_map(function ($task)use($reportsModel){$task['report_id'] = $reportsModel->id; return $task;}, $tasks); Yii::$app->db->createCommand()->batchInsert(ReportsTask::tableName(), $attributes, $tasks)->execute(); return array_merge($reportsModel->toArray(), ['tasks' => $tasks]); } 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(); } }