127 lines
3.2 KiB
PHP
127 lines
3.2 KiB
PHP
<?php
|
|
|
|
namespace frontend\modules\api\controllers;
|
|
|
|
use common\behaviors\GsCors;
|
|
use common\models\Reports;
|
|
use frontend\modules\api\models\ReportSearchForm;
|
|
use JsonException;
|
|
use Yii;
|
|
use yii\filters\auth\CompositeAuth;
|
|
use yii\filters\auth\HttpBearerAuth;
|
|
use yii\filters\ContentNegotiator;
|
|
use yii\rest\Controller;
|
|
use yii\web\BadRequestHttpException;
|
|
use yii\web\NotFoundHttpException;
|
|
use yii\web\Response;
|
|
|
|
class ReportsController extends Controller
|
|
{
|
|
public function init()
|
|
{
|
|
parent::init(); // TODO: Change the autogenerated stub
|
|
}
|
|
|
|
public function behaviors()
|
|
{
|
|
return [
|
|
[
|
|
'class' => 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 actionCreate()
|
|
{
|
|
$reportsModel = new Reports();
|
|
|
|
$params = Yii::$app->request->get();
|
|
$reportsModel->attributes = $params;
|
|
|
|
if(!$reportsModel->validate()){
|
|
throw new BadRequestHttpException(json_encode($reportsModel->errors));
|
|
}
|
|
|
|
$reportsModel->save();
|
|
|
|
return $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();
|
|
}
|
|
|
|
}
|