AccountController.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. <?php
  2. namespace App\Http\Controllers\Client;
  3. use App\Http\Controllers\Controller;
  4. use App\Services\Client\AccountService;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\Auth;
  7. /**
  8. * @group 用户端
  9. *
  10. * 包含登录、注册、账户管理等基础功能
  11. */
  12. class AccountController extends Controller
  13. {
  14. protected AccountService $service;
  15. public function __construct(AccountService $service)
  16. {
  17. $this->service = $service;
  18. }
  19. /**
  20. * 发送验证码
  21. *
  22. * 向指定手机号发送验证码
  23. *
  24. * @queryParam mobile string required 手机号码. Example: 13800138000
  25. *
  26. * @response {
  27. * "code": 200,
  28. * "message": "验证码发送成功",
  29. * "data": null
  30. * }
  31. */
  32. public function sendVerifyCode(Request $request)
  33. {
  34. $mobile = $request->input('mobile');
  35. return $this->service->sendVerifyCode($mobile);
  36. }
  37. /**
  38. * 用户登录
  39. *
  40. * 使用手机号和验证码登录账户
  41. *
  42. * @bodyParam mobile string required 手机号码. Example: 13800138000
  43. * @bodyParam code string required 验证码. Example: 123456
  44. *
  45. * @response {
  46. * "code": 200,
  47. * "message": "登录成功",
  48. * "data": {
  49. * "token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...",
  50. * "user": {
  51. * "id": 1,
  52. * "mobile": "13800138000",
  53. * "nickname": "用户昵称"
  54. * }
  55. * }
  56. * }
  57. */
  58. public function login(Request $request)
  59. {
  60. $mobile = $request->input('mobile');
  61. $code = $request->input('code');
  62. return $this->success(
  63. $this->service->login($mobile, $code)
  64. );
  65. }
  66. /**
  67. * 微信登录
  68. *
  69. * 使用微信openid登录账户
  70. *
  71. * @bodyParam openid string required 微信openid. Example: wx_123456789
  72. *
  73. * @response {
  74. * "code": 200,
  75. * "message": "登录成功",
  76. * "data": {
  77. * "token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...",
  78. * "user": {
  79. * "id": 1,
  80. * "openid": "wx_123456789",
  81. * "nickname": "微信昵称"
  82. * }
  83. * }
  84. * }
  85. */
  86. public function wxLogin(Request $request)
  87. {
  88. $openid = $request->input('openid');
  89. return $this->service->wxLogin($openid);
  90. }
  91. /**
  92. * 用户退出
  93. *
  94. * 退出当前账户登录状态
  95. *
  96. * @authenticated
  97. *
  98. * @response {
  99. * "code": 200,
  100. * "message": "退出成功",
  101. * "data": null
  102. * }
  103. */
  104. public function logout()
  105. {
  106. return $this->service->logout(Auth::user()->id);
  107. }
  108. /**
  109. * 用户注销
  110. *
  111. * 永久注销当前账户
  112. *
  113. * @authenticated
  114. *
  115. * @response {
  116. * "code": 200,
  117. * "message": "注销成功",
  118. * "data": null
  119. * }
  120. */
  121. public function destroy()
  122. {
  123. return $this->service->deleteAccount();
  124. }
  125. }