guild/frontend/modules/api/controllers/UserController.php

213 lines
5.7 KiB
PHP
Raw Normal View History

2021-07-28 18:15:38 +03:00
<?php
namespace frontend\modules\api\controllers;
use common\models\User;
use frontend\modules\api\models\profile\ProfileChangeEmailForm;
use frontend\modules\api\models\profile\ProfileChangePersonalDataForm;
use frontend\modules\api\services\UserService;
2021-07-28 18:15:38 +03:00
use Yii;
use yii\base\InvalidConfigException;
2021-07-28 18:15:38 +03:00
use yii\web\BadRequestHttpException;
2023-10-11 23:19:30 +03:00
class UserController extends ApiController
2021-07-28 18:15:38 +03:00
{
public $modelClass = User::class;
2023-10-12 10:45:39 +03:00
public function behaviors()
{
$behaviors = parent::behaviors();
if($this->action->id == "login"){
unset($behaviors['authenticator']);
}
return $behaviors;
}
private UserService $userService;
public function __construct(
$id,
$module,
UserService $userService,
$config = []
)
{
$this->userService = $userService;
parent::__construct($id, $module, $config);
2023-10-12 10:45:39 +03:00
}
2021-07-28 18:15:38 +03:00
2022-12-26 15:23:46 +03:00
public function actions()
2021-07-28 18:15:38 +03:00
{
2022-12-23 17:40:43 +03:00
$actions = parent::actions();
unset($actions['index']);
unset($actions['create']);
unset($actions['update']);
unset($actions['delete']);
2021-07-28 18:15:38 +03:00
}
public function verbs(): array
{
return [
'change-personalData' => ['put', 'patch'],
'change-email' => ['put', 'patch'],
'change-password' => ['put', 'patch'],
];
}
2021-07-28 18:15:38 +03:00
/**
* @return array
* @throws BadRequestHttpException
* @throws InvalidConfigException
*/
public function actionLogin(): array
2021-07-28 18:15:38 +03:00
{
return $this->userService->login(Yii::$app->getRequest()->getBodyParams());
2021-07-28 18:15:38 +03:00
}
2023-10-11 23:19:30 +03:00
/**
2023-10-11 23:32:30 +03:00
*
* @OA\Get(path="/user/me",
* summary="Получить данные пользователя",
* description="Метод для получения данныех пользователя",
* security={
* {"bearerAuth": {}}
* },
* tags={"User"},
* @OA\Response(
* response=200,
* description="Возвращает данные пользователя",
* @OA\MediaType(
* mediaType="application/json",
* ),
* ),
* )
*
* @return \frontend\modules\api\models\profile\User
2023-10-11 23:19:30 +03:00
* @throws BadRequestHttpException
*/
public function actionMe(): \frontend\modules\api\models\profile\User
2023-10-11 23:19:30 +03:00
{
return $this->userService->findCurrentUser();
}
/**
*
* @OA\Put(path="/user/change-email",
* summary="Изменить email адрес",
* description="Метод для изменения email адреса пользователя",
* security={
* {"bearerAuth": {}}
* },
* tags={"User"},
*
* @OA\RequestBody(
* @OA\MediaType(
* mediaType="application/x-www-form-urlencoded",
* @OA\Schema(
* required={"newEmail"},
* @OA\Property(
* property="newEmail",
* type="string",
* description="Новый email адрес",
* ),
* ),
* ),
* ),
* @OA\Response(
* response=200,
* description="Возвращает сообщение об успехе",
* ),
* )
* )
*
* @return ProfileChangeEmailForm|string[]
*/
public function actionChangeEmail()
{
return $this->userService->changeEmail(Yii::$app->request->post());
}
2023-10-11 23:19:30 +03:00
/**
*
* @OA\Put(path="/user/change-password",
* summary="Изменить пароль",
* description="Метод для изменения пароля пользователя",
* security={
* {"bearerAuth": {}}
* },
* tags={"User"},
*
* @OA\RequestBody(
* @OA\MediaType(
* mediaType="application/x-www-form-urlencoded",
* @OA\Schema(
* required={"password", newPassword},
* @OA\Property(
* property="password",
* type="string",
* description="Старый пароль",
* ),
* @OA\Property(
* property="newPassword",
* type="string",
* description="Новый пароль",
* ),
* ),
* ),
* ),
* @OA\Response(
* response=200,
* description="Возвращает сообщение об успехе",
* ),
* )
* )
*
* @return ProfileChangeEmailForm|string[]
*/
public function actionChangePassword()
{
return $this->userService->changePassword(Yii::$app->request->post());
}
/**
*
* @OA\Put(path="/user/change-personal-data",
* summary="Изменить логин",
* description="Метод для изменения логина пользователя",
* security={
* {"bearerAuth": {}}
* },
* tags={"User"},
*
* @OA\RequestBody(
* @OA\MediaType(
* mediaType="application/x-www-form-urlencoded",
* @OA\Schema(
* required={"newUsername"},
* @OA\Property(
* property="newUsername",
* type="string",
* description="Новый логин",
* ),
* ),
* ),
* ),
* @OA\Response(
* response=200,
* description="Возвращает сообщение об успехе",
* ),
* )
* )
*
* @return ProfileChangePersonalDataForm|string[]
* @throws \Exception
*/
public function actionChangePersonalData()
{
return $this->userService->changeChangePersonalData(Yii::$app->request->post());
2023-10-11 23:19:30 +03:00
}
2021-07-28 18:15:38 +03:00
}