@cubist-labs/cubesigner-sdk 0.2.28 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/README.md +30 -28
  2. package/dist/cjs/package.json +41 -0
  3. package/dist/cjs/spec/env/beta.json +9 -0
  4. package/dist/cjs/spec/env/gamma.json +9 -0
  5. package/dist/cjs/spec/env/prod.json +9 -0
  6. package/dist/cjs/src/api.d.ts +634 -0
  7. package/dist/cjs/src/api.js +1309 -0
  8. package/dist/cjs/src/client.d.ts +575 -0
  9. package/dist/cjs/src/client.js +378 -0
  10. package/dist/cjs/src/env.d.ts +15 -0
  11. package/dist/cjs/src/env.js +35 -0
  12. package/dist/cjs/src/error.d.ts +29 -0
  13. package/dist/cjs/src/error.js +36 -0
  14. package/dist/cjs/src/events.d.ts +84 -0
  15. package/dist/cjs/src/events.js +195 -0
  16. package/dist/cjs/src/index.d.ts +203 -0
  17. package/dist/cjs/src/index.js +298 -0
  18. package/dist/cjs/src/key.d.ts +152 -0
  19. package/dist/cjs/src/key.js +242 -0
  20. package/dist/{src/fido.d.ts → cjs/src/mfa.d.ts} +33 -15
  21. package/dist/cjs/src/mfa.js +169 -0
  22. package/dist/cjs/src/org.d.ts +99 -0
  23. package/dist/cjs/src/org.js +95 -0
  24. package/dist/cjs/src/paginator.d.ts +76 -0
  25. package/dist/cjs/src/paginator.js +99 -0
  26. package/dist/cjs/src/response.d.ts +101 -0
  27. package/dist/cjs/src/response.js +164 -0
  28. package/dist/cjs/src/role.d.ts +283 -0
  29. package/dist/cjs/src/role.js +253 -0
  30. package/dist/cjs/src/schema.d.ts +6209 -0
  31. package/dist/cjs/src/schema.js +7 -0
  32. package/dist/cjs/src/schema_types.d.ts +113 -0
  33. package/dist/cjs/src/schema_types.js +3 -0
  34. package/dist/cjs/src/session/session_storage.d.ts +27 -0
  35. package/dist/cjs/src/session/session_storage.js +47 -0
  36. package/dist/cjs/src/session/signer_session_manager.d.ts +125 -0
  37. package/dist/cjs/src/session/signer_session_manager.js +239 -0
  38. package/dist/cjs/src/signer_session.d.ts +41 -0
  39. package/dist/cjs/src/signer_session.js +77 -0
  40. package/dist/cjs/src/user_export.d.ts +52 -0
  41. package/dist/cjs/src/user_export.js +129 -0
  42. package/dist/cjs/src/util.d.ts +56 -0
  43. package/dist/cjs/src/util.js +86 -0
  44. package/dist/esm/package.json +41 -0
  45. package/dist/esm/spec/env/beta.json +9 -0
  46. package/dist/esm/spec/env/gamma.json +9 -0
  47. package/dist/esm/spec/env/prod.json +9 -0
  48. package/dist/esm/src/api.d.ts +634 -0
  49. package/dist/esm/src/api.js +1299 -0
  50. package/dist/esm/src/client.d.ts +575 -0
  51. package/dist/esm/src/client.js +374 -0
  52. package/dist/esm/src/env.d.ts +15 -0
  53. package/dist/esm/src/env.js +9 -0
  54. package/dist/esm/src/error.d.ts +29 -0
  55. package/dist/esm/src/error.js +31 -0
  56. package/dist/esm/src/events.d.ts +84 -0
  57. package/dist/esm/src/events.js +189 -0
  58. package/dist/esm/src/index.d.ts +203 -0
  59. package/dist/esm/src/index.js +276 -0
  60. package/dist/esm/src/key.d.ts +152 -0
  61. package/dist/esm/src/key.js +236 -0
  62. package/dist/esm/src/mfa.d.ts +94 -0
  63. package/dist/esm/src/mfa.js +163 -0
  64. package/dist/esm/src/org.d.ts +99 -0
  65. package/dist/esm/src/org.js +91 -0
  66. package/dist/esm/src/paginator.d.ts +76 -0
  67. package/dist/esm/src/paginator.js +94 -0
  68. package/dist/esm/src/response.d.ts +101 -0
  69. package/dist/esm/src/response.js +159 -0
  70. package/dist/esm/src/role.d.ts +283 -0
  71. package/dist/esm/src/role.js +248 -0
  72. package/dist/esm/src/schema.d.ts +6209 -0
  73. package/dist/esm/src/schema.js +6 -0
  74. package/dist/esm/src/schema_types.d.ts +113 -0
  75. package/dist/esm/src/schema_types.js +2 -0
  76. package/dist/esm/src/session/session_storage.d.ts +27 -0
  77. package/dist/esm/src/session/session_storage.js +43 -0
  78. package/dist/esm/src/session/signer_session_manager.d.ts +125 -0
  79. package/dist/esm/src/session/signer_session_manager.js +235 -0
  80. package/dist/esm/src/signer_session.d.ts +41 -0
  81. package/dist/esm/src/signer_session.js +72 -0
  82. package/dist/esm/src/user_export.d.ts +52 -0
  83. package/dist/esm/src/user_export.js +99 -0
  84. package/dist/esm/src/util.d.ts +56 -0
  85. package/dist/esm/src/util.js +76 -0
  86. package/dist/package.json +13 -45
  87. package/dist/src/api.d.ts +29 -1
  88. package/dist/src/api.js +66 -1
  89. package/dist/src/client.d.ts +35 -14
  90. package/dist/src/client.js +12 -8
  91. package/dist/src/events.js +1 -1
  92. package/dist/src/index.d.ts +6 -11
  93. package/dist/src/index.js +9 -25
  94. package/dist/src/key.d.ts +18 -7
  95. package/dist/src/key.js +52 -19
  96. package/dist/src/role.d.ts +46 -3
  97. package/dist/src/role.js +60 -8
  98. package/dist/src/schema.d.ts +206 -72
  99. package/dist/src/schema.js +1 -1
  100. package/dist/src/schema_types.d.ts +3 -0
  101. package/dist/src/schema_types.js +1 -1
  102. package/dist/src/session/signer_session_manager.d.ts +38 -14
  103. package/dist/src/session/signer_session_manager.js +93 -33
  104. package/dist/src/util.d.ts +14 -0
  105. package/dist/src/util.js +24 -27
  106. package/package.json +19 -46
  107. package/src/api.ts +79 -0
  108. package/src/client.ts +12 -8
  109. package/src/events.ts +2 -0
  110. package/src/index.ts +10 -24
  111. package/src/key.ts +36 -18
  112. package/src/role.ts +78 -7
  113. package/src/schema.ts +269 -110
  114. package/src/schema_types.ts +3 -0
  115. package/src/session/session_storage.ts +0 -32
  116. package/src/session/signer_session_manager.ts +124 -36
  117. package/src/util.ts +19 -10
  118. package/tsconfig.json +1 -21
  119. package/LICENSE-APACHE +0 -177
  120. package/LICENSE-MIT +0 -25
  121. package/NOTICE +0 -13
  122. package/dist/examples/ethers.d.ts +0 -1
  123. package/dist/examples/ethers.js +0 -142
  124. package/dist/src/ethers/index.d.ts +0 -95
  125. package/dist/src/ethers/index.js +0 -215
  126. package/dist/src/fido.js +0 -148
  127. package/dist/src/session/cognito_manager.d.ts +0 -71
  128. package/dist/src/session/cognito_manager.js +0 -129
  129. package/dist/src/session/generic.d.ts +0 -47
  130. package/dist/src/session/generic.js +0 -3
  131. package/dist/src/session/management_session_manager.d.ts +0 -59
  132. package/dist/src/session/management_session_manager.js +0 -111
  133. package/dist/src/session/oidc_session_manager.d.ts +0 -78
  134. package/dist/src/session/oidc_session_manager.js +0 -142
  135. package/dist/src/session/session_manager.d.ts +0 -99
  136. package/dist/src/session/session_manager.js +0 -136
  137. package/dist/src/sign.d.ts +0 -114
  138. package/dist/src/sign.js +0 -248
  139. package/dist/test/sessions.d.ts +0 -35
  140. package/dist/test/sessions.js +0 -56
  141. package/src/ethers/index.ts +0 -253
  142. package/src/session/cognito_manager.ts +0 -161
  143. package/src/session/session_manager.ts +0 -165
