feat(fsgx): 完成全部24项开发任务 Phase1-7
Phase1 后端核心:
- 新增 fsgx_v1.sql 迁移脚本(is_queue_goods/frozen_points/available_points/no_assess)
- SystemConfigServices 返佣设置扩展(周期人数/分档比例/范围/时机)
- StoreOrderCreateServices 周期循环佣金计算
- StoreOrderTakeServices 佣金发放后同步冻结积分
- StoreProductServices/StoreProduct 保存 is_queue_goods
Phase2 后端接口:
- GET /api/hjf/brokerage/progress 佣金周期进度
- GET /api/hjf/assets/overview 资产总览
- HjfPointsServices 每日 frozen_points 0.4‰ 释放定时任务
- PUT /adminapi/hjf/member/{uid}/no_assess 不考核接口
- GET /adminapi/hjf/points/release_log 积分日志接口
Phase3 前端清理:
- hjfCustom.js 路由精简(仅保留 points/log)
- hjfQueue.js/hjfMember.js API 清理/重定向至 CRMEB 原生接口
- pages.json 公排→推荐佣金/佣金记录/佣金规则
Phase4-5 前端改造:
- queue/status.vue 推荐佣金进度页整体重写
- 商品详情/订单确认/支付结果页文案与逻辑改造
- 个人中心/资产页/引导页/规则页文案改造
- HjfQueueProgress/HjfRefundNotice/HjfAssetCard 组件改造
- 推广中心嵌入佣金进度摘要
- hjfMockData.js 全量更新(公排字段→佣金字段)
Phase6 Admin 增强:
- 用户列表新增 frozen_points/available_points 列及不考核操作按钮
- hjfPoints.js USE_MOCK=false 对接真实积分日志接口
Phase7 配置文档:
- docs/fsgx-phase7-config-checklist.md 后台配置与全链路验收清单
Made-with: Cursor
This commit is contained in:
293
pro_v3.5.1_副本/crmeb/services/erp/AccessToken.php
Normal file
293
pro_v3.5.1_副本/crmeb/services/erp/AccessToken.php
Normal file
@@ -0,0 +1,293 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: CRMEB Team <admin@crmeb.com>
|
||||
// +----------------------------------------------------------------------
|
||||
|
||||
namespace crmeb\services\erp;
|
||||
|
||||
use crmeb\services\HttpService;
|
||||
use crmeb\services\CacheService;
|
||||
use think\facade\Config;
|
||||
use think\facade\Log;
|
||||
use think\helper\Str;
|
||||
use Psr\SimpleCache\CacheInterface;
|
||||
|
||||
/**
|
||||
* Class AccessTokenServeService
|
||||
* @package crmeb\services
|
||||
*/
|
||||
class AccessToken extends HttpService
|
||||
{
|
||||
/**
|
||||
* 配置
|
||||
* @var string
|
||||
*/
|
||||
protected $account;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
protected $secret;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
protected $apiUrl;
|
||||
|
||||
/**
|
||||
* 授权登录账号
|
||||
* @var string
|
||||
*/
|
||||
protected $authAccount;
|
||||
|
||||
/**
|
||||
* 授权登录密码
|
||||
* @var string
|
||||
*/
|
||||
protected $authPassword;
|
||||
|
||||
/**
|
||||
* @var CacheInterface
|
||||
*/
|
||||
protected $cache;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
protected $accessToken;
|
||||
|
||||
/**
|
||||
* 驱动类型
|
||||
* @var string
|
||||
*/
|
||||
protected $name;
|
||||
|
||||
/**
|
||||
* 配置文件名
|
||||
* @var string
|
||||
*/
|
||||
protected $configFile;
|
||||
|
||||
/**
|
||||
* 缓存token
|
||||
* @var string
|
||||
*/
|
||||
protected $cacheTokenPrefix = "_crmeb_erp";
|
||||
|
||||
/**
|
||||
* 刷新token
|
||||
* @var string
|
||||
*/
|
||||
protected $cacheRefreshTokenPrefix = "_crmeb_erp_re";
|
||||
|
||||
/**
|
||||
* AccessTokenServeService constructor.
|
||||
* AccessToken constructor.
|
||||
* @param string $name
|
||||
* @param string $configFile
|
||||
* @param array $config
|
||||
* @param CacheInterface|null $cache
|
||||
*/
|
||||
public function __construct(string $name, string $configFile, array $config, ?CacheInterface $cache = null)
|
||||
{
|
||||
if (!$cache) {
|
||||
/** @var CacheService $cache */
|
||||
$cache = app()->make(CacheService::class);
|
||||
}
|
||||
$this->account = isset($config["app_key"]) ? $config["app_key"] : config($configFile . '.stores.' . $name . '.app_key', '');
|
||||
$this->secret = isset($config["secret"]) ? $config["secret"] : config($configFile . '.stores.' . $name . '.secret', '');
|
||||
$this->authAccount = $config['login_account'] ?? config($configFile . '.stores.' . $name . '.login_account', '');
|
||||
$this->authPassword = $config['login_password'] ?? config($configFile . '.stores.' . $name . '.login_password', '');
|
||||
$this->cache = $cache;
|
||||
$this->name = $name;
|
||||
$this->configFile = $configFile;
|
||||
$this->apiUrl = Config::get($configFile . '.stores.' . $name . '.url', '');
|
||||
$this->apiUrl = 'https://openapi.jushuitan.com';
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取配置
|
||||
* @return array
|
||||
*/
|
||||
public function getConfig(): array
|
||||
{
|
||||
return [
|
||||
'account' => $this->account,
|
||||
'secret' => $this->secret
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取请求链接
|
||||
* @param string $url
|
||||
* @return string
|
||||
*/
|
||||
public function getApiUrl(string $url = ''): string
|
||||
{
|
||||
return $url ? $this->apiUrl . $url : $this->apiUrl;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取appKey
|
||||
* @return string
|
||||
*/
|
||||
public function getAccount(): string
|
||||
{
|
||||
return $this->account;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return mixed|string
|
||||
*/
|
||||
public function getAuthAccount()
|
||||
{
|
||||
return $this->authAccount;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return mixed|string
|
||||
*/
|
||||
public function getAuthPassword()
|
||||
{
|
||||
return $this->authPassword;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取appSecret
|
||||
* @return string
|
||||
*/
|
||||
public function getSecret(): string
|
||||
{
|
||||
return $this->secret;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取token
|
||||
* @return string
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function getAccessToken(): ?string
|
||||
{
|
||||
if (isset($this->accessToken)) {
|
||||
return $this->accessToken;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see getJushuitanAccessToken
|
||||
*/
|
||||
$action = 'get' . Str::studly($this->name) . 'AccessToken';
|
||||
if (method_exists($this, $action)) {
|
||||
return $this->{$action}();
|
||||
} else {
|
||||
throw new \RuntimeException(__CLASS__ . '->' . $action . '(),Method not worn in');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取聚水潭token
|
||||
* @return mixed|null|string
|
||||
* @throws \Exception
|
||||
*/
|
||||
protected function getJushuitanAccessToken(): ?string
|
||||
{
|
||||
//读缓存
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . $this->cacheTokenPrefix);
|
||||
$this->accessToken = $this->cache->get($cacheKey);
|
||||
|
||||
//需要前端异步授权
|
||||
if (empty($this->accessToken)) {
|
||||
throw new \RuntimeException("请跳转授权", 610);
|
||||
}
|
||||
|
||||
return $this->accessToken;
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置AccessToken缓存
|
||||
* @param string $accessToken
|
||||
* @param int $expiresIn
|
||||
* @return bool
|
||||
*/
|
||||
public function setAccessToken(string $accessToken, int $expiresIn): bool
|
||||
{
|
||||
if (empty($accessToken) || !is_numeric($expiresIn) || $expiresIn <= 0) {
|
||||
return false;
|
||||
}
|
||||
//写缓存
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . $this->cacheTokenPrefix);
|
||||
$this->cache->redisHandler()->tag('erp_shop')->set($cacheKey, $accessToken, $expiresIn);
|
||||
|
||||
$this->accessToken = $accessToken;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置AccessToken提前过期缓存
|
||||
* @param string $accessToken
|
||||
* @param int $expiresIn
|
||||
* @return bool
|
||||
*/
|
||||
public function setTokenExpire(string $accessToken, int $expiresIn): bool
|
||||
{
|
||||
if (empty($accessToken) || !is_numeric($expiresIn) || $expiresIn <= 0) {
|
||||
return false;
|
||||
}
|
||||
//写缓存
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . '_epr_expire');
|
||||
$this->cache->redisHandler()->tag('erp_shop')->set($cacheKey, $accessToken, $expiresIn);
|
||||
|
||||
$this->accessToken = $accessToken;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取提前过期缓存
|
||||
* @return bool|mixed|null
|
||||
* @throws \Psr\SimpleCache\InvalidArgumentException
|
||||
*/
|
||||
public function getTokenExpire()
|
||||
{
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . '_epr_expire');
|
||||
return $this->cache->get($cacheKey);
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置refreshToken缓存
|
||||
* @param string refreshToken
|
||||
* @return bool
|
||||
*/
|
||||
public function setRefreshToken(string $refreshToken): bool
|
||||
{
|
||||
if (empty($refreshToken)) {
|
||||
return false;
|
||||
}
|
||||
//写缓存
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . $this->cacheRefreshTokenPrefix);
|
||||
$this->cache->redisHandler()->tag('erp_shop')->set($cacheKey, $refreshToken);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取refreshToken缓存
|
||||
* @param string refreshToken
|
||||
* @return string
|
||||
*/
|
||||
public function getRefreshToken(): string
|
||||
{
|
||||
//读缓存
|
||||
$cacheKey = md5($this->account . '_' . $this->secret . $this->cacheRefreshTokenPrefix);
|
||||
|
||||
return $this->cache->get($cacheKey);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user