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

76 lines
2.6 KiB
TypeScript
Raw Normal View History

import db from '../config/database';
import { AuditService } from './AuditService';
import { AIService } from './AIService';
import { BlockchainTraceabilityService } from './BlockchainTraceabilityService';
import { FeatureGovernanceService } from '../core/governance/FeatureGovernanceService';
/**
* [BIZ_SOV_02] (Decentralized Arbitration)
* AI
*/
export class DecentralizedArbitrationService {
/**
*
*/
static async startArbitration(tenantId: string, disputeId: string, traceId: string): Promise<void> {
// Feature Flag Check
if (!(await FeatureGovernanceService.isEnabled('BIZ_SOV_ARBITRATION', tenantId))) {
return;
}
// 1. 提取区块链存证 (BIZ_TRADE_11 联动)
const evidence = await BlockchainTraceabilityService.getEvidenceChain(disputeId);
const evidenceHash = 'EVI-' + Math.random().toString(36).substring(7).toUpperCase();
// 2. AI 仲裁分析 (模拟调用 AGI 裁决引擎)
const arbitrationResult = await AIService.runArbitration(disputeId, evidence);
await db.transaction(async (trx) => {
// 3. 持久化仲裁记录
const [id] = await trx('cf_arbitration_records').insert({
tenant_id: tenantId,
dispute_id: disputeId,
evidence_hash: evidenceHash,
arbitration_logic: JSON.stringify({
evidenceSource: 'Blockchain',
reasoning: arbitrationResult.reasoning
}),
verdict: arbitrationResult.verdict,
awarded_amount: arbitrationResult.amount,
status: 'COMPLETED'
});
// 4. 执行资金结算 (联动 PayoutService)
if (arbitrationResult.verdict === 'WIN') {
// 模拟资金回笼
await trx('cf_payout_statements').insert({
tenant_id: tenantId,
amount: arbitrationResult.amount,
type: 'ARBITRATION_WIN',
status: 'PENDING'
});
}
// 审计记录
await AuditService.log({
tenant_id: tenantId,
action: 'ARBITRATION_COMPLETED',
target_type: 'TRADE_DISPUTE',
target_id: disputeId,
trace_id: traceId,
new_data: JSON.stringify({ verdict: arbitrationResult.verdict, amount: arbitrationResult.amount }),
metadata: JSON.stringify({ evidenceHash })
});
});
}
/**
*
*/
static async getArbitrationHistory(tenantId: string) {
return await db('cf_arbitration_records')
.where({ tenant_id: tenantId })
.orderBy('created_at', 'desc');
}
}