Files
makemd/server/src/services/DynamicRecompositionService.ts
wurenzhi 15ee1758f5 refactor: 重构项目结构并优化类型定义
- 移除extension模块,将功能迁移至node-agent
- 修复类型导出问题,使用export type明确类型导出
- 统一数据库连接方式,从直接导入改为使用config/database
- 更新文档中的项目结构描述
- 添加多个服务的实用方法,如getForecast、getBalances等
- 修复类型错误和TS1205警告
- 优化RedisService调用方式
- 添加新的实体类型定义
- 更新审计日志格式,统一字段命名
2026-03-21 15:04:06 +08:00

97 lines
3.2 KiB
TypeScript

import db from '../config/database';
import { AuditService } from './AuditService';
import { AIService } from './AIService';
/**
* [BIZ_ECO_04] 基于 AGI 的全球供应链动态重组 (Dynamic Supply Chain Recomposition)
* 负责实时监控全球风险,自动触发供应链节点的替换与重组(如:当某地区罢工时,自动重组至备选工厂与航线)
*/
export class DynamicRecompositionService {
/**
* 触发供应链动态重组分析
*/
static async triggerRecomposition(
tenantId: string,
category: string,
reason: string,
traceId: string
): Promise<void> {
// 1. 获取当前供应链节点快照
const currentNodes = await db('cf_autonomous_eco_contracts')
.where({ tenant_id: tenantId, status: 'SIGNED' })
.limit(10);
// 2. AGI 分析重组方案 (模拟)
const recompositionLogic = await AIService.analyzeSupplyChainRecomposition(tenantId, category, reason);
if (recompositionLogic.needsRecomposition) {
await db.transaction(async (trx) => {
// 3. 记录重组提案
const [id] = await trx('cf_dynamic_recomposition').insert({
tenant_id: tenantId,
category,
current_nodes: JSON.stringify(currentNodes),
new_nodes: JSON.stringify(recompositionLogic.proposedNodes),
logic_snapshot: recompositionLogic.reasoning,
status: 'PROPOSED'
});
// 审计记录
await AuditService.log({
tenantId: tenantId,
action: 'SUPPLY_CHAIN_RECOMPOSITION_PROPOSED',
module: 'SUPPLY_CHAIN',
resourceType: 'SUPPLY_CHAIN',
resourceId: id.toString(),
traceId: traceId,
userId: 'system',
result: 'success',
source: 'console',
afterSnapshot: { reason, proposedNodes: recompositionLogic.proposedNodes },
metadata: { logic: recompositionLogic.reasoning }
});
});
}
}
/**
* 执行重组方案 (BIZ_ECO_04)
*/
static async executeRecomposition(recompositionId: number, tenantId: string, traceId: string): Promise<void> {
const proposal = await db('cf_dynamic_recomposition').where({ id: recompositionId }).first();
if (!proposal) return;
await db.transaction(async (trx) => {
// 模拟执行重组:更新合同状态,激活新供应商
await trx('cf_dynamic_recomposition').where({ id: recompositionId }).update({
status: 'COMPLETED',
updated_at: db.fn.now()
});
// 审计记录
await AuditService.log({
tenantId: tenantId,
action: 'SUPPLY_CHAIN_RECOMPOSITION_EXECUTED',
module: 'SUPPLY_CHAIN',
resourceType: 'SUPPLY_CHAIN',
resourceId: recompositionId.toString(),
traceId: traceId,
userId: 'system',
result: 'success',
source: 'console',
afterSnapshot: { status: 'COMPLETED' },
metadata: { category: proposal.category }
});
});
}
/**
* 获取租户所有重组历史
*/
static async getRecompositionHistory(tenantId: string) {
return await db('cf_dynamic_recomposition')
.where({ tenant_id: tenantId })
.orderBy('created_at', 'desc');
}
}