UNPKG

futu-sdk

Version:

futu-api 的高性能精简易用版;基于*.proto静态编译,提供高性能的多层封装但层层开放的易用接口,获取最原始最完整的量化数据;相较于Python, nodejs更接近Web, 从而轻而易举搭建一个可视化交易站点,这是进行可控量化交易的不二选择。

313 lines (308 loc) 15.6 kB
import WebSocket from 'ws'; import * as proto from 'futu-sdk/proto'; interface WsUrl { host?: string; /** 默认WebSocket端口是33333, 不要传API端口11111 */ port?: number; /** WebSocket密钥,必传(即可ssl设为false也要传,否则不能建立连接) */ key: string; } type Message = { protobuf: Uint8Array; errorCode: number; errorMessage: string; }; type RequestFn = (cmd: number, buf: Uint8Array, callback: (message: Message) => void) => () => void; declare class WebRequest { private request; private subscribe; constructor(requestFn: Promise<RequestFn>); /** * @brief 初始化连接 * @param [in] stReq 请求包,具体字段请参考InitWebSocket.proto协议 */ InitWebSocket: (c2s: proto.InitWebSocket.IRequest["c2s"], timeout?: number) => Promise<proto.InitWebSocket.IResponse["s2c"]>; /** * @brief 订阅,反订阅 * @param [in] stReq 请求包,具体字段请参考Qot_Sub.proto协议 */ Sub: (c2s: proto.Qot_Sub.IRequest["c2s"]) => Generator<Promise<proto.Qot_Sub.IResponse["s2c"]>>; /** * @brief 获取交易帐号列表 * @param [in] stReq 请求包,具体字段请参考Trd_GetAccList.proto协议 */ GetAccList: (c2s: proto.Trd_GetAccList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetAccList.IResponse["s2c"]>; /** * @brief 解锁,针对OpenD解锁一次即可 * @param [in] stReq 请求包,具体字段请参考Trd_UnlockTrade.proto协议 */ UnlockTrade: (c2s: proto.Trd_UnlockTrade.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_UnlockTrade.IResponse["s2c"]>; /** * @brief 订阅接收推送数据的交易账户 * @param [in] stReq 请求包,具体字段请参考Trd_SubAccPush.proto协议 */ SubAccPush: (c2s: proto.Trd_SubAccPush.IRequest["c2s"]) => Generator<Promise<proto.Trd_SubAccPush.IResponse["s2c"]>>; /** * @brief 获取账户资金 * @param [in] stReq 请求包,具体字段请参考Trd_GetFunds.proto协议 */ GetFunds: (c2s: proto.Trd_GetFunds.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetFunds.IResponse["s2c"]>; /** * @brief 获取账户持仓 * @param [in] stReq 请求包,具体字段请参考Trd_GetPositionList.proto协议 */ GetPositionList: (c2s: proto.Trd_GetPositionList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetPositionList.IResponse["s2c"]>; /** * @brief 获取最大交易数量 * @param [in] stReq 请求包,具体字段请参考Trd_GetMaxTrdQtys.proto协议 */ GetMaxTrdQtys: (c2s: proto.Trd_GetMaxTrdQtys.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetMaxTrdQtys.IResponse["s2c"]>; /** * @brief 获取当日订单列表 * @param [in] stReq 请求包,具体字段请参考Trd_GetOrderList.proto协议 */ GetOrderList: (c2s: proto.Trd_GetOrderList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetOrderList.IResponse["s2c"]>; /** * @brief 下单 * @param [in] stReq 请求包,具体字段请参考Trd_PlaceOrder.proto协议,PacketID不需填写,发送时接口会填 */ PlaceOrder: (c2s: proto.Trd_PlaceOrder.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_PlaceOrder.IResponse["s2c"]>; /** * @brief 修改订单 * @param [in] stReq 请求包,具体字段请参考Trd_ModifyOrder.proto协议,PacketID不需填写,发送时接口会填 */ ModifyOrder: (c2s: proto.Trd_ModifyOrder.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_ModifyOrder.IResponse["s2c"]>; /** * @brief 获取当日成交列表 * @param [in] stReq 请求包,具体字段请参考Trd_GetOrderFillList.proto协议 */ GetOrderFillList: (c2s: proto.Trd_GetOrderFillList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetOrderFillList.IResponse["s2c"]>; /** * @brief 获取历史订单列表 * @param [in] stReq 请求包,具体字段请参考Trd_GetHistoryOrderList.proto协议 */ GetHistoryOrderList: (c2s: proto.Trd_GetHistoryOrderList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetHistoryOrderList.IResponse["s2c"]>; /** * @brief 获取历史成交列表 * @param [in] stReq 请求包,具体字段请参考Trd_GetHistoryOrderFillList.proto协议 */ GetHistoryOrderFillList: (c2s: proto.Trd_GetHistoryOrderFillList.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetHistoryOrderFillList.IResponse["s2c"]>; /** * @brief 获取融资融券数据 * @param [in] stReq 请求包,具体字段请参考Trd_GetMarginRatio.proto协议 */ GetMarginRatio: (c2s: proto.Trd_GetMarginRatio.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetMarginRatio.IResponse["s2c"]>; /** * @brief 获取订单收费明细数据 * @param [in] stReq 请求包,具体字段请参考Trd_GetOrderFee.proto协议 */ GetOrderFee: (c2s: proto.Trd_GetOrderFee.IRequest["c2s"], timeout?: number) => Promise<proto.Trd_GetOrderFee.IResponse["s2c"]>; /** * @brief 请求全局状态 * @praram 具体字段请参考GetGlobalState.proto协议 */ GetGlobalState: (c2s: proto.GetGlobalState.IRequest["c2s"], timeout?: number) => Promise<proto.GetGlobalState.IResponse["s2c"]>; /** * @brief 注册推送 * @param 具体字段请参考Qot_RegQotPush.proto协议 */ RegQotPush: (c2s: proto.Qot_RegQotPush.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_RegQotPush.IResponse["s2c"]>; /** * @brief 获取订阅信息 * @praram 具体字段请参考Qot_GetSubInfo.proto协议 */ GetSubInfo: (c2s: proto.GetUserInfo.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetSubInfo.IResponse["s2c"]>; /** * @brief 获取逐笔 * @praram 具体字段请参考Qot_GetTicker.proto协议 */ GetTicker: (c2s: proto.Qot_GetTicker.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetTicker.IResponse["s2c"]>; /** * @brief 获取报价 * @praram 具体字段请参考Qot_GetBasicQot.proto协议 */ GetBasicQot: (c2s: proto.Qot_GetBasicQot.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetBasicQot.IResponse["s2c"]>; /** * @brief 获取摆盘 * @praram 具体字段请参考Qot_GetOrderBook.proto协议 */ GetOrderBook: (c2s: proto.Qot_GetOrderBook.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetOrderBook.IResponse["s2c"]>; /** * @brief 获取K线 * @praram 具体字段请参考Qot_GetKL.proto协议 */ GetKL: (c2s: proto.Qot_GetKL.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetKL.IResponse["s2c"]>; /** * @brief 获取分时 * @praram 具体字段请参考Qot_GetRT.proto协议 */ GetRT: (c2s: proto.Qot_GetRT.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetRT.IResponse["s2c"]>; /** * @brief 获取经纪队列 * @praram 具体字段请参考Qot_GetBroker.proto协议 */ GetBroker: (c2s: proto.Qot_GetBroker.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetBroker.IResponse["s2c"]>; /** * @brief 在线请求历史复权信息,不读本地历史数据DB * @praram 具体字段请参考Qot_RequestRehab.proto协议 */ RequestRehab: (c2s: proto.Qot_RequestRehab.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_RequestRehab.IResponse["s2c"]>; /** * @brief 在线请求历史K线,不读本地历史数据DB * @praram 具体字段请参考Qot_RequestHistoryKL.proto协议 */ RequestHistoryKL: (c2s: proto.Qot_RequestHistoryKL.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_RequestHistoryKL.IResponse["s2c"]>; /** * @brief 获取历史K线已经用掉的额度 * @praram 具体字段请参考Qot_RequestHistoryKLQuota.proto协议 */ RequestHistoryKLQuota: (c2s: proto.Qot_RequestHistoryKLQuota.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_RequestHistoryKLQuota.IResponse["s2c"]>; /** * @brief 获取静态信息 * @praram 具体字段请参考Qot_GetStaticInfo.proto协议 */ GetStaticInfo: (c2s: proto.Qot_GetStaticInfo.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetStaticInfo.IResponse["s2c"]>; /** * @brief 获取股票快照 * @praram 具体字段请参考Qot_GetSecuritySnapshot.proto协议 */ GetSecuritySnapshot: (c2s: proto.Qot_GetSecuritySnapshot.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetSecuritySnapshot.IResponse["s2c"]>; /** * @brief 获取板块集合下的板块 * @praram 具体字段请参考Qot_GetPlateSet.proto协议 */ GetPlateSet: (c2s: proto.Qot_GetPlateSet.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetPlateSet.IResponse["s2c"]>; /** * @brief 获取板块下的股票 * @praram 具体字段请参考Qot_GetPlateSecurity.proto协议 */ GetPlateSecurity: (c2s: proto.Qot_GetPlateSecurity.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetPlateSecurity.IResponse["s2c"]>; /** * @brief 获取相关股票 * @praram 具体字段请参考Qot_GetReference.proto协议 */ GetReference: (c2s: proto.Qot_GetReference.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetReference.IResponse["s2c"]>; /** * @brief 获取股票所属的板块 * @praram 具体字段请参考Qot_GetOwnerPlate.proto协议 */ GetOwnerPlate: (c2s: proto.Qot_GetOwnerPlate.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetOwnerPlate.IResponse["s2c"]>; /** * @brief 获取大股东持股变化列表 * @praram 具体字段请参考Qot_GetHoldingChangeList.proto协议 */ GetHoldingChangeList: (c2s: proto.Qot_GetHoldingChangeList.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetHoldingChangeList.IResponse["s2c"]>; /** * @brief 筛选期权 * @praram 具体字段请参考Qot_GetOptionChain.proto协议 */ GetOptionChain: (c2s: proto.Qot_GetOptionChain.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetOptionChain.IResponse["s2c"]>; /** * @brief 筛选窝轮 * @praram 具体字段请参考Qot_GetWarrant.proto协议 */ GetWarrant: (c2s: proto.Qot_GetWarrant.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetWarrant.IResponse["s2c"]>; /** * @brief 获取资金流向 * @praram 具体字段请参考Qot_GetCapitalFlow.proto协议 */ GetCapitalFlow: (c2s: proto.Qot_GetCapitalFlow.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetCapitalFlow.IResponse["s2c"]>; /** * @brief 获取资金分布 * @praram 具体字段请参考Qot_GetCapitalDistribution.proto协议 */ GetCapitalDistribution: (c2s: proto.Qot_GetCapitalDistribution.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetCapitalDistribution.IResponse["s2c"]>; /** * @brief 获取自选股分组下的股票 * @praram 具体字段请参考Qot_GetUserSecurity.proto协议 */ GetUserSecurity: (c2s: proto.Qot_GetUserSecurity.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetUserSecurity.IResponse["s2c"]>; /** * @brief 修改自选股分组下的股票 * @praram 具体字段请参考Qot_ModifyUserSecurity.proto协议 */ ModifyUserSecurity: (c2s: proto.Qot_ModifyUserSecurity.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_ModifyUserSecurity.IResponse["s2c"]>; /** * @brief 条件选股 * @praram 具体字段请参考Qot_StockFilter.proto协议 */ StockFilter: (c2s: proto.Qot_StockFilter.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_StockFilter.IResponse["s2c"]>; /** * @brief 获取股票代码变化信息 * @praram 具体字段请参考Qot_GetCodeChange.proto协议 */ GetCodeChange: (c2s: proto.Qot_GetCodeChange.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetCodeChange.IResponse["s2c"]>; /** * @brief 新股IPO * @praram 具体字段请参考Qot_GetIpoList.proto协议 */ GetIpoList: (c2s: proto.Qot_GetIpoList.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetIpoList.IResponse["s2c"]>; /** * @brief 期货合约资料 * @praram 具体字段请参考Qot_GetFutureInfo.proto协议 */ GetFutureInfo: (c2s: proto.Qot_GetFutureInfo.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetFutureInfo.IResponse["s2c"]>; /** * @brief 获取市场交易日 * @praram 具体字段请参考QotRequestTradeDate.proto协议 */ RequestTradeDate: (c2s: proto.Qot_RequestTradeDate.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_RequestTradeDate.IResponse["s2c"]>; /** * @brief 设置到价提醒 * @praram 具体字段请参考QotSetPriceReminder.proto协议 */ SetPriceReminder: (c2s: proto.Qot_SetPriceReminder.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_SetPriceReminder.IResponse["s2c"]>; /** * @brief 获取到价提醒 * @praram 具体字段请参考QotGetPriceReminder.proto协议 */ GetPriceReminder: (c2s: proto.Qot_GetPriceReminder.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetPriceReminder.IResponse["s2c"]>; /** * @brief 获取自选股分组列表 * @praram 具体字段请参考QotGetUserSecurityGroup.proto协议 */ GetUserSecurityGroup: (c2s: proto.Qot_GetUserSecurityGroup.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetUserSecurityGroup.IResponse["s2c"]>; /** * @brief 获取股票对应市场状态 * @praram 具体字段请参考QotGetMarketState.proto协议 */ GetMarketState: (c2s: proto.Qot_GetMarketState.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetMarketState.IResponse["s2c"]>; /** * @brief 获取期权链到期日 * @praram 具体字段请参考QotGetOptionExpirationDate.proto协议 */ GetOptionExpirationDate: (c2s: proto.Qot_GetOptionExpirationDate.IRequest["c2s"], timeout?: number) => Promise<proto.Qot_GetOptionExpirationDate.IResponse["s2c"]>; } interface IWebRequest extends Omit<WebRequest, 'InitWebSocket'> { } /** * getFutuApi 内部实例化 WebSocket 连接,并基于 WebSocket 封装了的查询对象 WebRequest, 你可以使用 `webRequest` 查询各种接口, * 也可以使用 `webSocket` 来关闭连接(`webSocket.close()`)和实现事件监听(如 onclose/onopen/onmessage等) * * Example: * * ```ts * import { getFutuApi } from 'futu-sdk'; * // import { Trd_Common } from 'futu-sdk/proto'; * * const { webRequest, webSocket } = getFutuApi('ws://127.0.0.1:33333', '9d261112869397f0'); * try { * const { accList } = (await webRequest.GetAccList({ userID: 0, needGeneralSecAccount: true })) || {}; * console.log({ accList }); * } finally { * webSocket.close(); * } * ``` * @param wsUrl 连接本地 WebSocket 的地址,如 `ws://127.0.0.1:33333` * @param key WebSocket 密钥,每次启动 OpenD 可能都不一样 * @returns `{ webRequest: WebRequest, webSocket: WebSocket }` */ declare const getFutuApi: (wsUrl: string, key: string) => { webSocket: WebSocket; webRequest: IWebRequest; }; /** * @deprecated 已废弃,请使用 `const { webRequest } = getFutuApi(`ws://${host}:${port}`, key);` */ declare const getWebRequest: ({ host, port, key }: WsUrl) => IWebRequest; export { type IWebRequest, getFutuApi, getWebRequest };