ThostFtdcMdApi.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. /////////////////////////////////////////////////////////////////////////
  2. ///@system 新一代交易所系统
  3. ///@company 上海期货信息技术有限公司
  4. ///@file ThostFtdcMdApi.h
  5. ///@brief 定义了客户端接口
  6. ///@history
  7. ///20060106 赵鸿昊 创建该文件
  8. /////////////////////////////////////////////////////////////////////////
  9. #if !defined(THOST_FTDCMDAPI_H)
  10. #define THOST_FTDCMDAPI_H
  11. #if _MSC_VER > 1000
  12. #pragma once
  13. #endif // _MSC_VER > 1000
  14. #include "ThostFtdcUserApiStruct.h"
  15. #if defined(ISLIB) && defined(WIN32)
  16. #ifdef LIB_MD_API_EXPORT
  17. #define MD_API_EXPORT __declspec(dllexport)
  18. #else
  19. #define MD_API_EXPORT __declspec(dllimport)
  20. #endif
  21. #else
  22. #define MD_API_EXPORT
  23. #endif
  24. class CThostFtdcMdSpi
  25. {
  26. public:
  27. ///当客户端与交易后台建立起通信连接时(还未登录前),该方法被调用。
  28. virtual void OnFrontConnected(){};
  29. ///当客户端与交易后台通信连接断开时,该方法被调用。当发生这个情况后,API会自动重新连接,客户端可不做处理。
  30. ///@param nReason 错误原因
  31. /// 0x1001 网络读失败
  32. /// 0x1002 网络写失败
  33. /// 0x2001 接收心跳超时
  34. /// 0x2002 发送心跳失败
  35. /// 0x2003 收到错误报文
  36. virtual void OnFrontDisconnected(int nReason){};
  37. ///心跳超时警告。当长时间未收到报文时,该方法被调用。
  38. ///@param nTimeLapse 距离上次接收报文的时间
  39. virtual void OnHeartBeatWarning(int nTimeLapse){};
  40. ///登录请求响应
  41. virtual void OnRspUserLogin(CThostFtdcRspUserLoginField *pRspUserLogin, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast) {};
  42. ///登出请求响应
  43. virtual void OnRspUserLogout(CThostFtdcUserLogoutField *pUserLogout, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast) {};
  44. ///错误应答
  45. virtual void OnRspError(CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast) {};
  46. ///订阅行情应答
  47. virtual void OnRspSubMarketData(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast) {};
  48. ///取消订阅行情应答
  49. virtual void OnRspUnSubMarketData(CThostFtdcSpecificInstrumentField *pSpecificInstrument, CThostFtdcRspInfoField *pRspInfo, int nRequestID, bool bIsLast) {};
  50. ///深度行情通知
  51. virtual void OnRtnDepthMarketData(CThostFtdcDepthMarketDataField *pDepthMarketData) {};
  52. };
  53. class MD_API_EXPORT CThostFtdcMdApi
  54. {
  55. public:
  56. ///创建MdApi
  57. ///@param pszFlowPath 存贮订阅信息文件的目录,默认为当前目录
  58. ///@return 创建出的UserApi
  59. ///modify for udp marketdata
  60. static CThostFtdcMdApi *CreateFtdcMdApi(const char *pszFlowPath = "", const bool bIsUsingUdp=false, const bool bIsMulticast=false);
  61. ///删除接口对象本身
  62. ///@remark 不再使用本接口对象时,调用该函数删除接口对象
  63. virtual void Release() = 0;
  64. ///初始化
  65. ///@remark 初始化运行环境,只有调用后,接口才开始工作
  66. virtual void Init() = 0;
  67. ///等待接口线程结束运行
  68. ///@return 线程退出代码
  69. virtual int Join() = 0;
  70. ///获取当前交易日
  71. ///@retrun 获取到的交易日
  72. ///@remark 只有登录成功后,才能得到正确的交易日
  73. virtual const char *GetTradingDay() = 0;
  74. ///注册前置机网络地址
  75. ///@param pszFrontAddress:前置机网络地址。
  76. ///@remark 网络地址的格式为:“protocol://ipaddress:port”,如:”tcp://127.0.0.1:17001”。
  77. ///@remark “tcp”代表传输协议,“127.0.0.1”代表服务器地址。”17001”代表服务器端口号。
  78. virtual void RegisterFront(char *pszFrontAddress) = 0;
  79. ///注册名字服务器网络地址
  80. ///@param pszNsAddress:名字服务器网络地址。
  81. ///@remark 网络地址的格式为:“protocol://ipaddress:port”,如:”tcp://127.0.0.1:12001”。
  82. ///@remark “tcp”代表传输协议,“127.0.0.1”代表服务器地址。”12001”代表服务器端口号。
  83. ///@remark RegisterNameServer优先于RegisterFront
  84. virtual void RegisterNameServer(char *pszNsAddress) = 0;
  85. ///注册名字服务器用户信息
  86. ///@param pFensUserInfo:用户信息。
  87. virtual void RegisterFensUserInfo(CThostFtdcFensUserInfoField * pFensUserInfo) = 0;
  88. ///注册回调接口
  89. ///@param pSpi 派生自回调接口类的实例
  90. virtual void RegisterSpi(CThostFtdcMdSpi *pSpi) = 0;
  91. ///订阅行情。
  92. ///@param ppInstrumentID 合约ID
  93. ///@param nCount 要订阅/退订行情的合约个数
  94. ///@remark
  95. virtual int SubscribeMarketData(char *ppInstrumentID[], int nCount) = 0;
  96. ///退订行情。
  97. ///@param ppInstrumentID 合约ID
  98. ///@param nCount 要订阅/退订行情的合约个数
  99. ///@remark
  100. virtual int UnSubscribeMarketData(char *ppInstrumentID[], int nCount) = 0;
  101. ///用户登录请求
  102. virtual int ReqUserLogin(CThostFtdcReqUserLoginField *pReqUserLoginField, int nRequestID) = 0;
  103. ///登出请求
  104. virtual int ReqUserLogout(CThostFtdcUserLogoutField *pUserLogout, int nRequestID) = 0;
  105. protected:
  106. ~CThostFtdcMdApi(){};
  107. };
  108. #endif