AssetManager.API/AssetManager.Services/IPortfolioFacade.cs
OpenClaw Agent 4ce29a1036 refactor: 架构优化 P0-P3
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
2026-03-15 12:54:05 +00:00

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);
}