AccessTokenService.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. <?php
  2. namespace services\api;
  3. use Yii;
  4. use yii\db\ActiveRecord;
  5. use common\components\Service;
  6. use common\enums\StatusEnum;
  7. use common\helpers\ArrayHelper;
  8. use common\models\member\Member;
  9. use common\enums\DevPatternEnum;
  10. use common\models\api\AccessToken;
  11. /**
  12. * Class AccessTokenService
  13. * @package services\api
  14. * @author jianyan74 <751393839@qq.com>
  15. */
  16. class AccessTokenService extends Service
  17. {
  18. /**
  19. * @var bool
  20. */
  21. public $cache = false;
  22. /**
  23. * @var int
  24. */
  25. public $timeout = 720;
  26. /**
  27. * 获取token
  28. *
  29. * @param Member $member
  30. * @param $group
  31. * @param int $cycle_index 重新获取次数
  32. * @return array
  33. * @throws \yii\base\Exception
  34. */
  35. public function getAccessToken(Member $member, $group, $cycle_index = 1)
  36. {
  37. $model = $this->findModel($member->id, $member->type, $group);
  38. $model->member_id = $member->id;
  39. $model->member_type = $member->type;
  40. $model->merchant_id = $member->merchant_id;
  41. $model->group = $group;
  42. // 删除缓存
  43. !empty($model->access_token) && Yii::$app->cache->delete($this->getCacheKey($model->access_token));
  44. $model->refresh_token = Yii::$app->security->generateRandomString() . '_' . time();
  45. $model->access_token = Yii::$app->security->generateRandomString() . '_' . time();
  46. $model->status = StatusEnum::ENABLED;
  47. if (!$model->save()) {
  48. if ($cycle_index <= 3) {
  49. $cycle_index++;
  50. return self::getAccessToken($member, $group, $cycle_index);
  51. }
  52. $this->error($model);
  53. }
  54. $result = [];
  55. $result['refresh_token'] = $model->refresh_token;
  56. $result['access_token'] = $model->access_token;
  57. $result['expiration_time'] = Yii::$app->params['user.accessTokenExpire'];
  58. // 关联账号信息
  59. $account = $member->account;
  60. $memberLevel = $member->memberLevel;
  61. $member = ArrayHelper::toArray($member);
  62. unset($member['password_hash'], $member['auth_key'], $member['password_reset_token'], $member['access_token'], $member['refresh_token']);
  63. $result['member'] = $member;
  64. $result['member']['account'] = ArrayHelper::toArray($account);
  65. $result['member']['memberLevel'] = ArrayHelper::toArray($memberLevel);
  66. // 写入缓存
  67. $this->cache === true && Yii::$app->cache->set($this->getCacheKey($model->access_token), $model, $this->timeout);
  68. return $result;
  69. }
  70. /**
  71. * @param $token
  72. * @param $type
  73. * @return array|mixed|null|ActiveRecord
  74. */
  75. public function getTokenToCache($token, $type, $cache = false)
  76. {
  77. if ($cache == false && $this->cache == false) {
  78. return $this->findByAccessToken($token);
  79. }
  80. $key = $this->getCacheKey($token);
  81. if (!($model = Yii::$app->cache->get($key))) {
  82. $model = $this->findByAccessToken($token);
  83. Yii::$app->cache->set($key, $model, $this->timeout);
  84. }
  85. return $model;
  86. }
  87. /**
  88. * 禁用token
  89. *
  90. * @param $access_token
  91. */
  92. public function disableByAccessToken($access_token)
  93. {
  94. $this->cache === true && Yii::$app->cache->delete($this->getCacheKey($access_token));
  95. if ($model = $this->findByAccessToken($access_token)) {
  96. $model->status = StatusEnum::DISABLED;
  97. return $model->save();
  98. }
  99. return false;
  100. }
  101. /**
  102. * 获取token
  103. *
  104. * @param $token
  105. * @return array|null|ActiveRecord|AccessToken
  106. */
  107. public function findByAccessToken($token)
  108. {
  109. return AccessToken::find()
  110. ->where(['access_token' => $token, 'status' => StatusEnum::ENABLED])
  111. ->one();
  112. }
  113. /**
  114. * @param $access_token
  115. * @return string
  116. */
  117. protected function getCacheKey($access_token)
  118. {
  119. return 'apiAccessToken' . $access_token;
  120. }
  121. /**
  122. * 返回模型
  123. *
  124. * @param $member_id
  125. * @param $group
  126. * @return array|AccessToken|null|ActiveRecord
  127. */
  128. protected function findModel($member_id, $member_type, $group)
  129. {
  130. if (empty(($model = AccessToken::find()->where([
  131. 'member_id' => $member_id,
  132. 'member_type' => $member_type,
  133. 'group' => $group
  134. ])->andFilterWhere(['merchant_id' => $this->getMerchantId()])->one()))) {
  135. $model = new AccessToken();
  136. return $model->loadDefaultValues();
  137. }
  138. return $model;
  139. }
  140. }
粤ICP备19079148号