265 lines
7.7 KiB
PHP
265 lines
7.7 KiB
PHP
<?php
|
|
|
|
namespace frontend\modules\api\controllers;
|
|
|
|
use frontend\modules\api\models\Comment;
|
|
use yii\web\BadRequestHttpException;
|
|
|
|
class CommentController extends ApiController
|
|
{
|
|
public function verbs(): array
|
|
{
|
|
return [
|
|
'get-entity-type-list' => ['get'],
|
|
'create' => ['post'],
|
|
'update' => ['put', 'patch'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @OA\Get(path="/comment/get-entity-type-list",
|
|
* summary="Список типов сущностей",
|
|
* description="Получить список всех возможных типов сущностей",
|
|
* tags={"Comment"},
|
|
* security={
|
|
* {"bearerAuth": {}}
|
|
* },
|
|
* @OA\Response(
|
|
* response=200,
|
|
* description="Возвращает массив",
|
|
* @OA\MediaType(
|
|
* mediaType="application/json",
|
|
* @OA\Schema(
|
|
* type="array",
|
|
* @OA\Items(
|
|
* @OA\Property(
|
|
* property="id",
|
|
* type="integer",
|
|
* example="1",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="name",
|
|
* type="string",
|
|
* example="Проект",
|
|
* ),
|
|
* )
|
|
* ),
|
|
* ),
|
|
*
|
|
* ),
|
|
* )
|
|
*
|
|
* @return array
|
|
*/
|
|
public function actionGetEntityTypeList(): array
|
|
{
|
|
$arr = [];
|
|
foreach (Comment::getEntityTypeList() as $key => $value) {
|
|
$arr[] = ["id" => $key, "name" => $value];
|
|
}
|
|
|
|
return $arr;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @OA\Post(path="/comment/create",
|
|
* summary="Добавить комментарий",
|
|
* description="Метод для создания комментария",
|
|
* security={
|
|
* {"bearerAuth": {}}
|
|
* },
|
|
* tags={"Comment"},
|
|
*
|
|
* @OA\RequestBody(
|
|
* @OA\MediaType(
|
|
* mediaType="multipart/form-data",
|
|
* @OA\Schema(
|
|
* required={"text", "entity_type", "entity_id"},
|
|
* @OA\Property(
|
|
* property="text",
|
|
* type="string",
|
|
* description="Текст комментария",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="entity_type",
|
|
* type="integer",
|
|
* description="Тип сущности",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="entity_id",
|
|
* type="integer",
|
|
* description="Идентификатор сущности",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="parent_id",
|
|
* type="integer",
|
|
* description="Идентификатор родительского комментария",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="status",
|
|
* type="integer",
|
|
* description="Статус комментария",
|
|
* ),
|
|
* ),
|
|
* ),
|
|
* ),
|
|
* @OA\Response(
|
|
* response=200,
|
|
* description="Возвращает объект комментария",
|
|
* @OA\MediaType(
|
|
* mediaType="application/json",
|
|
* @OA\Schema(ref="#/components/schemas/Comment"),
|
|
* ),
|
|
* ),
|
|
* )
|
|
*
|
|
* @return array|Comment
|
|
* @throws BadRequestHttpException
|
|
*/
|
|
public function actionCreate()
|
|
{
|
|
$model = new Comment();
|
|
$request = \Yii::$app->request->post();
|
|
|
|
$user_id = \Yii::$app->user->id;
|
|
if (!$user_id) {
|
|
throw new BadRequestHttpException(json_encode(['User not found']));
|
|
}
|
|
|
|
$request['user_id'] = $user_id;
|
|
|
|
$put = array_diff($request, [null, '']);
|
|
|
|
$model->load($put, '');
|
|
|
|
if (!$model->save()) {
|
|
return $model->errors;
|
|
}
|
|
|
|
return $model;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @OA\Put(path="/comment/update",
|
|
* summary="Редактировать комментария",
|
|
* description="Метод для редактирования комментария",
|
|
* security={
|
|
* {"bearerAuth": {}}
|
|
* },
|
|
* tags={"Comment"},
|
|
*
|
|
* @OA\RequestBody(
|
|
* @OA\MediaType(
|
|
* mediaType="application/x-www-form-urlencoded",
|
|
* @OA\Schema(
|
|
* required={"comment_id", "text"},
|
|
* @OA\Property(
|
|
* property="comment_id",
|
|
* type="integer",
|
|
* description="Идентификатор комментария",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="text",
|
|
* type="string",
|
|
* description="Текст комментария",
|
|
* ),
|
|
* @OA\Property(
|
|
* property="status",
|
|
* type="integer",
|
|
* description="статус",
|
|
* ),
|
|
* ),
|
|
* ),
|
|
* ),
|
|
* @OA\Response(
|
|
* response=200,
|
|
* description="Возвращает объект Комментария",
|
|
* @OA\MediaType(
|
|
* mediaType="application/json",
|
|
* @OA\Schema(ref="#/components/schemas/Comment"),
|
|
* ),
|
|
* ),
|
|
* )
|
|
*
|
|
* @return Comment
|
|
* @throws BadRequestHttpException
|
|
* @throws \yii\base\InvalidConfigException
|
|
*/
|
|
public function actionUpdate(): Comment
|
|
{
|
|
$user_id = \Yii::$app->user->id;
|
|
if (!$user_id) {
|
|
throw new BadRequestHttpException(json_encode(['User not found']));
|
|
}
|
|
|
|
$comment_id = \Yii::$app->request->getBodyParam('comment_id');
|
|
$model = Comment::findOne($comment_id);
|
|
if (!$model) {
|
|
throw new BadRequestHttpException(json_encode(['Comment not found']));
|
|
}
|
|
|
|
$put = array_diff(\Yii::$app->request->getBodyParams(), [null, '']);
|
|
$model->load($put, '');
|
|
|
|
|
|
if(!$model->validate()){
|
|
throw new BadRequestHttpException($model->errors);
|
|
}
|
|
$model->save();
|
|
|
|
return $model;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @OA\Get(path="/comment/get-by-entity",
|
|
* summary="Получить комментарии по идентификатору сущности",
|
|
* description="Метод для получения комментариев по идентификатору сущности.",
|
|
* security={
|
|
* {"bearerAuth": {}}
|
|
* },
|
|
* tags={"Comment"},
|
|
* @OA\Parameter(
|
|
* name="entity_id",
|
|
* in="query",
|
|
* required=true,
|
|
* @OA\Schema(
|
|
* type="integer",
|
|
* default=null
|
|
* )
|
|
* ),
|
|
*
|
|
* @OA\Parameter(
|
|
* name="entity_type",
|
|
* in="query",
|
|
* required=true,
|
|
* @OA\Schema(
|
|
* type="integer",
|
|
* default=null
|
|
* )
|
|
* ),
|
|
*
|
|
* @OA\Response(
|
|
* response=200,
|
|
* description="Возвращает массив объектов Комментариев",
|
|
* @OA\MediaType(
|
|
* mediaType="application/json",
|
|
* @OA\Schema(ref="#/components/schemas/CommentExample"),
|
|
* ),
|
|
* ),
|
|
* )
|
|
*
|
|
* @param int $entity_id
|
|
* @return array|\yii\db\ActiveRecord[]
|
|
*/
|
|
public function actionGetByEntity(int $entity_id, int $entity_type): array
|
|
{
|
|
$model = Comment::find()->where(['entity_id' => $entity_id, 'entity_type' => $entity_type, 'status' => Comment::STATUS_ACTIVE])->all();
|
|
|
|
return $model;
|
|
}
|
|
|
|
} |