Files
huangjingfen/pro_v3.5.1_副本/crmeb/services/wechat/config/WorkConfig.php

163 lines
3.9 KiB
PHP
Raw Normal View History

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
2026-03-23 22:32:19 +08:00
<?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\wechat\config;
use crmeb\services\wechat\contract\ConfigHandlerInterface;
use crmeb\services\wechat\contract\WorkAppConfigHandlerInterface;
use crmeb\services\wechat\DefaultConfig;
use JetBrains\PhpStorm\ArrayShape;
use JetBrains\PhpStorm\Pure;
/**
* 企业微信配置
* Class WorkConfig
* @package crmeb\services\wechat\config
*/
class WorkConfig implements ConfigHandlerInterface
{
//应用
const TYPE_APP = 'app';
//客户联系
const TYPE_USER = 'user';
//通讯录同步
const TYPE_ADDRESS = 'address';
//客服
const TYPE_KEFU = 'kefu';
//审批
const TYPE_APPROVE = 'approve';
//会议室
const TYPE_MEETING = 'meeting';
//自建应用
const TYPE_USER_APP = 'build';
/**
* @var string
*/
public string $corpId;
/**
* @var string
*/
public string $token;
/**
* @var string
*/
public string $aesKey;
/**
* @var string
*/
protected string $responseType = 'array';
/**
* @var HttpCommonConfig
*/
protected HttpCommonConfig $httpConfig;
/**
* @var bool
*/
protected bool $init = false;
/**
* @var string
*/
protected string $handler;
/**
* @var array
*/
protected array $appConfig;
/**
* WorkConfig constructor.
* @param HttpCommonConfig $commonConfig
*/
public function __construct(HttpCommonConfig $commonConfig)
{
$this->httpConfig = $commonConfig;
$this->init();
}
/**
* @author 等风来
* @email 136327134@qq.com
* @date 2023/9/18
*/
protected function init()
{
if ($this->init) {
return;
}
$this->init = true;
$this->corpId = $this->httpConfig->getConfig(DefaultConfig::WORK_CORP_ID, '');
$this->token = $this->httpConfig->getConfig('work.token', '');
$this->aesKey = $this->httpConfig->getConfig('work.key', '');
}
/**
* 获取全部值
* @return array
*/
#[ArrayShape([
'corp_id' => "string",
'token' => "string",
'aes_key' => "string",
'response_type' => "string",
'log' => "array",
'http' => "bool[]"
])]
#[Pure]
public function all(): array
{
return [
'corp_id' => $this->corpId,
'token' => $this->token,
'aes_key' => $this->aesKey,
'response_type' => $this->responseType,
'http' => $this->httpConfig->all()
];
}
/**
* 获取应用配置
* @param string $type
* @return array
*/
public function getAppConfig(string $type): array
{
if (!isset($this->appConfig[$type])) {
/** @var WorkAppConfigHandlerInterface $make */
$make = app()->make($this->handler);
if (!$this->corpId) {
$this->init();
}
$this->appConfig[$type] = $make->getAppConfig($this->corpId, $type);
}
return $this->appConfig[$type];
}
/**
* 设置
* @param string $handler
* @return $this
*/
public function setHandler(string $handler): self
{
$this->handler = $handler;
return $this;
}
}