Skip to content

Latest commit

 

History

History
93 lines (81 loc) · 4.93 KB

1-Overview and authorize.md

File metadata and controls

93 lines (81 loc) · 4.93 KB

概述与授权

为了降低使用复杂度,针对转账支付接口(transfer)可以直接发起调用,不用提前注册DApp,但是请各钱包应用提醒用户转账风险;除此之外,还可以结合DApp注册机制实现安全可靠的支付功能。

本接口规范起于对EOS、EUN的支持,但是从设计上来说同样支持BTC、ETH等已有其他数字资产。

为了降低信息维护复杂度,该 Repository 会提供已经支持的Token、DApp相关信息,分别为 tokens_info.json、dapps_info.json,不在统计范围内的Token和DApp可以通过Pull Request来提交更新请求。

tokens_info.json 示例

tokenid name chainid contract token_name website status
22572363 {"en":"EOS", "cn":"柚子"} aca376f206b8fc25a6ed44dbdc66547c36c6c33e3a119ffbeaef943642f0e906 eosio.token EOS https://github.com/EOSIO/eos 0
5adf002f {"en":"ENU", "cn":"牛油果"} cf057bbfb72640471fd910bcb67639c22df9f92470936cddc1ade0e2f2e7dc4f enu.token ENU https://github.com/enumivo/enumivo 0
dfa1bfdc {"en":"BTC", "cn":"比特币"} 00000000839a8e6886ab5951d76f411475428afc90947ee320161bbf18eb6048 BTC https://github.com/bitcoin/bitcoin 0

注:

  • tokenid: 全局唯一的由chainid、contract、token_name 三者确定的一个ID,计算方式为: hashlib.sha256({chainid+contract+token_name}).hexdigest()[:8]
  • chainid: 该币所在链chainid 或者 NUM #1 block hash
  • status: 0 正常使用;

dapps_info.json 示例

symbol dapp_name dapp_scheme account_info org description
dappone_c391d81c {"cn":"游戏达人","en":"dappone"} KylinDappDemo [{"tokenid":"22572363","account":"wallet4bixin","memo":"123123"}] {"name":"DAPPONE","website":"http://dappone.com/","email":"[email protected]","branding":{"logo":"http://dappone.com/pic/logo.png","cover":"http://dappone.com/pic/cover.png"},"social_network":{"steemit":"https://steemit.com/eos/@dappone","twitter":"https://twitter.com/CIGEOS","facebook":"https://www.facebook.com/cigeos","telegram":"https://t.me/cigeos"}} {"cn":"第一款超级dapp游戏","en":"This is a super DAPP"}
注:
  • symbol: 全局唯一的DApp自己的标识,并在各个DApp统一使用,长度尽量短,最长 64 个字符,合法字符 a-z|0-9|_
  • account_info: DApp预先注册的收款账户地址,tokenid 采用 tokens_info.json 中的字段
  • dapp_scheme: dapp的scheme,可供iOS添加scheme白名单使用

DApp开放平台认证授权逻辑

签名授权机制

DApp在开放平台可以申请自己的secretkey(长度大于32B)进行数据签名,保证数据安全和请求的有效性,签名计算方法为:

signature = base64(hmac-sha1(secretkey, ( timestamp + ‘\n’+ params_str)))

timestamp: unix 时间戳
params_str: 参数名name按照字典序从小到大排序,然后 ‘,’.join(name+’:’value)

HTTPS 请求时 HEAD里面增加 Authorization 字段内容如下:

	accesskey + ":" + signature

注:

  • /kylindapp/login 接口需要使用该签名,其余接口参数中包含sessionid即可。

DApp应用在开放平台中注册

让DApp注册的目的是明确DApp在当前开放平台的身份信息,推荐钱包平台要启用KYC验证。类似于支付宝商家认证,最终是为了保证用户权益。每个DApp都会分配一个唯一dapp_id用于在平台内部标识。

    URL:
        /kylindapp/register
    POST PARAM: 
        dappsymbol: DApp唯一标识,在各个开放平台要一致, dapps_info.json 文件中的 symbol 字段
    RESPONSE:
        code: 错误信息代码,0表示成功
        message: symbol已存在|DAPP名称已被注册|参数异常
        dapp_id: DApp的唯一标识,建议使用UUID,保证在不同平台的唯一性
        platformid: 开放平台标识
        accesskey: 返回的默认accesskey
        secretkey: 返回的默认secretkey 

DApp应用申请密钥对

DApp与开放平台进行交互时需要确认身份,采用隔离性更好的AccessKey 和 SecretKey机制。

    URL:
        /kylindapp/request/accesskey
    POST PARAM: 
        dapp_id: 112
        platformid
        tag : 申请业务标识 32 B 英文字符,为后面拓展开放平台功能预留 
        sessionid
    RESPONSE:
        code: 错误信息代码,0表示成功
        message 
        accesskey 
        secretkey 

DApp应用在开放平台中解除注册应用信息

该接口主要是用于注销\锁定一个DApp授权,调用以后该 dapp_id 对应的Accesskey都将会禁止。

    URL:
        /kylindapp/unregister
    POST PARAM: 
        dapp_id: 112
        platformid
        sessionid
    RESPONSE:
        code: 错误信息代码,0表示成功
        message: