2026-03-17 22:07:19 +08:00
|
|
|
|
import db from '../config/database';
|
2026-03-18 13:38:05 +08:00
|
|
|
|
import { logger } from '../utils/logger';
|
2026-03-17 22:07:19 +08:00
|
|
|
|
import { AuditService } from './AuditService';
|
|
|
|
|
|
import { AIService } from './AIService';
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* [BIZ_SOV_04] 自治贸易主权合规治理引擎 (Sovereignty Governance)
|
|
|
|
|
|
* 负责实时扫描租户的贸易行为,确保其符合全球法规、伦理准则及主权安全策略,并自动执行熔断或修复
|
|
|
|
|
|
*/
|
|
|
|
|
|
export class SovereigntyGovernanceService {
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 执行合规性扫描
|
|
|
|
|
|
*/
|
|
|
|
|
|
static async performGovernanceCheck(tenantId: string, traceId: string): Promise<number> {
|
|
|
|
|
|
// 1. 获取租户最近贸易活动快照
|
|
|
|
|
|
const activities = await db('cf_orders').where({ tenant_id: tenantId }).limit(100);
|
|
|
|
|
|
|
|
|
|
|
|
// 2. 调用 AGI 治理引擎进行多维度审计 (法规、伦理、政治风险)
|
2026-03-18 13:38:05 +08:00
|
|
|
|
// 模拟审计结果
|
|
|
|
|
|
const auditResult = {
|
|
|
|
|
|
globalScore: 95,
|
|
|
|
|
|
violations: [
|
|
|
|
|
|
{
|
|
|
|
|
|
type: 'COMPLIANCE',
|
|
|
|
|
|
description: 'Sample violation',
|
|
|
|
|
|
suggestedAction: 'MONITOR'
|
|
|
|
|
|
}
|
|
|
|
|
|
]
|
|
|
|
|
|
};
|
2026-03-17 22:07:19 +08:00
|
|
|
|
|
|
|
|
|
|
await db.transaction(async (trx) => {
|
|
|
|
|
|
// 3. 记录治理事件
|
|
|
|
|
|
for (const violation of auditResult.violations) {
|
|
|
|
|
|
await trx('cf_sov_governance').insert({
|
|
|
|
|
|
tenant_id: tenantId,
|
|
|
|
|
|
policy_type: violation.type,
|
|
|
|
|
|
violation_description: violation.description,
|
|
|
|
|
|
action_taken: violation.suggestedAction,
|
|
|
|
|
|
compliance_score: auditResult.globalScore
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
// 4. 自动执行治理动作 (如熔断高风险订单)
|
|
|
|
|
|
if (violation.suggestedAction === 'FREEZE') {
|
|
|
|
|
|
await AuditService.log({
|
2026-03-18 13:38:05 +08:00
|
|
|
|
tenantId,
|
|
|
|
|
|
userId: 'SYSTEM',
|
|
|
|
|
|
module: 'SOVEREIGNTY',
|
2026-03-17 22:07:19 +08:00
|
|
|
|
action: 'SOVEREIGN_GOVERNANCE_FREEZE',
|
2026-03-18 13:38:05 +08:00
|
|
|
|
resourceType: 'TENANT_ACCOUNT',
|
|
|
|
|
|
resourceId: tenantId,
|
|
|
|
|
|
traceId,
|
|
|
|
|
|
afterSnapshot: { reason: violation.description },
|
|
|
|
|
|
result: 'success',
|
|
|
|
|
|
source: 'node',
|
|
|
|
|
|
metadata: { score: auditResult.globalScore }
|
2026-03-17 22:07:19 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
return auditResult.globalScore;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 获取租户合规性画像
|
|
|
|
|
|
*/
|
|
|
|
|
|
static async getComplianceProfile(tenantId: string) {
|
|
|
|
|
|
const latest = await db('cf_sov_governance')
|
|
|
|
|
|
.where({ tenant_id: tenantId })
|
|
|
|
|
|
.orderBy('created_at', 'desc')
|
|
|
|
|
|
.first();
|
|
|
|
|
|
|
|
|
|
|
|
const history = await db('cf_sov_governance')
|
|
|
|
|
|
.where({ tenant_id: tenantId })
|
|
|
|
|
|
.orderBy('created_at', 'desc')
|
|
|
|
|
|
.limit(10);
|
|
|
|
|
|
|
|
|
|
|
|
return { latest, history };
|
|
|
|
|
|
}
|
2026-03-18 13:38:05 +08:00
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 创建提案
|
|
|
|
|
|
*/
|
|
|
|
|
|
static async createProposal(tenantId: string, proposalType: string, data: any, traceId: string) {
|
|
|
|
|
|
logger.info(`[SovereigntyGovernanceService] Creating proposal for tenant: ${tenantId}, type: ${proposalType}`);
|
|
|
|
|
|
|
|
|
|
|
|
const proposalId = `proposal_${tenantId}_${Date.now()}`;
|
|
|
|
|
|
|
|
|
|
|
|
await db('cf_sov_governance').insert({
|
|
|
|
|
|
tenant_id: tenantId,
|
|
|
|
|
|
policy_type: proposalType,
|
|
|
|
|
|
violation_description: `Proposal: ${proposalType}`,
|
|
|
|
|
|
action_taken: 'PENDING',
|
|
|
|
|
|
compliance_score: 100
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
await AuditService.log({
|
|
|
|
|
|
tenantId,
|
|
|
|
|
|
userId: 'SYSTEM',
|
|
|
|
|
|
module: 'SOVEREIGNTY',
|
|
|
|
|
|
action: 'CREATE_PROPOSAL',
|
|
|
|
|
|
resourceType: 'PROPOSAL',
|
|
|
|
|
|
resourceId: proposalId,
|
|
|
|
|
|
traceId,
|
|
|
|
|
|
afterSnapshot: { proposalType, data },
|
|
|
|
|
|
result: 'success',
|
|
|
|
|
|
source: 'console'
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
return proposalId;
|
|
|
|
|
|
}
|
2026-03-17 22:07:19 +08:00
|
|
|
|
}
|