@@ -1,142 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- const cs = __importStar(require("../src/index"));
27
- const ethers_1 = require("ethers");
28
- const WALLET_ADDRESS = env("WALLET_ADDRESS");
29
- const RECIPIENT = env("RECIPIENT");
30
- const RPC_PROVIDER = env("RPC_PROVIDER", "https://rpc.ankr.com/eth_goerli");
31
- const AMOUNT = ethers_1.ethers.parseEther(env("AMOUNT", "0.0000001"));
32
- const CUBE_SIGNER_TOKEN = env("CUBE_SIGNER_TOKEN", null /* load from fs */);
33
- // create like CUBE_SIGNER_TOKEN=$(cs token create ... --output base64)
34
- /** Main entry point */
35
- async function main() {
36
- // If token is passed via env variable, decode and parse it,
37
- // otherwise just load token from default filesystem location.
38
- const memStorage = CUBE_SIGNER_TOKEN
39
- ? new cs.MemorySessionStorage(JSON.parse(atob(CUBE_SIGNER_TOKEN)))
40
- : undefined;
41
- // Load signer session
42
- const signerSession = await cs.CubeSigner.loadSignerSession(memStorage);
43
- const provider = new ethers_1.ethers.JsonRpcProvider(RPC_PROVIDER);
44
- const signer = new EthersCubeSinger(WALLET_ADDRESS, signerSession, provider);
45
- // get balance
46
- const addr = await signer.getAddress();
47
- console.log(`${addr} has ${await provider.getBalance(addr)} gwei`);
48
- console.log(`Transferring ${AMOUNT} wei from ${addr} to ${RECIPIENT}...`);
49
- const tx = {
50
- to: RECIPIENT,
51
- value: AMOUNT,
52
- };
53
- const response = await signer.sendTransaction(tx);
54
- await response.wait();
55
- // get new balance
56
- console.log(`${addr} has ${await provider.getBalance(addr)} gwei`);
57
- }
58
- main().catch((err) => {
59
- console.error(err);
60
- process.exit(1);
61
- });
62
- /**
63
- * A bare-bones ethers.Signer implementation that uses EthersCubeSinger to sign transactions.
64
- */
65
- class EthersCubeSinger extends ethers_1.ethers.AbstractSigner {
66
- /** Create new EthersCubeSinger ethers.Signer instance
67
- * @param {string} address The address of the account touser.
68
- * @param {cs.SignerSession<cs.SignerSessionObject>} signerSession The underlying EthersCubeSinger session.
69
- * @param {null | ethers.Provider} provider The optional provider instance to use.
70
- */
71
- constructor(address, signerSession, provider) {
72
- super(provider);
73
- this.address = address;
74
- this.signerSession = signerSession;
75
- }
76
- /** Resolves to the signer address. */
77
- async getAddress() {
78
- return this.address;
79
- }
80
- /**
81
- * Returns the signer connected to %%provider%%.
82
- * @param {null | ethers.Provider} provider The optional provider instance to use.
83
- * @return {EthersCubeSinger} The signer connected to signer.
84
- */
85
- connect(provider) {
86
- return new EthersCubeSinger(this.address, this.signerSession, provider);
87
- }
88
- /**
89
- * Signs a transaction.
90
- * @param {ethers.TransactionRequest} tx The transaction to sign.
91
- * @return {Promise<string>} The signature.
92
- */
93
- async signTransaction(tx) {
94
- // get the chain id from the network or tx
95
- let chainId = tx.chainId;
96
- if (chainId === undefined) {
97
- const network = await this.provider?.getNetwork();
98
- const id = network?.chainId;
99
- if (id === undefined) {
100
- throw new Error("Missing chainId");
101
- }
102
- chainId = id.toString();
103
- }
104
- // Convert the transaction into a JSON-RPC transaction
105
- const rpcTx = this.provider instanceof ethers_1.JsonRpcApiProvider
106
- ? this.provider.getRpcTransaction(tx)
107
- : // We can just call the getRpcTransaction with a
108
- // null receiver since it doesn't actually use it
109
- // (and really should be declared static).
110
- ethers_1.JsonRpcApiProvider.prototype.getRpcTransaction.call(null, tx);
111
- rpcTx.type = (0, ethers_1.toBeHex)(tx.type ?? 0x02, 1); // we expect 0x0[0-2]
112
- const req = {
113
- chain_id: Number(chainId),
114
- tx: rpcTx,
115
- };
116
- const sig = await this.signerSession.signEth1(this.address, req);
117
- return sig.data().rlp_signed_tx;
118
- }
119
- /** Signs arbitrary message. Not yet implemented. */
120
- async signMessage() {
121
- throw new Error("Method not implemented.");
122
- }
123
- /** Signs typed data. Not yet implemented. */
124
- signTypedData() {
125
- throw new Error("Method not implemented.");
126
- }
127
- }
128
- /**
129
- * Returns the value of the environment variable.
130
- * @param {string} name The name of the environment variable.
131
- * @param {string} fallback The optional fallback value.
132
- * @return {string} The value of the environment variable, the fallback, or undefined.
133
- * @throws {Error} If the environment variable is not set and no fallback is provided.
134
- */
135
- function env(name, fallback) {
136
- const val = process.env[name] ?? fallback;
137
- if (val === undefined) {
138
- throw new Error(`Missing environment variable ${name}`);
139
- }
140
- return val;
141
- }
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ethers.js","sourceRoot":"","sources":["../../examples/ethers.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cs from \"../src/index\";\nimport { JsonRpcApiProvider, ethers, toBeHex } from \"ethers\";\n\nconst WALLET_ADDRESS: string = env(\"WALLET_ADDRESS\")!;\nconst RECIPIENT: string = env(\"RECIPIENT\")!;\nconst RPC_PROVIDER: string = env(\"RPC_PROVIDER\", \"https://rpc.ankr.com/eth_goerli\")!;\nconst AMOUNT: bigint = ethers.parseEther(env(\"AMOUNT\", \"0.0000001\")!);\nconst CUBE_SIGNER_TOKEN = env(\"CUBE_SIGNER_TOKEN\", null /* load from fs */);\n// create like CUBE_SIGNER_TOKEN=$(cs token create ... --output base64)\n\n/** Main entry point */\nasync function main() {\n  // If token is passed via env variable, decode and parse it,\n  // otherwise just load token from default filesystem location.\n  const memStorage = CUBE_SIGNER_TOKEN\n    ? new cs.MemorySessionStorage(JSON.parse(atob(CUBE_SIGNER_TOKEN)))\n    : undefined;\n  // Load signer session\n  const signerSession = await cs.CubeSigner.loadSignerSession(memStorage);\n\n  const provider = new ethers.JsonRpcProvider(RPC_PROVIDER);\n  const signer = new EthersCubeSinger(WALLET_ADDRESS, signerSession, provider);\n\n  // get balance\n  const addr = await signer.getAddress();\n  console.log(`${addr} has ${await provider.getBalance(addr)} gwei`);\n\n  console.log(`Transferring ${AMOUNT} wei from ${addr} to ${RECIPIENT}...`);\n\n  const tx = {\n    to: RECIPIENT,\n    value: AMOUNT,\n  };\n\n  const response = await signer.sendTransaction(tx);\n  await response.wait();\n\n  // get new balance\n  console.log(`${addr} has ${await provider.getBalance(addr)} gwei`);\n}\n\nmain().catch((err: Error) => {\n  console.error(err);\n  process.exit(1);\n});\n\n/**\n * A bare-bones ethers.Signer implementation that uses EthersCubeSinger to sign transactions.\n */\nclass EthersCubeSinger extends ethers.AbstractSigner {\n  /** The address of the account */\n  readonly address!: string;\n\n  /** The underlying EthersCubeSinger session */\n  readonly signerSession!: cs.SignerSession;\n\n  /** Create new EthersCubeSinger ethers.Signer instance\n   * @param {string} address The address of the account touser.\n   * @param {cs.SignerSession<cs.SignerSessionObject>} signerSession The underlying EthersCubeSinger session.\n   * @param {null | ethers.Provider} provider The optional provider instance to use.\n   */\n  constructor(address: string, signerSession: cs.SignerSession, provider?: null | ethers.Provider) {\n    super(provider);\n    this.address = address;\n    this.signerSession = signerSession;\n  }\n\n  /** Resolves to the signer address. */\n  async getAddress(): Promise<string> {\n    return this.address;\n  }\n\n  /**\n   *  Returns the signer connected to %%provider%%.\n   *  @param {null | ethers.Provider} provider The optional provider instance to use.\n   *  @return {EthersCubeSinger} The signer connected to signer.\n   */\n  connect(provider: null | ethers.Provider): EthersCubeSinger {\n    return new EthersCubeSinger(this.address, this.signerSession, provider);\n  }\n\n  /**\n   * Signs a transaction.\n   * @param {ethers.TransactionRequest} tx The transaction to sign.\n   * @return {Promise<string>} The signature.\n   */\n  async signTransaction(tx: ethers.TransactionRequest): Promise<string> {\n    // get the chain id from the network or tx\n    let chainId = tx.chainId;\n    if (chainId === undefined) {\n      const network = await this.provider?.getNetwork();\n      const id = network?.chainId;\n      if (id === undefined) {\n        throw new Error(\"Missing chainId\");\n      }\n      chainId = id.toString();\n    }\n\n    // Convert the transaction into a JSON-RPC transaction\n    const rpcTx =\n      this.provider instanceof JsonRpcApiProvider\n        ? this.provider.getRpcTransaction(tx)\n        : // We can just call the getRpcTransaction with a\n          // null receiver since it doesn't actually use it\n          // (and really should be declared static).\n          JsonRpcApiProvider.prototype.getRpcTransaction.call(null, tx);\n    rpcTx.type = toBeHex(tx.type ?? 0x02, 1); // we expect 0x0[0-2]\n\n    const req = <cs.Eth1SignRequest>{\n      chain_id: Number(chainId),\n      tx: rpcTx,\n    };\n    const sig = await this.signerSession.signEth1(this.address, req);\n    return sig.data().rlp_signed_tx;\n  }\n\n  /** Signs arbitrary message. Not yet implemented. */\n  async signMessage(): Promise<string> {\n    throw new Error(\"Method not implemented.\");\n  }\n\n  /** Signs typed data. Not yet implemented. */\n  signTypedData(): Promise<string> {\n    throw new Error(\"Method not implemented.\");\n  }\n}\n\n/**\n * Returns the value of the environment variable.\n * @param {string} name The name of the environment variable.\n * @param {string} fallback The optional fallback value.\n * @return {string} The value of the environment variable, the fallback, or undefined.\n * @throws {Error} If the environment variable is not set and no fallback is provided.\n */\nfunction env(name: string, fallback?: string | null): string | null {\n  const val = process.env[name] ?? fallback;\n  if (val === undefined) {\n    throw new Error(`Missing environment variable ${name}`);\n  }\n  return val;\n}\n"]}
@@ -1,95 +0,0 @@
1
- import { TypedDataDomain, TypedDataField, ethers } from "ethers";
2
- import { SignerSession } from "../signer_session";
3
- import { EvmSignRequest, MfaRequestInfo } from "../schema_types";
4
- import { KeyInfo } from "../key";
5
- /** Options for the signer */
6
- interface SignerOptions {
7
- /** Optional provider to use */
8
- provider?: null | ethers.Provider;
9
- /**
10
- * The function to call when MFA information is retrieved. If this callback
11
- * throws, no transaction is broadcast.
12
- */
13
- onMfaPoll?: (arg0: MfaRequestInfo) => void;
14
- /**
15
- * The amount of time (in milliseconds) to wait between checks for MFA
16
- * updates. Default is 1000ms
17
- */
18
- mfaPollIntervalMs?: number;
19
- }
20
- /**
21
- * A ethers.js Signer using CubeSigner
22
- */
23
- export declare class Signer extends ethers.AbstractSigner {
24
- #private;
25
- /**
26
- * Create new Signer instance
27
- * @param {KeyInfo | string} address The key or the eth address of the account to use.
28
- * @param {SignerSession} signerSession The underlying Signer session.
29
- * @param {SignerOptions} options The options to use for the Signer instance
30
- */
31
- constructor(address: KeyInfo | string, signerSession: SignerSession, options?: SignerOptions);
32
- /** Resolves to the signer address. */
33
- getAddress(): Promise<string>;
34
- /**
35
- * Returns the signer connected to %%provider%%.
36
- * @param {null | ethers.Provider} provider The optional provider instance to use.
37
- * @return {Signer} The signer connected to signer.
38
- */
39
- connect(provider: null | ethers.Provider): Signer;
40
- /**
41
- * Construct a signing request from a transaction. This populates the transaction
42
- * type to `0x02` (EIP-1559) unless set.
43
- *
44
- * @param {ethers.TransactionRequest} tx The transaction
45
- * @return {EvmSignRequest} The EVM sign request to be sent to CubeSigner
46
- */
47
- evmSignRequestFromTx(tx: ethers.TransactionRequest): Promise<EvmSignRequest>;
48
- /**
49
- * Sign a transaction. This method will block if the key requires MFA approval.
50
- * @param {ethers.TransactionRequest} tx The transaction to sign.
51
- * @return {Promise<string>} Hex-encoded RLP encoding of the transaction and its signature.
52
- */
53
- signTransaction(tx: ethers.TransactionRequest): Promise<string>;
54
- /**
55
- * Signs arbitrary messages. This uses ethers.js's [hashMessage](https://docs.ethers.org/v6/api/hashing/#hashMessage)
56
- * to compute the EIP-191 digest and signs this digest using {@link Key#signBlob}.
57
- * The key (for this session) must have the `"AllowRawBlobSigning"` policy attached.
58
- * @param {string | Uint8Array} message The message to sign.
59
- * @return {Promise<string>} The signature.
60
- */
61
- signMessage(message: string | Uint8Array): Promise<string>;
62
- /**
63
- * Signs EIP-712 typed data. This uses ethers.js's
64
- * [TypedDataEncoder.hash](https://docs.ethers.org/v6/api/hashing/#TypedDataEncoder_hash)
65
- * to compute the EIP-712 digest and signs this digest using {@link Key#signBlob}.
66
- * The key (for this session) must have the `"AllowRawBlobSigning"` policy attached.
67
- * @param {TypedDataDomain} domain The domain of the typed data.
68
- * @param {Record<string, Array<TypedDataField>>} types The types of the typed data.
69
- * @param {Record<string, any>} value The value of the typed data.
70
- * @return {Promise<string>} The signature.
71
- */
72
- signTypedData(domain: TypedDataDomain, types: Record<string, Array<TypedDataField>>, value: Record<string, any>): Promise<string>;
73
- /**
74
- * Sign arbitrary digest. This uses {@link Key#signBlob}.
75
- * @param {string} digest The digest to sign.
76
- * @return {Promise<string>} The signature.
77
- */
78
- private signBlob;
79
- /**
80
- * Initialize the signing a message using MFA approvals. This method populates
81
- * missing fields. If the signing does not require MFA, this method throws.
82
- * @param {ethers.TransactionRequest} tx The transaction to send.
83
- * @return {string} The MFA id associated with the signing request.
84
- */
85
- sendTransactionMfaInit(tx: ethers.TransactionRequest): Promise<string>;
86
- /**
87
- * Send a transaction from an approved MFA request. The MFA request contains
88
- * information about the approved signing request, which this method will
89
- * execute.
90
- * @param {MfaRequestInfo} mfaInfo The approved MFA request.
91
- * @return {ethers.TransactionResponse} The result of submitting the transaction
92
- */
93
- sendTransactionMfaApproved(mfaInfo: MfaRequestInfo): Promise<ethers.TransactionResponse>;
94
- }
95
- export {};
@@ -1,215 +0,0 @@
1
- "use strict";
2
- var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
3
- if (kind === "m") throw new TypeError("Private method is not writable");
4
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
5
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
6
- return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
7
- };
8
- var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
9
- if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
10
- if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
11
- return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
12
- };
13
- var __importDefault = (this && this.__importDefault) || function (mod) {
14
- return (mod && mod.__esModule) ? mod : { "default": mod };
15
- };
16
- var _Signer_instances, _Signer_address, _Signer_key, _Signer_signerSession, _Signer_onMfaPoll, _Signer_mfaPollIntervalMs, _Signer_handleMfa;
17
- Object.defineProperty(exports, "__esModule", { value: true });
18
- exports.Signer = void 0;
19
- const ethers_1 = require("ethers");
20
- const assert_1 = __importDefault(require("assert"));
21
- /**
22
- * A ethers.js Signer using CubeSigner
23
- */
24
- class Signer extends ethers_1.ethers.AbstractSigner {
25
- /**
26
- * Create new Signer instance
27
- * @param {KeyInfo | string} address The key or the eth address of the account to use.
28
- * @param {SignerSession} signerSession The underlying Signer session.
29
- * @param {SignerOptions} options The options to use for the Signer instance
30
- */
31
- constructor(address, signerSession, options) {
32
- super(options?.provider);
33
- _Signer_instances.add(this);
34
- /** The address of the account */
35
- _Signer_address.set(this, void 0);
36
- /** The key to use for signing */
37
- _Signer_key.set(this, void 0);
38
- /** The underlying session */
39
- _Signer_signerSession.set(this, void 0);
40
- /**
41
- * The function to call when MFA information is retrieved. If this callback
42
- * throws, no transaction is broadcast.
43
- */
44
- _Signer_onMfaPoll.set(this, void 0);
45
- /** The amount of time to wait between checks for MFA updates */
46
- _Signer_mfaPollIntervalMs.set(this, void 0);
47
- if (typeof address === "string") {
48
- __classPrivateFieldSet(this, _Signer_address, address, "f");
49
- }
50
- else {
51
- __classPrivateFieldSet(this, _Signer_address, address.materialId, "f");
52
- __classPrivateFieldSet(this, _Signer_key, address, "f");
53
- }
54
- __classPrivateFieldSet(this, _Signer_signerSession, signerSession, "f");
55
- __classPrivateFieldSet(this, _Signer_onMfaPoll, options?.onMfaPoll ?? (( /* _mfaInfo: MfaRequestInfo */) => { }), "f"); // eslint-disable-line @typescript-eslint/no-empty-function
56
- __classPrivateFieldSet(this, _Signer_mfaPollIntervalMs, options?.mfaPollIntervalMs ?? 1000, "f");
57
- }
58
- /** Resolves to the signer address. */
59
- async getAddress() {
60
- return __classPrivateFieldGet(this, _Signer_address, "f");
61
- }
62
- /**
63
- * Returns the signer connected to %%provider%%.
64
- * @param {null | ethers.Provider} provider The optional provider instance to use.
65
- * @return {Signer} The signer connected to signer.
66
- */
67
- connect(provider) {
68
- return new Signer(__classPrivateFieldGet(this, _Signer_address, "f"), __classPrivateFieldGet(this, _Signer_signerSession, "f"), { provider });
69
- }
70
- /**
71
- * Construct a signing request from a transaction. This populates the transaction
72
- * type to `0x02` (EIP-1559) unless set.
73
- *
74
- * @param {ethers.TransactionRequest} tx The transaction
75
- * @return {EvmSignRequest} The EVM sign request to be sent to CubeSigner
76
- */
77
- async evmSignRequestFromTx(tx) {
78
- // get the chain id from the network or tx
79
- let chainId = tx.chainId;
80
- if (chainId === undefined) {
81
- const network = await this.provider?.getNetwork();
82
- chainId = network?.chainId?.toString() ?? "1";
83
- }
84
- // Convert the transaction into a JSON-RPC transaction
85
- const rpcTx = this.provider instanceof ethers_1.JsonRpcApiProvider
86
- ? this.provider.getRpcTransaction(tx)
87
- : // We can just call the getRpcTransaction with a
88
- // null receiver since it doesn't actually use it
89
- // (and really should be declared static).
90
- ethers_1.JsonRpcApiProvider.prototype.getRpcTransaction.call(null, tx);
91
- rpcTx.type = (0, ethers_1.toBeHex)(tx.type ?? 0x02, 1); // we expect 0x0[0-2]
92
- return {
93
- chain_id: Number(chainId),
94
- tx: rpcTx,
95
- };
96
- }
97
- /**
98
- * Sign a transaction. This method will block if the key requires MFA approval.
99
- * @param {ethers.TransactionRequest} tx The transaction to sign.
100
- * @return {Promise<string>} Hex-encoded RLP encoding of the transaction and its signature.
101
- */
102
- async signTransaction(tx) {
103
- const req = await this.evmSignRequestFromTx(tx);
104
- const res = await __classPrivateFieldGet(this, _Signer_signerSession, "f").signEvm(__classPrivateFieldGet(this, _Signer_address, "f"), req);
105
- const data = await __classPrivateFieldGet(this, _Signer_instances, "m", _Signer_handleMfa).call(this, res);
106
- return data.rlp_signed_tx;
107
- }
108
- /**
109
- * Signs arbitrary messages. This uses ethers.js's [hashMessage](https://docs.ethers.org/v6/api/hashing/#hashMessage)
110
- * to compute the EIP-191 digest and signs this digest using {@link Key#signBlob}.
111
- * The key (for this session) must have the `"AllowRawBlobSigning"` policy attached.
112
- * @param {string | Uint8Array} message The message to sign.
113
- * @return {Promise<string>} The signature.
114
- */
115
- async signMessage(message) {
116
- const digest = ethers_1.ethers.hashMessage(message);
117
- return this.signBlob(digest);
118
- }
119
- /**
120
- * Signs EIP-712 typed data. This uses ethers.js's
121
- * [TypedDataEncoder.hash](https://docs.ethers.org/v6/api/hashing/#TypedDataEncoder_hash)
122
- * to compute the EIP-712 digest and signs this digest using {@link Key#signBlob}.
123
- * The key (for this session) must have the `"AllowRawBlobSigning"` policy attached.
124
- * @param {TypedDataDomain} domain The domain of the typed data.
125
- * @param {Record<string, Array<TypedDataField>>} types The types of the typed data.
126
- * @param {Record<string, any>} value The value of the typed data.
127
- * @return {Promise<string>} The signature.
128
- */
129
- async signTypedData(domain, types, value) {
130
- const digest = ethers_1.TypedDataEncoder.hash(domain, types, value);
131
- return this.signBlob(digest);
132
- }
133
- /**
134
- * Sign arbitrary digest. This uses {@link Key#signBlob}.
135
- * @param {string} digest The digest to sign.
136
- * @return {Promise<string>} The signature.
137
- */
138
- async signBlob(digest) {
139
- const blobReq = {
140
- message_base64: Buffer.from((0, ethers_1.getBytes)(digest)).toString("base64"),
141
- };
142
- // Get the key corresponding to this address
143
- if (__classPrivateFieldGet(this, _Signer_key, "f") === undefined) {
144
- const key = (await __classPrivateFieldGet(this, _Signer_signerSession, "f").keys()).find((k) => k.material_id === __classPrivateFieldGet(this, _Signer_address, "f"));
145
- if (key === undefined) {
146
- throw new Error(`Cannot access key '${__classPrivateFieldGet(this, _Signer_address, "f")}'`);
147
- }
148
- __classPrivateFieldSet(this, _Signer_key, key, "f");
149
- }
150
- const res = await __classPrivateFieldGet(this, _Signer_signerSession, "f").signBlob(__classPrivateFieldGet(this, _Signer_key, "f").key_id, blobReq);
151
- const data = await __classPrivateFieldGet(this, _Signer_instances, "m", _Signer_handleMfa).call(this, res);
152
- const signature = data.signature;
153
- (0, assert_1.default)(signature.startsWith("0x"));
154
- (0, assert_1.default)(signature.length == 132);
155
- const vAdj = (parseInt(signature.slice(130), 16) + 27).toString(16);
156
- return signature.slice(0, 130) + vAdj;
157
- }
158
- /**
159
- * Initialize the signing a message using MFA approvals. This method populates
160
- * missing fields. If the signing does not require MFA, this method throws.
161
- * @param {ethers.TransactionRequest} tx The transaction to send.
162
- * @return {string} The MFA id associated with the signing request.
163
- */
164
- async sendTransactionMfaInit(tx) {
165
- const popTx = await this.populateTransaction(tx);
166
- const req = await this.evmSignRequestFromTx(popTx);
167
- const res = await __classPrivateFieldGet(this, _Signer_signerSession, "f").signEvm(__classPrivateFieldGet(this, _Signer_address, "f"), req);
168
- return res.mfaId();
169
- }
170
- /**
171
- * Send a transaction from an approved MFA request. The MFA request contains
172
- * information about the approved signing request, which this method will
173
- * execute.
174
- * @param {MfaRequestInfo} mfaInfo The approved MFA request.
175
- * @return {ethers.TransactionResponse} The result of submitting the transaction
176
- */
177
- async sendTransactionMfaApproved(mfaInfo) {
178
- if (!mfaInfo.request.path.includes("/eth1/sign/")) {
179
- throw new Error(`Expected EVM transaction signing request, got ${mfaInfo.request.path}`);
180
- }
181
- if (!mfaInfo.request.path.includes(__classPrivateFieldGet(this, _Signer_address, "f"))) {
182
- throw new Error(`Expected signing request for ${__classPrivateFieldGet(this, _Signer_address, "f")} but got ${mfaInfo.request.path}`);
183
- }
184
- const signedTx = await __classPrivateFieldGet(this, _Signer_signerSession, "f").signEvm(__classPrivateFieldGet(this, _Signer_address, "f"), mfaInfo.request.body, {
185
- mfaId: mfaInfo.id,
186
- mfaOrgId: __classPrivateFieldGet(this, _Signer_signerSession, "f").orgId,
187
- mfaConf: mfaInfo.receipt.confirmation,
188
- });
189
- return await this.provider.broadcastTransaction(signedTx.data().rlp_signed_tx);
190
- }
191
- }
192
- exports.Signer = Signer;
193
- _Signer_address = new WeakMap(), _Signer_key = new WeakMap(), _Signer_signerSession = new WeakMap(), _Signer_onMfaPoll = new WeakMap(), _Signer_mfaPollIntervalMs = new WeakMap(), _Signer_instances = new WeakSet(), _Signer_handleMfa =
194
- /**
195
- * If the sign request requires MFA, this method waits for approvals
196
- * @param {CubeSignerResponse<U>} res The response of a sign request
197
- * @return {Promise<U>} The sign data after MFA approvals
198
- */
199
- async function _Signer_handleMfa(res) {
200
- while (res.requiresMfa()) {
201
- await new Promise((resolve) => setTimeout(resolve, __classPrivateFieldGet(this, _Signer_mfaPollIntervalMs, "f")));
202
- const mfaId = res.mfaId();
203
- const mfaInfo = await __classPrivateFieldGet(this, _Signer_signerSession, "f").getMfaInfo(mfaId);
204
- __classPrivateFieldGet(this, _Signer_onMfaPoll, "f").call(this, mfaInfo);
205
- if (mfaInfo.receipt) {
206
- res = await res.signWithMfaApproval({
207
- mfaId,
208
- mfaOrgId: __classPrivateFieldGet(this, _Signer_signerSession, "f").orgId,
209
- mfaConf: mfaInfo.receipt.confirmation,
210
- });
211
- }
212
- }
213
- return res.data();
214
- };
215
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ethers/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  JsonRpcApiProvider,\n  TypedDataDomain,\n  TypedDataEncoder,\n  TypedDataField,\n  ethers,\n  getBytes,\n  toBeHex,\n} from \"ethers\";\nimport { SignerSession } from \"../signer_session\";\nimport { CubeSignerResponse } from \"../response\";\nimport { BlobSignRequest, EvmSignRequest, MfaRequestInfo } from \"../schema_types\";\nimport { KeyInfo } from \"../key\";\nimport assert from \"assert\";\n\n/** Options for the signer */\ninterface SignerOptions {\n  /** Optional provider to use */\n  provider?: null | ethers.Provider;\n  /**\n   * The function to call when MFA information is retrieved. If this callback\n   * throws, no transaction is broadcast.\n   */\n  onMfaPoll?: (arg0: MfaRequestInfo) => void;\n  /**\n   * The amount of time (in milliseconds) to wait between checks for MFA\n   * updates. Default is 1000ms\n   */\n  mfaPollIntervalMs?: number;\n}\n\n/**\n * A ethers.js Signer using CubeSigner\n */\nexport class Signer extends ethers.AbstractSigner {\n  /** The address of the account */\n  readonly #address: string;\n\n  /** The key to use for signing */\n  #key?: KeyInfo;\n\n  /** The underlying session */\n  readonly #signerSession: SignerSession;\n\n  /**\n   * The function to call when MFA information is retrieved. If this callback\n   * throws, no transaction is broadcast.\n   */\n  readonly #onMfaPoll: (arg0: MfaRequestInfo) => void;\n\n  /** The amount of time to wait between checks for MFA updates */\n  readonly #mfaPollIntervalMs: number;\n\n  /**\n   * Create new Signer instance\n   * @param {KeyInfo | string} address The key or the eth address of the account to use.\n   * @param {SignerSession} signerSession The underlying Signer session.\n   * @param {SignerOptions} options The options to use for the Signer instance\n   */\n  constructor(address: KeyInfo | string, signerSession: SignerSession, options?: SignerOptions) {\n    super(options?.provider);\n    if (typeof address === \"string\") {\n      this.#address = address;\n    } else {\n      this.#address = address.materialId;\n      this.#key = address as KeyInfo;\n    }\n    this.#signerSession = signerSession;\n    this.#onMfaPoll = options?.onMfaPoll ?? ((/* _mfaInfo: MfaRequestInfo */) => {}); // eslint-disable-line @typescript-eslint/no-empty-function\n    this.#mfaPollIntervalMs = options?.mfaPollIntervalMs ?? 1000;\n  }\n\n  /** Resolves to the signer address. */\n  async getAddress(): Promise<string> {\n    return this.#address;\n  }\n\n  /**\n   *  Returns the signer connected to %%provider%%.\n   *  @param {null | ethers.Provider} provider The optional provider instance to use.\n   *  @return {Signer} The signer connected to signer.\n   */\n  connect(provider: null | ethers.Provider): Signer {\n    return new Signer(this.#address, this.#signerSession, { provider });\n  }\n\n  /**\n   * Construct a signing request from a transaction. This populates the transaction\n   * type to `0x02` (EIP-1559) unless set.\n   *\n   * @param {ethers.TransactionRequest} tx The transaction\n   * @return {EvmSignRequest} The EVM sign request to be sent to CubeSigner\n   */\n  async evmSignRequestFromTx(tx: ethers.TransactionRequest): Promise<EvmSignRequest> {\n    // get the chain id from the network or tx\n    let chainId = tx.chainId;\n    if (chainId === undefined) {\n      const network = await this.provider?.getNetwork();\n      chainId = network?.chainId?.toString() ?? \"1\";\n    }\n\n    // Convert the transaction into a JSON-RPC transaction\n    const rpcTx =\n      this.provider instanceof JsonRpcApiProvider\n        ? this.provider.getRpcTransaction(tx)\n        : // We can just call the getRpcTransaction with a\n          // null receiver since it doesn't actually use it\n          // (and really should be declared static).\n          JsonRpcApiProvider.prototype.getRpcTransaction.call(null, tx);\n    rpcTx.type = toBeHex(tx.type ?? 0x02, 1); // we expect 0x0[0-2]\n\n    return <EvmSignRequest>{\n      chain_id: Number(chainId),\n      tx: rpcTx,\n    };\n  }\n\n  /**\n   * Sign a transaction. This method will block if the key requires MFA approval.\n   * @param {ethers.TransactionRequest} tx The transaction to sign.\n   * @return {Promise<string>} Hex-encoded RLP encoding of the transaction and its signature.\n   */\n  async signTransaction(tx: ethers.TransactionRequest): Promise<string> {\n    const req = await this.evmSignRequestFromTx(tx);\n    const res = await this.#signerSession.signEvm(this.#address, req);\n    const data = await this.#handleMfa(res);\n    return data.rlp_signed_tx;\n  }\n\n  /**\n   * Signs arbitrary messages. This uses ethers.js's [hashMessage](https://docs.ethers.org/v6/api/hashing/#hashMessage)\n   * to compute the EIP-191 digest and signs this digest using {@link Key#signBlob}.\n   * The key (for this session) must have the `\"AllowRawBlobSigning\"` policy attached.\n   * @param {string | Uint8Array} message The message to sign.\n   * @return {Promise<string>} The signature.\n   */\n  async signMessage(message: string | Uint8Array): Promise<string> {\n    const digest = ethers.hashMessage(message);\n    return this.signBlob(digest);\n  }\n\n  /**\n   * Signs EIP-712 typed data. This uses ethers.js's\n   * [TypedDataEncoder.hash](https://docs.ethers.org/v6/api/hashing/#TypedDataEncoder_hash)\n   * to compute the EIP-712 digest and signs this digest using {@link Key#signBlob}.\n   * The key (for this session) must have the `\"AllowRawBlobSigning\"` policy attached.\n   * @param {TypedDataDomain} domain The domain of the typed data.\n   * @param {Record<string, Array<TypedDataField>>} types The types of the typed data.\n   * @param {Record<string, any>} value The value of the typed data.\n   * @return {Promise<string>} The signature.\n   */\n  async signTypedData(\n    domain: TypedDataDomain,\n    types: Record<string, Array<TypedDataField>>,\n    value: Record<string, any>, // eslint-disable-line @typescript-eslint/no-explicit-any\n  ): Promise<string> {\n    const digest = TypedDataEncoder.hash(domain, types, value);\n    return this.signBlob(digest);\n  }\n\n  /**\n   * Sign arbitrary digest. This uses {@link Key#signBlob}.\n   * @param {string} digest The digest to sign.\n   * @return {Promise<string>} The signature.\n   */\n  private async signBlob(digest: string): Promise<string> {\n    const blobReq = <BlobSignRequest>{\n      message_base64: Buffer.from(getBytes(digest)).toString(\"base64\"),\n    };\n    // Get the key corresponding to this address\n    if (this.#key === undefined) {\n      const key = (await this.#signerSession.keys()).find((k) => k.material_id === this.#address);\n      if (key === undefined) {\n        throw new Error(`Cannot access key '${this.#address}'`);\n      }\n      this.#key = key;\n    }\n\n    const res = await this.#signerSession.signBlob(this.#key.key_id, blobReq);\n    const data = await this.#handleMfa(res);\n\n    const signature = data.signature;\n    assert(signature.startsWith(\"0x\"));\n    assert(signature.length == 132);\n    const vAdj = (parseInt(signature.slice(130), 16) + 27).toString(16);\n    return signature.slice(0, 130) + vAdj;\n  }\n\n  /**\n   * Initialize the signing a message using MFA approvals. This method populates\n   * missing fields. If the signing does not require MFA, this method throws.\n   * @param {ethers.TransactionRequest} tx The transaction to send.\n   * @return {string} The MFA id associated with the signing request.\n   */\n  async sendTransactionMfaInit(tx: ethers.TransactionRequest): Promise<string> {\n    const popTx = await this.populateTransaction(tx);\n    const req = await this.evmSignRequestFromTx(popTx);\n    const res = await this.#signerSession.signEvm(this.#address, req);\n    return res.mfaId();\n  }\n\n  /**\n   * Send a transaction from an approved MFA request. The MFA request contains\n   * information about the approved signing request, which this method will\n   * execute.\n   * @param {MfaRequestInfo} mfaInfo The approved MFA request.\n   * @return {ethers.TransactionResponse} The result of submitting the transaction\n   */\n  async sendTransactionMfaApproved(mfaInfo: MfaRequestInfo): Promise<ethers.TransactionResponse> {\n    if (!mfaInfo.request.path.includes(\"/eth1/sign/\")) {\n      throw new Error(`Expected EVM transaction signing request, got ${mfaInfo.request.path}`);\n    }\n    if (!mfaInfo.request.path.includes(this.#address)) {\n      throw new Error(\n        `Expected signing request for ${this.#address} but got ${mfaInfo.request.path}`,\n      );\n    }\n\n    const signedTx = await this.#signerSession.signEvm(\n      this.#address,\n      mfaInfo.request.body as EvmSignRequest,\n      {\n        mfaId: mfaInfo.id,\n        mfaOrgId: this.#signerSession.orgId,\n        mfaConf: mfaInfo.receipt!.confirmation,\n      },\n    );\n    return await this.provider!.broadcastTransaction(signedTx.data().rlp_signed_tx);\n  }\n\n  /**\n   * If the sign request requires MFA, this method waits for approvals\n   * @param {CubeSignerResponse<U>} res The response of a sign request\n   * @return {Promise<U>} The sign data after MFA approvals\n   */\n  async #handleMfa<U>(res: CubeSignerResponse<U>): Promise<U> {\n    while (res.requiresMfa()) {\n      await new Promise((resolve) => setTimeout(resolve, this.#mfaPollIntervalMs));\n\n      const mfaId = res.mfaId();\n      const mfaInfo = await this.#signerSession.getMfaInfo(mfaId);\n      this.#onMfaPoll(mfaInfo);\n      if (mfaInfo.receipt) {\n        res = await res.signWithMfaApproval({\n          mfaId,\n          mfaOrgId: this.#signerSession.orgId,\n          mfaConf: mfaInfo.receipt.confirmation,\n        });\n      }\n    }\n    return res.data();\n  }\n}\n"]}