P0 - 安全修复: - 移除硬编码 API Key,启动时校验必填环境变量 P1 - 高优先级: - Entity 拆分:Position.cs, Transaction.cs 独立文件 - Controller Facade 封装:IPortfolioFacade 减少依赖注入 P2 - 中优先级: - Repository 抽象:IPortfolioRepository, IMarketDataRepository - MarketDataService 拆分:组合模式整合 Tencent/Tiingo/OKX P3 - 低优先级: - DTO 命名规范:统一 PascalCase - 单元测试框架:xUnit + Moq + FluentAssertions
60 lines
1.9 KiB
C#
60 lines
1.9 KiB
C#
using AssetManager.Models.DTOs;
|
|
|
|
namespace AssetManager.Services;
|
|
|
|
/// <summary>
|
|
/// 投资组合门面接口 - 整合多个服务,简化 Controller 调用
|
|
/// </summary>
|
|
public interface IPortfolioFacade
|
|
{
|
|
/// <summary>
|
|
/// 创建投资组合
|
|
/// </summary>
|
|
Task<CreatePortfolioResponse> CreatePortfolioAsync(CreatePortfolioRequest request, string userId);
|
|
|
|
/// <summary>
|
|
/// 获取投资组合详情
|
|
/// </summary>
|
|
Task<PortfolioDetailResponse> GetPortfolioDetailAsync(string portfolioId, string userId);
|
|
|
|
/// <summary>
|
|
/// 获取投资组合列表
|
|
/// </summary>
|
|
Task<List<PortfolioListItem>> GetPortfolioListAsync(string userId);
|
|
|
|
/// <summary>
|
|
/// 获取净值历史
|
|
/// </summary>
|
|
Task<NavHistoryResponse> GetNavHistoryAsync(string portfolioId, NavHistoryRequest request, string userId);
|
|
|
|
/// <summary>
|
|
/// 创建交易
|
|
/// </summary>
|
|
Task<TransactionItem> CreateTransactionAsync(string portfolioId, CreateTransactionRequest request, string userId);
|
|
|
|
/// <summary>
|
|
/// 获取交易列表
|
|
/// </summary>
|
|
Task<List<TransactionItem>> GetTransactionsAsync(string portfolioId, GetTransactionsRequest request, string userId);
|
|
|
|
/// <summary>
|
|
/// 获取策略信号
|
|
/// </summary>
|
|
Task<StrategySignalResponse> GetStrategySignalAsync(string portfolioId, string userId);
|
|
|
|
/// <summary>
|
|
/// 删除投资组合
|
|
/// </summary>
|
|
Task<bool> DeletePortfolioAsync(string portfolioId, string userId);
|
|
|
|
/// <summary>
|
|
/// 创建投资组合(含用户验证和币种校验)
|
|
/// </summary>
|
|
Task<CreatePortfolioResponse> CreatePortfolioWithValidationAsync(CreatePortfolioRequest request, string userId);
|
|
|
|
/// <summary>
|
|
/// 回填净值历史
|
|
/// </summary>
|
|
Task<BackfillNavResponse> BackfillNavHistoryAsync(string portfolioId, string userId, bool force = false);
|
|
}
|