Files
makemd/server/src/api/controllers/ArbitrageController.ts

70 lines
2.2 KiB
TypeScript
Raw Normal View History

import { Request, Response } from 'express';
import { ArbitrageHeatmapService } from '../../domains/Arbitrage/ArbitrageHeatmapService';
import { ArbitrageService } from '../../domains/Arbitrage/ArbitrageService';
import { SupplyChainService } from '../../services/SupplyChainService';
import { logger } from '../../utils/logger';
/**
* [BIZ_ARB_01] & [UX_BI_05]
*/
export class ArbitrageController {
/**
* (Heatmap)
* GET /api/v1/arbitrage/heatmap
*/
static async getHeatmap(req: Request, res: Response) {
const tenantId = req.headers['x-tenant-id'] as string;
if (!tenantId) {
return res.status(400).json({ success: false, error: 'x-tenant-id header is required' });
}
try {
const heatmap = await ArbitrageHeatmapService.getHeatmapData(tenantId);
const trend = await ArbitrageHeatmapService.getTrendHeatmap(tenantId, 14);
return res.json({
success: true,
data: {
heatmap,
trend
}
});
} catch (err: any) {
logger.error(`[ArbitrageController] Get heatmap failed: ${err.message}`);
return res.status(500).json({ success: false, error: 'Internal server error' });
}
}
/**
* [CORE_AI_50] AGI
* POST /api/v1/arbitrage/visual-sourcing
*/
static async visualSourcing(req: Request, res: Response) {
const { imageUrl } = req.body;
if (!imageUrl) {
return res.status(400).json({ success: false, error: 'imageUrl is required' });
}
try {
const results = await SupplyChainService.visualSourcing(imageUrl);
return res.json({ success: true, data: results });
} catch (err: any) {
return res.status(500).json({ success: false, error: err.message });
}
}
/**
* ( DomainBootstrap )
*/
static async init(req: Request, res: Response) {
try {
await ArbitrageService.initTable();
return res.json({ success: true, message: 'Arbitrage tables initialized' });
} catch (err: any) {
return res.status(500).json({ success: false, error: err.message });
}
}
}