Files
makemd/server/src/services/EcoValueSharingService.ts

88 lines
2.8 KiB
TypeScript
Raw Normal View History

import db from '../config/database';
import { AuditService } from './AuditService';
import { AIService } from './AIService';
import { FeatureGovernanceService } from '../core/governance/FeatureGovernanceService';
/**
* [BIZ_ECO_02] (Eco Value Sharing)
*
*/
export class EcoValueSharingService {
/**
*
*/
static async calculateAndShare(
tenantId: string,
supplierId: string,
totalIncrementalProfit: number,
traceId: string
): Promise<number> {
// Feature Flag Check
if (!(await FeatureGovernanceService.isEnabled('BIZ_ECO_VALUE_SHARING', tenantId))) {
return 0;
}
// 1. 获取博弈因子 (租户忠诚度、供应商交期稳定性、质量分)
// 模拟数据:替代 AIService.getEcoGameFactors
const gameFactors = {
tenantLoyalty: 0.85,
supplierDeliveryStability: 0.92,
qualityScore: 0.95
};
// 2. 运行博弈论分配模型 (Shapley Value 或 Nash Equilibrium 模拟)
// 模拟数据:替代 AIService.runValueSharingGame
const supplierShare = totalIncrementalProfit * 0.3; // 假设供应商分享30%
const sharingLogic = {
supplierAmount: supplierShare,
tenantAmount: totalIncrementalProfit - supplierShare,
model: 'Nash Equilibrium',
factors: gameFactors
};
await db.transaction(async (trx) => {
// 3. 记录分配快照
const [id] = await trx('cf_eco_value_sharing').insert({
tenant_id: tenantId,
supplier_id: supplierId,
shared_profit_amount: supplierShare,
sharing_logic: JSON.stringify(sharingLogic),
status: 'CALCULATED'
});
// 4. 执行资金拨付 (模拟)
await trx('cf_eco_value_sharing')
.where({ id })
.update({
status: 'TRANSFERRED',
updated_at: db.fn.now()
});
// 5. 审计记录
await AuditService.log({
tenantId: tenantId,
userId: 'SYSTEM_BOT',
module: 'ECO_VALUE_SHARING',
action: 'ECO_VALUE_SHARED',
resourceType: 'SUPPLIER_RELATION',
resourceId: supplierId,
traceId: traceId,
afterSnapshot: JSON.stringify({ sharedAmount: supplierShare, totalProfit: totalIncrementalProfit }),
result: 'success',
source: 'node',
metadata: { model: 'Nash Equilibrium' }
});
});
return supplierShare;
}
/**
*
*/
static async getSharingHistory(tenantId: string) {
return await db('cf_eco_value_sharing')
.where({ tenant_id: tenantId })
.orderBy('created_at', 'desc');
}
}