Provider.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. <?php
  2. namespace SocialiteProviders\WeixinWeb;
  3. use Illuminate\Support\Arr;
  4. use SocialiteProviders\Manager\OAuth2\AbstractProvider;
  5. use SocialiteProviders\Manager\OAuth2\User;
  6. class Provider extends AbstractProvider
  7. {
  8. /**
  9. * Unique Provider Identifier.
  10. */
  11. public const IDENTIFIER = 'WEIXINWEB';
  12. /**
  13. * @var string
  14. */
  15. protected $openId;
  16. /**
  17. * {@inheritdoc}.
  18. */
  19. protected $scopes = ['snsapi_login'];
  20. /**
  21. * set Open Id.
  22. *
  23. * @param string $openId
  24. */
  25. public function setOpenId($openId)
  26. {
  27. $this->openId = $openId;
  28. }
  29. /**
  30. * {@inheritdoc}.
  31. */
  32. protected function getAuthUrl($state)
  33. {
  34. //return $this->buildAuthUrlFromBase('https://open.weixin.qq.com/connect/qrconnect', $state);
  35. return $this->buildAuthUrlFromBase($this->getConfig(
  36. 'auth_base_uri',
  37. 'https://open.weixin.qq.com/connect/qrconnect'
  38. ), $state);
  39. }
  40. /**
  41. * {@inheritdoc}.
  42. */
  43. protected function buildAuthUrlFromBase($url, $state)
  44. {
  45. $query = http_build_query($this->getCodeFields($state), '', '&', $this->encodingType);
  46. return $url.'?'.$query.'#wechat_redirect';
  47. }
  48. /**
  49. * {@inheritdoc}.
  50. */
  51. protected function getCodeFields($state = null)
  52. {
  53. return [
  54. 'appid' => $this->clientId, 'redirect_uri' => $this->redirectUrl,
  55. 'response_type' => 'code',
  56. 'scope' => $this->formatScopes($this->scopes, $this->scopeSeparator),
  57. 'state' => $state,
  58. ];
  59. }
  60. /**
  61. * {@inheritdoc}.
  62. */
  63. protected function getTokenUrl()
  64. {
  65. return 'https://api.weixin.qq.com/sns/oauth2/access_token';
  66. }
  67. /**
  68. * {@inheritdoc}.
  69. */
  70. protected function getUserByToken($token)
  71. {
  72. $response = $this->getHttpClient()->get('https://api.weixin.qq.com/sns/userinfo', [
  73. 'query' => [
  74. 'access_token' => $token,
  75. 'openid' => $this->openId,
  76. 'lang' => 'zh_CN',
  77. ],
  78. ]);
  79. return json_decode($response->getBody(), true);
  80. }
  81. /**
  82. * {@inheritdoc}.
  83. */
  84. protected function mapUserToObject(array $user)
  85. {
  86. return (new User())->setRaw($user)->map([
  87. 'id' => Arr::get($user, 'openid'),
  88. 'unionid' => Arr::get($user, 'unionid'),
  89. 'nickname' => $user['nickname'],
  90. 'avatar' => $user['headimgurl'],
  91. 'name' => null, 'email' => null,
  92. ]);
  93. }
  94. /**
  95. * {@inheritdoc}.
  96. */
  97. protected function getTokenFields($code)
  98. {
  99. return [
  100. 'appid' => $this->clientId, 'secret' => $this->clientSecret,
  101. 'code' => $code, 'grant_type' => 'authorization_code',
  102. ];
  103. }
  104. /**
  105. * {@inheritdoc}.
  106. */
  107. public function getAccessTokenResponse($code)
  108. {
  109. $response = $this->getHttpClient()->get($this->getTokenUrl(), [
  110. 'query' => $this->getTokenFields($code),
  111. ]);
  112. $this->credentialsResponseBody = json_decode($response->getBody(), true);
  113. $this->openId = $this->credentialsResponseBody['openid'];
  114. //return $this->parseAccessToken($response->getBody());
  115. return $this->credentialsResponseBody;
  116. }
  117. public static function additionalConfigKeys()
  118. {
  119. return ['auth_base_uri'];
  120. }
  121. }