AuthController.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <?php
  2. namespace App\Modules\Mini\Controllers;
  3. use App\Base\BaseController;
  4. use App\Models\User\User;
  5. use App\Modules\Mini\Services\AuthService;
  6. use App\Modules\Mini\Services\WechatService;
  7. use App\Modules\Mini\Services\EmailService;
  8. use Illuminate\Support\Facades\Auth;
  9. class AuthController extends BaseController
  10. {
  11. public function codeToSession()
  12. {
  13. $params = $this->valid([
  14. "code" => "required",
  15. ]);
  16. $sessionData = app(WechatService::class)->codeToSession($params['code']);
  17. $token = app(AuthService::class)->authByOpenid($sessionData['openid']);
  18. return $this->ok([
  19. "token" => $token,
  20. "openid" => $sessionData['openid'],
  21. "sessionKey" => $sessionData['session_key'],
  22. ]);
  23. }
  24. public function decryptUserInfo()
  25. {
  26. $params = $this->valid([
  27. "iv" => "required",
  28. "encrypted_data" => "required",
  29. "session_key" => "required",
  30. ]);
  31. app(WechatService::class)->decryptUserInfo($params);
  32. /** @var User $user */
  33. $user = \Auth::user();
  34. return $this->ok([
  35. "token" => app(AuthService::class)->encryptToken($user->id),
  36. "name" => $user->name,
  37. "phone" => $user->phone,
  38. ]);
  39. }
  40. public function decryptPhone()
  41. {
  42. $params = $this->valid([
  43. "iv" => "required",
  44. "encrypted_data" => "required",
  45. "session_key" => "required",
  46. ]);
  47. app(WechatService::class)->decryptPhone($params);
  48. /** @var User $user */
  49. $user = \Auth::user();
  50. return $this->ok([
  51. "token" => app(AuthService::class)->encryptToken($user->id),
  52. "name" => $user->name,
  53. "phone" => $user->phone,
  54. ]);
  55. }
  56. public function profile()
  57. {
  58. /** @var User $user */
  59. $user = Auth::user();
  60. return $this->ok([
  61. "id" => $user->id,
  62. "token" => app(AuthService::class)->encryptToken($user->id),
  63. "name" => $user->name,
  64. "avatar" => $user->avatar,
  65. "company" => [
  66. "id" => optional($user->company)->id ?? 0,
  67. "name" => optional($user->company)->name ?? "",
  68. ],
  69. ]);
  70. }
  71. public function test()
  72. {
  73. $id = request()->input("id");
  74. return $this->ok(app(AuthService::class)->encryptToken($id));
  75. }
  76. public function emailCaptcha()
  77. {
  78. $params = $this->valid([
  79. "email" => "required|email",
  80. "source" => "required",
  81. ]);
  82. return $this->ok(app(EmailService::class)->emailCaptcha($params['email'], $params['source']));
  83. }
  84. public function register()
  85. {
  86. return $this->ok([
  87. "token" => "token",
  88. "name" => "",
  89. "phone" => "",
  90. ]);
  91. }
  92. public function login()
  93. {
  94. return $this->ok([
  95. "token" => "token",
  96. "name" => "",
  97. "phone" => "",
  98. ]);
  99. }
  100. public function resetPassword()
  101. {
  102. return $this->ok([
  103. "token" => "token",
  104. "name" => "",
  105. "phone" => "",
  106. ]);
  107. }
  108. }