连接浏览器插件钱包

Provider API (Signet)#

什么是 Injected provider API (Signet) ?#

OKX Injected Providers API (Signet) 基于 JavaScript 模型,由 OKX 嵌入用户访问网站中。DApp 项目可以通过调用此 API 请求用户账户信息,从用户所连接的区块链中读取数据,并协助用户进行消息和交易的签署。

注:BTC Signet 仅适用于钱包插件端为 2.82.32 或更高版本。

connect#

okxwallet.bitcoinSignet.connect()

描述

连接钱包

参数

返回值

  • Promise - object
    • address - string:当前账户的地址
    • publicKey - string:当前账户的公钥

示例

const result = await okxwallet.bitcoinSignet.connect()
// example
{
  address: 'bc1pwqye6x35g2n6xpwalywhpsvsu39k3l6086cvdgqazlw9mz2meansz9knaq',
  publicKey: '4a627f388196639041ce226c0229560127ef9a5a39d4885123cd82dc82d8b497'
}

signMessage#

okxwallet.bitcoinSignet.signMessage(signStr[, type])

描述

签名消息

参数

  • signStr - string:需要签名的数据
  • type - string: (可选) "ecdsa" | "bip322-simple",默认值是 "ecdsa"

返回值

  • Promise - string:签名结果

示例

const signStr = 'need sign string';
const result = await window.okxwallet.bitcoinSignet.signMessage(signStr, 'ecdsa')
// example
INg2ZeG8b6GsiYLiWeQQpvmfFHqCt3zC6ocdlN9ZRQLhSFZdGhgYWF8ipar1wqJtYufxzSYiZm5kdlAcnxgZWQU=

signPsbt#

okxwallet.bitcoinSignet.signPsbt(psbtHex[, options])

描述

签名 psbt,该方法将遍历所有与当前地址匹配的输入进行签名

参数

  • psbtHex - string:要签名的 psbt 的十六进制字符串

构建交易生成 psbt (string 类型),如果遇到 input 地址是 Taproot 类型,需要提供公钥。

示例:可参考下面的 txInput 和 publicKey。

const txInputs: utxoInput[] = [];
txInputs.push({
      txId: "1e0f92720ef34ab75eefc5d691b551fb2f783eac61503a69cdf63eb7305d2306",
      vOut: 2,
      amount: 341474,
      address: "tb1q8h8....mjxzny",
      privateKey: "0s79......ldjejke",
      publicKey: "tb1q8h8....mjxzny",
      bip32Derivation: [
          {
              "masterFingerprint": "a22e8e32",
              "pubkey": "tb1q8h8....mjxzny",
              "path": "m/49'/0'/0'/0/0",
          },
      ],
  });
  • options
    • autoFinalized - boolean:签名后是否完成 psbt,默认为 true
    • toSignInputs - array:
      • index - number:要签名的输入
      • address - string:用于签名的相应私钥所对应的地址
      • publicKey - string:用于签名的相应私钥所对应的公钥
      • sighashTypes - number[]: (可选) sighashTypes
      • disableTweakSigner - boolean: (可选) 签名和解锁 Taproot 地址时, 默认使用 tweakSigner 来生成签名,启用此选项允许使用原始私钥进行签名

返回值

  • Promise - string:已签名 psbt 的十六进制字符串

示例

try {
  let res = await okxwallet.bitcoinSignet.signPsbt('70736274ff01007d....', {
    autoFinalized: false,
    toSignInputs: [
      {
        index: 0,
        address: 'tb1q8h8....mjxzny',
      },
      {
        index: 1,
        publicKey: 'tb1q8h8....mjxzny',
        sighashTypes: [1],
      },
      {
        index: 2,
        publicKey: '02062...8779693f',
      },
    ],
  });
  console.log(res);
} catch (e) {
  console.log(e);
}

okxwallet.bitcoinSignet.signPsbt('xxxxxxxx', {
  toSignInputs: [{ index: 0, publicKey: 'xxxxxx', disableTweakSigner: true }],
  autoFinalized: false,
});

signPsbts#

okxwallet.bitcoinSignet.signPsbts(psbtHexs[, options])

描述

签署多个 psbt,该方法将遍历所有与当前地址匹配的输入进行签名

参数

  • psbtHexs - string[]:要签名的 psbt 的十六进制字符串

构建交易生成 psbt (string 类型),如果遇到 input 地址是 Taproot 类型,需要提供公钥。

示例:可参考下面的 txInput 和 publicKey。

const txInputs: utxoInput[] = [];
txInputs.push({
      txId: "1e0f92720ef34ab75eefc5d691b551fb2f783eac61503a69cdf63eb7305d2306",
      vOut: 2,
      amount: 341474,
      address: "tb1q8h8....mjxzny",
      privateKey: "0s79......ldjejke",
      publicKey: "tb1q8h8....mjxzny",
      bip32Derivation: [
          {
              "masterFingerprint": "a22e8e32",
              "pubkey": "tb1q8h8....mjxzny",
              "path": "m/49'/0'/0'/0/0",
          },
      ],
  });
  • options - object[]:签署 psbt 的选项
    • autoFinalized - boolean:签名后是否完成 psbt,默认为 true
    • toSignInputs - array:
      • index - number:要签名的输入
      • address - string:用于签名的相应私钥所对应的地址
      • publicKey - string:用于签名的相应私钥所对应的公钥
      • sighashTypes - number[]: (可选) sighashTypes

返回值

  • Promise - string[]:已签名 psbt 的十六进制字符串

示例

try {
  let res = await okxwallet.bitcoinSignet.signPsbts([
    '70736274ff01007d...',
    '70736274ff01007d...',
  ]);
  console.log(res);
} catch (e) {
  console.log(e);
}