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
114 lines
3.4 KiB
PHP
114 lines
3.4 KiB
PHP
<?php
|
||
/**
|
||
* +----------------------------------------------------------------------
|
||
* | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
* +----------------------------------------------------------------------
|
||
* | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
|
||
* +----------------------------------------------------------------------
|
||
* | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
* +----------------------------------------------------------------------
|
||
* | Author: CRMEB Team <admin@crmeb.com>
|
||
* +----------------------------------------------------------------------
|
||
*/
|
||
|
||
namespace crmeb\services\upload;
|
||
|
||
/**
|
||
* 基础请求
|
||
* Class BaseClient
|
||
* @author 等风来
|
||
* @email 136327134@qq.com
|
||
* @date 2023/5/18
|
||
* @package crmeb\services\upload
|
||
*/
|
||
abstract class BaseClient
|
||
{
|
||
|
||
/**
|
||
* 是否解析为xml
|
||
* @var bool
|
||
*/
|
||
protected $isXml = true;
|
||
|
||
/**
|
||
*
|
||
* @var []callable
|
||
*/
|
||
protected $curlFn = [];
|
||
|
||
/**
|
||
* @param callable $curlFn
|
||
* @return $this
|
||
* @author 等风来
|
||
* @email 136327134@qq.com
|
||
* @date 2023/5/18
|
||
*/
|
||
public function middleware(callable $curlFn)
|
||
{
|
||
$this->curlFn[] = $curlFn;
|
||
return $this;
|
||
}
|
||
|
||
/**
|
||
* 发起请求
|
||
* @param string $url
|
||
* @param string $method
|
||
* @param array $data
|
||
* @param array $clientHeader
|
||
* @param int $timeout
|
||
* @return array|bool|SimpleXMLElement|mixed
|
||
*/
|
||
protected function requestClient(string $url, string $method, array $data = [], array $clientHeader = [], int $timeout = 10)
|
||
{
|
||
$headers = [];
|
||
foreach ($clientHeader as $key => $item) {
|
||
$headers[] = $key . ':' . $item;
|
||
}
|
||
$curl = curl_init($url);
|
||
//请求方式
|
||
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, $method);
|
||
//post请求
|
||
if (!empty($data['body'])) {
|
||
curl_setopt($curl, CURLOPT_POSTFIELDS, $data['body']);
|
||
} else if (!empty($data['json'])) {
|
||
curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data['json']));
|
||
} else {
|
||
$curlFn = $this->curlFn;
|
||
foreach ($curlFn as $item) {
|
||
if ($item instanceof \Closure) {
|
||
$curlFn($curl);
|
||
}
|
||
}
|
||
}
|
||
//超时时间
|
||
curl_setopt($curl, CURLOPT_TIMEOUT, $timeout);
|
||
//设置header头
|
||
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
|
||
|
||
curl_setopt($curl, CURLOPT_FAILONERROR, false);
|
||
//返回抓取数据
|
||
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
|
||
//输出header头信息
|
||
curl_setopt($curl, CURLOPT_HEADER, true);
|
||
//TRUE 时追踪句柄的请求字符串,从 PHP 5.1.3 开始可用。这个很关键,就是允许你查看请求header
|
||
curl_setopt($curl, CURLINFO_HEADER_OUT, true);
|
||
//https请求
|
||
if (1 == strpos("$" . $url, "https://")) {
|
||
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
|
||
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
|
||
}
|
||
[$content, $status] = [curl_exec($curl), curl_getinfo($curl)];
|
||
curl_close($curl);
|
||
$content = trim(substr($content, $status['header_size']));
|
||
if ($content) {
|
||
if ($this->isXml) {
|
||
return XML::parse($content);
|
||
} else {
|
||
return json_decode($content, true);
|
||
}
|
||
} else {
|
||
return true;
|
||
}
|
||
}
|
||
}
|