经纪商申请
如果您的业务平台提供数字货币服务,您就可以申请加入欧易经纪商项目,成为欧易的经纪商合作伙伴,享受专属的经纪商服务,并通过用户在欧易产生的交易手续费赚取高额返佣。
经纪商业务包含且不限:聚合交易平台、交易机器人、跟单平台、交易策略提供方、量化策略机构、资管平台等。
具体经纪商业务文档及产品服务在申请成功后提供相关资料。
经纪商指引
获取返佣指引
OKX Broker 经纪商进行 OKX V5 API 接口调用时,当请求参数有"tag"时,请务必录入您专属的 Broker code 信息,实现订单与经纪商的关联。
当订单录入 BrokerCode 信息后,经纪商方可享受对应的佣金奖励、数据统计等特定逻辑追踪
经纪商常用接口
OKX Broker经纪商进行OKX V5 API接口调用时,当请求参数有tag
时,请务必录入您专属的Broker code信息,实现订单与经纪商的关联。
当订单录入Brokercode
信息后,经纪商方可享受对应的佣金奖励、数据统计等特定逻辑追踪。
常规下单
策略交易
网格交易
定投交易
大宗交易
价差撮合交易
闪兑
金融产品
DMA 经纪商
获取子账户列表
限速:1次/s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/broker/dma/subaccount-info
请求示例
GET /api/v5/broker/dma/subaccount-info
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 获取子账户列表
result = ndBrokerAPI.get_subaccount_info()
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 否 | 子账户名称 |
uid | String | 否 | 子账户UID |
page | String | 否 | 查询页数 |
limit | String | 否 | 分页返回的结果集数量,最大为100,不填默认返回100条 |
返回结果
{
"code": "0",
"data": [
{
"details": [
{
"acctLv": "1",
"canTransOut": false,
"mainAcct": "",
"enable": true,
"frozenFunc": [],
"label": "1",
"subAcct": "h*******5",
"ts": "1648521249000",
"uid": "289*********1696"
}
],
"page": "1",
"totalPage": "1"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
totalPage | String | 总的页数 |
page | String | 当前页数 |
details | Array | 子账户列表 |
> subAcct | String | 子账户名称 |
> uid | String | 子账户UID |
> label | String | 子账户的备注 |
> acctLv | String | 账户模式1 :现货模式2 :现货和合约模式3 :跨币种保证金模式4 :组合保证金模式 |
> enable | Boolean | 子账户状态true :正常使用false :冻结(全局) |
> frozenFunc | Array of string | 被冻结的功能trading :交易convert :闪兑transfer :母子账户间资金划转withdrawal :提币deposit :充值flexible_loan :活期借币 |
> canTransOut | String | 是否可以主动转出(通过子账户APIKey直接转到另一个子账户下)true :可以转出false :不可转出 |
> mainAcct | String | 二级子账户的母账户名称 为""时,代表返回的是一级子账户,有值时为二级子账户 |
> ts | String | 子账户创建时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
获取子账户交易手续费费率
限速:1次/s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/broker/dma/subaccount-trade-fee
请求示例
GET /api/v5/broker/dma/subaccount-trade-fee
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 否 | 子账户名称 |
uid | String | 否 | 子账户UID |
page | String | 否 | 查询页数 |
limit | String | 否 | 分页返回的结果集数量,最大为100,不填默认返回100条 |
返回结果
{
"code": "0",
"data": [
{
"details": [
{
"feeRates": [
{
"marker": "-0.0008",
"taker": "-0.001",
"type": "1"
},
{
"marker": "-0.0005",
"taker": "-0.0007",
"type": "2"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "3"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "4"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "5"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "6"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "7"
},
{
"marker": "-0.0002",
"taker": "-0.0005",
"type": "8"
},
{
"marker": "-0.0002",
"taker": "-0.0003",
"type": "9"
}
],
"mainAcct": "",
"subAcct": "subaccount111ad",
"ts": "1658287703000",
"uid": "335748406955877155"
}
],
"page": "1",
"totalPage": "1"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
totalPage | String | 总的页数 |
page | String | 当前页数 |
details | Array | 子账户列表 |
> subAcct | String | 子账户名称 |
> uid | String | 子账户UID |
> mainAcct | String | 二级子账户的母账户名称 为""时,代表返回的是一级子账户,有值时为二级子账户 |
> ts | String | 子账户创建时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
> feeRates | Array | 手续费率信息 |
>> type | String | 手续费类型1 现货 USDT 交易对2 现货 稳定币/Crypto3 USDT 交割合约4 USDC 交割合约5 币本位交割合约6 USDT 永续合约7 USDC 永续合约8 币本位永续合约9 期权 |
>> maker | String | 挂单手续费率 |
>> taker | String | 吃单手续费率 |
创建子账户的APIKey
限速:40次/s
限速规则:UserID
权限:交易
HTTP请求
POST /api/v5/broker/dma/subaccount/apikey
请求示例
POST /api/v5/broker/dma/subaccount/apikey
body
{
"subAcct":"panpanBroker2",
"label":"broker3",
"passphrase":"Qwr4321!",
"perm":"read_only,trade",
"ip":"10.0.108.9"
}
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 创建子账户的APIKey
result = ndBrokerAPI.create_subaccount_apikey(
subAcct="panpanBroker2",
label="broker3",
passphrase="Qwr4321!",
perm="trade",
ip="10.0.108.9"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称,支持6-20位字母和数字组合(区分大小写,不支持空格符号) |
label | String | 是 | API Key备注 不超过50位字母(区分大小写)或数字,可以是纯字母或纯数字。 |
passphrase | String | 是 | API Key密码,8-32位字母数字组合,至少包含一个数字、一个大写字母、一个小写字母、一个特殊字符 |
ip | String | 否 | 绑定IP地址,多个IP用半角逗号隔开,最多支持20个IP 安全性考虑,推荐绑定IP 未绑定IP且拥有交易或提币权限的API key,将在闲置14天之后自动删除。(模拟盘的API key不会被删除) |
perm | String | 否 | API Key权限read_only :读取,默认拥有,且不可去除trade :交易withdraw :提币 |
返回结果
{
"code": "0",
"msg": "",
"data": [{
"subAcct": "panpanBroker2",
"label": "broker3",
"apiKey": "****",
"secretKey": "****",
"passphrase": "Qwr4321!",
"perm": "read_only,trade",
"ip": "10.0.108.9",
"ts": "1597026383085"
}]
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
subAcct | String | 子账户名称 |
label | String | API Key备注 |
apiKey | String | API公钥 |
secretKey | String | API Key私钥 |
passphrase | String | API Key密码 |
perm | String | API Key权限 |
ip | String | API Key绑定的ip地址 |
ts | String | 创建时间,Unix时间戳的毫秒数格式,如 1597026383085 |
查询子账户的API Key
限速:1次/s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/broker/dma/subaccount/apikey
请求示例
GET /api/v5/broker/dma/subaccount/apikey?subAcct=panpanBroker2
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 查询子账户的APIKey
result = ndBrokerAPI.get_subaccount_apikey(
subAcct="panpanBroker2",
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称 |
apiKey | String | 否 | API Key公钥 |
返回结果
{
"code":"0",
"msg":"",
"data":[
{
"label":"v5",
"apiKey":"arg13sdfgs",
"perm":"read_only,trade",
"ip":"1.1.1.1,2.2.2.2",
"ts":"1597026383085"
},
{
"label":"v5.1",
"apiKey":"arg13sdfgs",
"perm":"read_only",
"ip":"1.1.1.1,2.2.2.2",
"ts":"1597026383085"
}
]
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
label | String | API Key备注 |
apiKey | String | API Key公钥 |
perm | String | API Key权限read_only :读取trade :交易withdraw :提币 |
ip | String | API Key绑定的IP地址 |
ts | String | API Key创建时间 |
设置子账户的账户模式
经纪商母账户调整子账户的账户等级。
如果经纪商母账户想调整自己的账户模式,参考 设置账户模式
限速:5次/2s
限速规则:UserID
权限:交易
HTTP请求
POST /api/v5/broker/dma/set-subaccount-level
请求示例
POST /api/v5/broker/dma/set-subaccount-level
body
{
"acctLv":"3",
"subAcct":"brokerTest3"
}
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 设置子账户的账户等级
result = ndBrokerAPI.set_subaccount_level(
subAcct="panpanBroker2",
acctLv="3",
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称 |
acctLv | String | 是 | 账户模式 1 :现货模式2 :现货和合约模式3 :跨币种保证金模式4 :组合保证金模式 |
返回结果
{
"code": "0",
"data": [
{
"acctLv": "3"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
acctLv | String | 账户模式 1 :现货模式,2 :现货和合约模式 ,3 :跨币种保证金模式 ,4 :组合保证金模式 |
创建子账户充值地址
经纪商母账户创建子账户的充值地址,每个币种最多20个充值地址。闪电网络充值有独立接口。
限速:10次/s
限速规则:UserID
权限:交易
HTTP请求
POST /api/v5/asset/broker/dma/subaccount-deposit-address
请求示例
POST /api/v5/asset/broker/dma/subaccount-deposit-address
body
{
"ccy":"BTC",
"subAcct":"brokerTest5"
}
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 创建子账户充值地址
result = ndBrokerAPI.create_subaccount_deposit_address(
ccy="BTC",
subAcct="panpanBroker2"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称 |
ccy | String | 是 | 币种名称,仅支持大写,如 BTC |
chain | String | 否 | 币种链信息 有的币种下有多个链,必须要做区分,如 USDT 下有USDT-ERC20 ,USDT-TRC20 多个链如果不填此参数,则默认为主链 |
addrType | String | 否 | 充值地址类型1 :普通地址2 :隔离验证地址 (仅适用于BTC 和LTC )默认为 1 |
to | String | 否 | 充值到账账户6 :资金账户18 :交易账户默认为 6 |
返回结果
{
"code": "0",
"data": [
{
"chain": "EOS-EOS",
"ccy": "EOS",
"memo": "10810086",
"addr": "okbtothemoon",
"ts": "1637141950450"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
ccy | String | 充值币种 |
addr | String | 充值地址 |
chain | String | 币种链信息 |
pmtId | String | 部分币种提币需要此字段,如 XMR 如果不需要此字段的币种,则不会返回 |
tag | String | 部分币种提币需要此字段,如 XRP 如果不需要此字段的币种,则不会返回 |
memo | String | 部分币种充值需要标签,如 EOS 若不需要则不返回此字段,则不会返回 |
comment | String | 部分币种充值需要标签,如 TON 若不需要则不返回此字段,则不会返回 |
ts | String | 创建时间,Unix 时间戳的毫秒数格式,如 1597026383085 |
重置子账户充值地址
目前仅支持充值到账账户的调整
限速:6次/s
限速规则:UserID
权限:交易
HTTP请求
POST /api/v5/asset/broker/dma/modify-subaccount-deposit-address
请求示例
POST /api/v5/asset/broker/dma/modify-subaccount-deposit-address
body
{
"subAcct":"test",
"ccy":"USDT",
"chain":"USDT-ERC20",
"addr":"1123456",
"to":"18"
}
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 重置子账户充值地址
result = ndBrokerAPI.reset_subaccount_deposit_address(
ccy="USDT",
subAcct="panpanBroker2",
chain="USDT-ERC20",
addr="1123456",
to="18"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称 |
ccy | String | 是 | 币种名称,仅支持大写,如 BTC |
chain | String | 否 | 币种链信息 有的币种下有多个链,必须要做区分,如 USDT 下有USDT-ERC20 ,USDT-TRC20 多个链如果不填此参数,则默认为主链 |
addr | String | 是 | 充值地址 某些数字货币地址格式为:地址+标签,如 ARDOR-7JF3-8F2E-QUWZ-CAN7F:123456 |
to | String | 是 | 充值到账账户6 :资金账户 18 :交易账户充值到账账户是一个全局设置,单个子账户下的所有充值地址的到账账户都会影响 |
返回结果
{
"code": "0",
"data": [
{
"chain": "USDT-ERC20",
"ccy": "USDT",
"to": "18",
"addr": "1123456",
"ts": "1654778132000"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
ccy | String | 充值币种 |
addr | String | 充值地址 |
chain | String | 币种链信息 |
pmtId | String | 部分币种提币需要此字段,如果不需要此字段的币种吗,返回"" ,如 XMR |
tag | String | 部分币种提币需要此字段,如果不需要此字段的币种吗,返回"" , 如 XRP |
memo | String | 部分币种充值需要标签,若不需要则不返回此字段,返回"",如 EOS |
comment | String | 部分币种充值需要标签,若不需要则不返回此字段,返回"",如 TON |
to | String | 调整后的充值到账账户6 :资金账户 18 :交易账户 |
ts | String | 修改时间,Unix 时间戳的毫秒数格式,如 1597026383085 |
获取子账户充值地址
获取子账户的充值地址
限速:6次/s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/asset/broker/dma/subaccount-deposit-address
请求示例
GET /api/v5/asset/broker/dma/subaccount-deposit-address?ccy=BTC&subAcct=brokerTest1
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 获取子账户充值地址
result = ndBrokerAPI.get_subaccount_deposit_address(
ccy="USDT",
subAcct="panpanBroker2"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 是 | 子账户名称 |
ccy | String | 是 | 币种,仅支持大写:如 BTC |
返回结果
{
"code": "0",
"data": [
{
"chain": "XMR-Monero",
"ctAddr": "",
"ccy": "XMR",
"to": "6",
"addr": "884ifkSCavs9X759FZhfmrNmEbimqnXdofsd5kqXwuxfJMKZPKCfSAubrnwanuUf2JJi6hwskfcYzAUGodkJj3RsHAVFoDm",
"selected": false
},
{
"chain": "XMR-Monero",
"ctAddr": "",
"ccy": "XMR",
"to": "6",
"addr": "88aCNpJgfX1DGZ2HPd5i9DaAmyuRiQbnFGVbc8AFXgAhi4i7eX6sRm75m1UuJNZxwfMh4xBwV5fv6h4A5v1qQET5LHnXqgn",
"selected": false
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
addr | String | 充值地址 |
tag | String | 部分币种充值需要标签,若不需要则不返回此字段 |
memo | String | 部分币种充值需要标签,若不需要则不返回此字段 |
pmtId | String | 部分币种充值需要此字段,若不需要则不返回此字段 |
comment | String | 部分币种充值需要此字段,若不需要则不返回此字段 |
ccy | String | 币种,如BTC |
chain | String | 币种链信息 有的币种下有多个链,必须要做区分,如 USDT 下有USDT-ERC20 ,USDT-TRC20 多个链 |
to | String | 转入账户6 :资金账户18 :交易账户 |
selected | Boolean | 该地址是否为页面选中的地址 |
ctAddr | String | 合约地址后6位 |
获取子账户充值记录
根据币种,充值状态,时间范围获取充值记录,按照时间倒序排列,默认返回 100 条数据。
支持Websocket订阅,参考 充值信息频道。
限速:5次/2s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/asset/broker/dma/subaccount-deposit-history
请求示例
查询最近的充值记录
GET /api/v5/asset/broker/dma/subaccount-deposit-history?subAcct=brokerTest1&state=1
import okx.NDBroker as NDBroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "1" # 实盘:0 , 模拟盘:1
ndBrokerAPI = NDBroker.NDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 获取子账户充值记录
result = ndBrokerAPI.get_subaccount_deposit_history()
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
subAcct | String | 否 | 子账户名称 |
ccy | String | 否 | 币种名称,如 BTC |
txId | String | 否 | 区块转账哈希记录 |
type | String | 否 | 充值方式3 :内部转账4 :链上充值 |
state | String | 否 | 充值状态0 :等待确认1 :确认到账2 :充值成功8 :因该币种暂停充值而未到账,恢复充值后自动到账11 :命中黑名单地址12 :账户或充值被冻结13 :子账户充值拦截14 :KYC限额 |
after | String | 否 | 查询在此之前的内容,值为时间戳,Unix 时间戳为毫秒数格式,如 1597026383085 |
before | String | 否 | 查询在此之后的内容,值为时间戳,Unix 时间戳为毫秒数格式,如 1597026383085 |
limit | string | 否 | 返回的结果集数量,默认为 100,最大为 100 |
返回结果
{
"code": "0",
"msg": "",
"data": [
{
"amt": "0.01044408",
"actualDepBlkConfirm": "17",
"txId": "1915737_3_0_0_asset",
"ccy": "BTC",
"chain":"BTC-Bitcoin",
"from": "13801825426",
"areaCodeFrom": "86",
"to": "",
"ts": "1597026383085",
"state": "2",
"subAcct": "brokerTest1",
"depId": "4703879"
}
]
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
subAcct | String | 子账户名称 |
ccy | String | 币种名称,如 BTC |
chain | String | 币种链信息 有的币种下有多个链,必须要做区分,如 USDT 下有USDT-ERC20 ,USDT-TRC20 多个链 |
amt | String | 充值数量 |
from | String | 充值账户,只显示内部账户转账地址,不显示区块链充值地址 |
areaCodeFrom | String | 如果from 为手机号,该字段为该手机号的区号 |
to | String | 到账地址 |
txId | String | 区块转账哈希记录 |
ts | String | 充值记录创建时间,Unix 时间戳的毫秒数格式,如 1597026383085 |
state | String | 充值状态0 :等待确认1 :确认到账2 :充值成功8 :因该币种暂停充值而未到账,恢复充值后自动到账11 :命中黑名单地址12 :账户或充值被冻结13 :子账户充值拦截14 :KYC限额 |
depId | String | 充值记录 ID |
actualDepBlkConfirm | String | 最新的充币网络确认数 |
全披露经纪商(API和OAuth)
简介
全披露经纪商,按照鉴权和运作方式的不同,可以分为两种经纪商模式,即 API经纪商、OAuth经纪商。如果您是聚合交易平台、交易机器人、量化机构、资管平台等,需要 OKX 提供账户及流动性,赋能于交易用户,OKX FD Broker 是你最好的选择。
API经纪商:
- 集成欧易API,实现经纪商平台与用户的高效对接,享受独特的经纪商功能。
- 用户在欧易申请APIKey并提供给经纪商,通过Brokercode+用户API Key下单。
OAuth经纪商:
- OAuth一键授权登陆,更安全、更便捷的的经纪商&用户对接方式
- 经纪商提供用户跳转到欧易Oauth授权功能,通过Broker code+用户鉴权码下单。
- 更多详情可参考经纪商主页。
FD Broker 的优势如下
- 丰厚的佣金奖励机制
- 高达 50% 的佣金奖励
- 新老用户均可返佣
- 支持与节点返佣叠加,享受更高佣金比例
- 支持高 VIP 返佣策略
- 灵活的佣金管理机制
- 更安全的用户接入方案
- FAST API,更便捷的API接入方式
- 第三方 IP 白名单,安全可靠的平台绑定方案
OAuth 经纪商
简介
OKX OAuth一键授权登陆,提供更安全、更便捷的的经纪商&用户对接方式。
通过欧易OAuth 2.0用户仅需要在第三方应用内一键授权,即可进行交易。无需用户提供账户API Key或者登录密码。
欧易OAuth 2.0支持WEB和APP应用,基于OAuth 2.0协议(RFC 6749)和 OAuth 2.1草案协议中的一些新特征开发。
相关技术文档可联系商务获取。
接入前的准备
- 官网注册账户申请经纪商
您需要先申请成为OAuth经纪商,审核通过后您可以获取到client_id
,client_secret
信息。专属客户经理会提供给您相应的开发文档。
接入步骤:
- 经纪商申请OKX的账户
- 经纪商进入OKX经纪商官网申请OAuth经纪商,填写申请表,红色星为必填
- OKX收到申请表后2天内会进行审核
- 申请表在OKX的后台审核通过后,经纪商会收到邮件通知,邮件内容包括
client_id
和client_secret
- OAuth返佣设置
当前接入的OAuth经纪商的返佣需要设置标签,下单时需要将BrokerCode标识填写到tag字段里,作为返佣订单统计的标识。
授权模式介绍
欧易OAuth 2.0提供的授权模式:授权码模式、PKCE模式。
授权模式 | 描述 | 使用场景 |
---|---|---|
授权码模式 | 用户授权,第三方应用提供client_secret 获取授权码。通过授权码获取访问令牌 和刷新令牌 。 |
应用有服务器,可存储应用密钥,与欧易OAuth服务器进行密钥交互。 |
PKCE模式 | 用户授权,第三方应用提供临时密钥code_verifier 获取授权码。通过授权码获取访问令牌 和刷新令牌 |
应用无服务器(或不愿意后端服务器介入授权过程),无法存储应用密钥,通过随机字符串与欧易OAuth服务器进行交互。 |
授权码模式
同时支持App与Web应用的接入,呈现授权页面给用户,第三方应用在获取用户的授权码后,可以凭借此授权码换取访问令牌,调用OKX OpenAPI,访问用户授权的数据资源。
PKCE模式
若第三方应用无服务端或者不希望服务端参与授权过程,无法存储第三方应用密钥(client_secret),则推荐此模式,通过应用客户端接入获取令牌,有效提升开发者应用的安全防护。
令牌的使用
令牌的区别
第三方应用通过授权码调用换取令牌接口后,会得到两种令牌。
- 访问令牌(access token): 用于第三方应用调用OKX OpenAPI接口。
- 刷新令牌(refresh token): 当访问令牌失效后,用户获取新的访问令牌。
如何使用
请求示例
curl -H "Content-Type:application/json" \
-H "Authorization:Bearer eyJhbGciOiJIUzUxMiIsImNpZCI6ImFhIn0.eyJqdGkiOiJleDExMDE2Mzg4NDM3ODg1MzIxMzMzNUVGMkVGRTNGOUM2Y1BJWiIsInVpZCI6IlEybEZxMnY2N0VybnVMZ0o1cFYzdUE9PSIsIm1pZCI6InFGbG5lVEc4dnlJeDNMSnNSa29qZ0E9PSIsImlhdCI6MTYzODg0Mzc4OCwiZXhwIjoxNjM4ODQ3Mzg4LCJzdWIiOiIxMC4yNTQuMjcuMTIwIiwiYW95IjoiOSIsInZlciI6IjEiLCJkZXYiOiIzMmNmOWM2My02NzM3LTRhYjUtYjFhYi04ODU4YWU2NTkxODUiLCJndHkiOiJhdXRob3JpemUifQ.bWXsgN7hTszxmdFB9xhr0Qh67HQWIp2zoxoqMCUzw2y1MBFPm38nNJJY9coljkivgAQPso81YUnHoLsFOLjxGg" \
-H "TERMID:32cf9c63-6737-4ab5-b1ab-8858ae659185" \
https://www.okx.com/api/v5/asset/currencies
第三方应用完成授权并获取到令牌后,就可以通过访问令牌调用OKX OpenAPI接口了。 请求时需要在请求头中携带如下信息:
请求头字段 | 是否必须 | 描述 |
---|---|---|
Authorization | 是 | 将访问令牌 以Bearer的方式填写到此字段 |
TERMID | 可选 | 用于校验请求合法性的设备号信息 如果请求是由第三方应用客户端应用发起的(如选择了PKCE模式),则客户端应将客户端设备号在请求时带上 如果请求是由第三方应用服务端发起的(如选择了授权码模式),则无需填写此字段 |
令牌的有效期
- 访问令牌(access token):有效期为1个小时。
- 刷新令牌(refresh token):有效期为3天。
超过了访问令牌的有效期,接口会调用失败,如果刷新令牌还在有效期内,第三方应用需要调用刷新令牌接口,获取新的一对访问令牌和刷新令牌。新的访问令牌可以继续使用。需要注意的是,一旦刷新了令牌,无论原来的令牌有没有过期,都不再有效。
当您撤销令牌后,原令牌将不再有效。
权限
权限 | 描述 |
---|---|
read_only | 拥有读取功能的权限(不包含子账户模块) |
trade | 拥有交易功能的权限(不包含子账户模块) |
Fast API
简介
Fast API是帮助OKX用户快速授权第三方应用,创建APIKey并绑定第三方应用的功能。
Fast API工作流程
API Broker的界面上Broker用户登录之后,可以通过Oauth授权跳转到登录OKX页面,在OKX页面登录授权以后,OKX会授权该API Broker 拥有为其用户创建拥有读取
和交易
权限的API Key。
申请流程
- 在OKX申请API和OAuth经纪商
- 建议申请第三方APP IP白名单
- 建议申请第三方APP IP白名单
- 在OauthBroker应用程序中,提供
- 第三方服务器IP白名单
- 重定向URL
- Logo
- Fast API权限
- 跨域域名
- 申请成功后,您会收到一封电子邮件,包含client_id和client_secret。请务必妥善保存此信息,不要对他人展示。
经纪商返佣API
- 可以通过节点接口判断用户是否是自己的节点邀请用户
- 可以通过获取用户的 Broker 返佣信息接口判断用户是否可以给 Broker 返佣
- 返佣数据下载
- 先通过生成返佣明细下载链接(FD)接口生成数据
- 再通过获取返佣明细下载链接(FD)接口下载数据
获取返佣明细下载链接(FD)
获取已经申请成功的返佣明细下载链接,每次请求时获取新的链接,且2小时内有效。
限速:2次/1min
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/broker/fd/rebate-per-orders
请求示例
GET /api/v5/broker/fd/rebate-per-orders?type=false&begin=20221207&end=20230207
import okx.FDBroker as FDbroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "0" # 实盘:0 , 模拟盘:1
fdBrokerAPI = FDbroker.FDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 获取返佣明细下载链接
result = fdBrokerAPI.get_rebate_details_download_link(
type="true"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
type | String | 是 | 筛选条件类型true :获取当前用户所有已生成的历史记录false :查询指定的历史记录 |
begin | String | 可选 | 查询链接生成的起始日期 格式: YYYYMMdd ,如 20210623 ,查询在 2021/06/23 00:00:00 (包含)后的记录如果type为 false ,该字段必填 |
end | String | 可选 | 查询链接生成的结束日期 格式: YYYYMMdd ,如 20210623 ,查询在 2021/06/24 00:00:00 (不包含)前的记录如果type为 false ,该字段必填 |
brokerType | String | 可选 | 经纪商类型api :API经纪商oauth :Oauth经纪商当经纪商只有一种类型时,该参数可以不填 当经纪商有多种类型时,该参数必填 |
返回结果
{
"code": "0",
"data": [
{
"beginTime": "1671638400000",
"cTime": "1671675432000",
"endTime": "1671638400000",
"fileHref": "http://okg-pri-hk.oss-cn-hongkong.aliyuncs.com/okex/broker/pap/brokerRebateInfo/dc9df1365dac6695737e7f17cae14198/21754f4be28dBCDE/2022-12-22/RebateDetails/RebateDetails1222-1222.csv?Expires=1697617451&OSSAccessKeyId=LTAI5tKNPwWs7AttSPZn4iaa&Signature=EdnQthE3PgXHFVtGlQ7gGILi%2Fbw%3D",
"state": "finished",
"ts": "1671676696000"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
fileHref | String | 文件链接 |
beginTime | String | 返佣明细的开始时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
endTime | String | 返佣明细的结束时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
cTime | String | 生成下载链接的首次请求时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
ts | String | 下载链接生成时间,Unix时间戳的毫秒数格式 ,如 1597026383085 |
state | String | 下载链接状态finished :已生成ongoing :生成中 |
解压后CSV里的字段说明
参数名 | 描述 |
---|---|
brokerCode | 申请到的BrokerCode标识 |
level | 用户等级,如Lv1, Lv2, VIP1, VIP2 |
instId | 产品ID |
ordId | 订单ID |
spotTradeAmt | 现货交易量,单位为USDT |
derivativeTradeAmt | 衍生品交易量,单位为USDT |
fee | 手续费,单位为USDT |
netFee | 净手续费 (去除返佣卡、对手方等数据后进行返佣结算的手续费基数),单位为USDT |
settlementFee | 结算手续费 (去除节点返佣、返佣卡等,Broker进行结算前的手续费基数),单位为USDT |
brokerRebate | 经纪商返佣量,单位为USDT |
suBrokerRebate | 经纪商助力人返佣量,单位为USDT |
userRebate | 用户返佣量,单位为USDT |
affiliated | 是否有节点返佣true :节点返佣false :无节点返佣 |
ts | 该笔订单当天最后一次成交时间 Unix 时间戳为毫秒数格式,如 1597026383085 |
生成返佣明细下载链接(FD)
支持FD Broker的所有历史返佣明细。
限速:1次/1h
限速规则:UserID
权限:读取
HTTP请求
POST /api/v5/broker/fd/rebate-per-orders
请求示例
POST /api/v5/broker/fd/rebate-per-orders
body
{
"begin":"20210623",
"end":"20210626"
}
import okx.FDBroker as FDbroker
# API 初始化
apikey = "YOUR_API_KEY"
secretkey = "YOUR_SECRET_KEY"
passphrase = "YOUR_PASSPHRASE"
flag = "0" # 实盘:0 , 模拟盘:1
fdBrokerAPI = FDbroker.FDBrokerAPI(apikey, secretkey, passphrase, False, flag)
# 生成返佣明细下载链接
result = fdBrokerAPI.generate_rebate_details_download_link(
begin="20210623",
end="20210626"
)
print(result)
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
begin | String | 是 | 起始日期 格式: YYYYMMdd ,如 20210623 ,查询在 2021/06/23 00:00:00 (包含)后的记录 |
end | String | 是 | 结束日期 格式: YYYYMMdd ,如 20210623 ,查询在 2021/06/24 00:00:00 (不包含)前的记录 |
brokerType | String | 可选 | 经纪商类型api :API经纪商oauth :Oauth经纪商当经纪商只有一种类型时,该参数可以不填 当经纪商有多种类型时,该参数必填 |
返回结果
{
"code": "0",
"data":[
{
"result": "true",
"ts": "1646892328000"
}
],
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
result | String | 是否已经存在该区间的下载链接true :已存在,可以通过"获取返佣明细下载链接"接口获取false :不存在,正在生成,请2个小时后查看下载链接 |
ts | String | 服务端首次收到请求的时间,Unix时间戳的毫秒数格式,如 1597026383085 |
获取用户的 Broker 返佣信息
FD broker 查询用户是否有返佣条件,满足Broker返佣条件、下单时指定了 brokerCode、且用户的交易产生手续费时,Broker 会获得返佣。
限速:5次/2s
限速规则:UserID
权限:读取
HTTP请求
GET /api/v5/broker/fd/if-rebate
请求示例
GET /api/v5/broker/fd/if-rebate?apiKey=63d54aa0-0020-4ad9-a9f0-ac92654bc831
请求参数
参数名 | 类型 | 是否必须 | 描述 |
---|---|---|---|
apiKey | String | 是 | 用户的 API key |
brokerType | String | 可选 | 经纪商类型api :API经纪商oauth :Oauth经纪商当经纪商只有一种类型时,该参数可以不填 当经纪商有多种类型时,该参数必填 |
返回结果
{
"code": "0",
"data":[
{
"affiliated": false,
"brokerCode": "6099c63a8d75SCDE",
"type": "0",
"clientRebateRatio":"0",
"lastRebate":""
}
] ,
"msg": ""
}
返回参数
参数名 | 类型 | 描述 |
---|---|---|
type | String | 账户无法Broker返佣的原因0 :可以返佣1 :Broker身份过期2 :手续费等级为VIP4/5 且月返佣金额达到上限3 :手续费等级大于等于VIP6 |
brokerCode | String | FD broker 申请到的 BrokerCode 标识 |
affiliated | String | 绑定关系的情况,有无节点返佣true :有节点返佣false :无节点返佣 |
clientRebateRatio | String | 交易用户可获取返佣比例 |
lastRebate | String | 账号月返佣金额,仅适用于 VIP4 和 VIP5 的用户 |
错误码
错误提示 | HTTP 状态码 | 错误码 |
---|---|---|
53000 | 400 | 无效的token |
53001 | 400 | 无效的授权,用户已取消授权 |
53002 | 400 | token已过期 |
53003 | 400 | token已撤销 |
53004 | 400 | 用户已被冻结 |
53005 | 400 | 刷新令牌不正确 |
53006 | 401 | 无效的设备 |
53009 | 400 | 授权失败 |
53010 | 400 | 参数{0}错误 |
53011 | 400 | 必填参数{0}不能为空 |
53012 | 400 | 授权码已过期 |
53013 | 400 | 接口权限不足 |
53014 | 401 | 无效的IP |
53015 | 400 | 参数{参数名}长度超过最大限制{长度} |
53016 | 400 | 无效的redirect_uri |
53017 | 400 | 快捷 API 权限尚未开启 |