AccountController.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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. * @bodyParam 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->service->login($mobile, $code);
  63. }
  64. /**
  65. * 微信登录
  66. *
  67. * 使用微信openid登录账户
  68. *
  69. * @bodyParam openid string required 微信openid. Example: wx_123456789
  70. *
  71. * @response {
  72. * "code": 200,
  73. * "message": "登录成功",
  74. * "data": {
  75. * "token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...",
  76. * "user": {
  77. * "id": 1,
  78. * "openid": "wx_123456789",
  79. * "nickname": "微信昵称"
  80. * }
  81. * }
  82. * }
  83. */
  84. public function wxLogin(Request $request)
  85. {
  86. $openid = $request->input('openid');
  87. return $this->service->wxLogin($openid);
  88. }
  89. /**
  90. * 用户退出
  91. *
  92. * 退出当前账户登录状态
  93. *
  94. * @authenticated
  95. *
  96. * @response {
  97. * "code": 200,
  98. * "message": "退出成功",
  99. * "data": null
  100. * }
  101. */
  102. public function logout()
  103. {
  104. return $this->service->logout(Auth::user()->id);
  105. }
  106. /**
  107. * 用户注销
  108. *
  109. * 永久注销当前账户
  110. *
  111. * @authenticated
  112. *
  113. * @response {
  114. * "code": 200,
  115. * "message": "注销成功",
  116. * "data": null
  117. * }
  118. */
  119. public function destroy()
  120. {
  121. return $this->service->deleteAccount();
  122. }
  123. }