@cubist-labs/cubesigner-sdk 0.1.77 → 0.2.15
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.
- package/dist/package.json +68 -0
- package/dist/src/api.d.ts +493 -0
- package/dist/src/api.js +1166 -0
- package/dist/src/client.d.ts +534 -10
- package/dist/src/client.js +355 -19
- package/dist/src/ethers/index.d.ts +34 -9
- package/dist/src/ethers/index.js +63 -19
- package/dist/src/index.d.ts +51 -70
- package/dist/src/index.js +83 -237
- package/dist/src/key.d.ts +35 -64
- package/dist/src/key.js +32 -96
- package/dist/src/mfa.d.ts +85 -14
- package/dist/src/mfa.js +146 -40
- package/dist/src/org.d.ts +42 -194
- package/dist/src/org.js +52 -336
- package/dist/src/paginator.js +1 -1
- package/dist/src/response.d.ts +101 -0
- package/dist/src/response.js +164 -0
- package/dist/src/role.d.ts +87 -83
- package/dist/src/role.js +79 -136
- package/dist/src/schema.d.ts +936 -28
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +109 -0
- package/dist/src/schema_types.js +3 -0
- package/dist/src/session/cognito_manager.d.ts +15 -3
- package/dist/src/session/cognito_manager.js +23 -5
- package/dist/src/session/session_manager.d.ts +1 -1
- package/dist/src/session/session_manager.js +3 -11
- package/dist/src/session/session_storage.js +1 -1
- package/dist/src/session/signer_session_manager.d.ts +10 -29
- package/dist/src/session/signer_session_manager.js +21 -80
- package/dist/src/signer_session.d.ts +15 -252
- package/dist/src/signer_session.js +25 -424
- package/dist/src/user_export.d.ts +52 -0
- package/dist/src/user_export.js +129 -0
- package/dist/src/util.d.ts +15 -0
- package/dist/src/util.js +33 -11
- package/package.json +13 -11
- package/src/api.ts +1395 -0
- package/src/client.ts +413 -12
- package/src/ethers/index.ts +74 -28
- package/src/index.ts +96 -273
- package/src/key.ts +36 -131
- package/src/{fido.ts → mfa.ts} +62 -38
- package/src/org.ts +54 -405
- package/src/response.ts +196 -0
- package/src/role.ts +113 -184
- package/src/schema.ts +936 -28
- package/src/schema_types.ts +110 -0
- package/src/session/cognito_manager.ts +33 -6
- package/src/session/session_manager.ts +2 -8
- package/src/session/signer_session_manager.ts +29 -110
- package/src/signer_session.ts +22 -597
- package/src/user_export.ts +116 -0
- package/src/util.ts +29 -10
package/dist/src/key.d.ts
CHANGED
|
@@ -1,24 +1,25 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { KeyPolicy } from "./role";
|
|
2
|
+
import { KeyInfoApi, KeyTypeApi, SchemaKeyType } from "./schema_types";
|
|
3
|
+
import { CubeSignerClient } from "./client";
|
|
3
4
|
/** Secp256k1 key type */
|
|
4
5
|
export declare enum Secp256k1 {
|
|
5
|
-
Evm = "SecpEthAddr"
|
|
6
|
-
Btc = "SecpBtc"
|
|
7
|
-
BtcTest = "SecpBtcTest"
|
|
8
|
-
Ava = "SecpAvaAddr"
|
|
6
|
+
Evm = "SecpEthAddr",// eslint-disable-line no-unused-vars
|
|
7
|
+
Btc = "SecpBtc",// eslint-disable-line no-unused-vars
|
|
8
|
+
BtcTest = "SecpBtcTest",// eslint-disable-line no-unused-vars
|
|
9
|
+
Ava = "SecpAvaAddr",// eslint-disable-line no-unused-vars
|
|
9
10
|
AvaTest = "SecpAvaTestAddr"
|
|
10
11
|
}
|
|
11
12
|
/** BLS key type */
|
|
12
13
|
export declare enum Bls {
|
|
13
|
-
Eth2Deposited = "BlsPub"
|
|
14
|
+
Eth2Deposited = "BlsPub",// eslint-disable-line no-unused-vars
|
|
14
15
|
Eth2Inactive = "BlsInactive"
|
|
15
16
|
}
|
|
16
17
|
/** Ed25519 key type */
|
|
17
18
|
export declare enum Ed25519 {
|
|
18
|
-
Solana = "Ed25519SolanaAddr"
|
|
19
|
-
Sui = "Ed25519SuiAddr"
|
|
20
|
-
Aptos = "Ed25519AptosAddr"
|
|
21
|
-
Cardano = "Ed25519CardanoAddrVk"
|
|
19
|
+
Solana = "Ed25519SolanaAddr",// eslint-disable-line no-unused-vars
|
|
20
|
+
Sui = "Ed25519SuiAddr",// eslint-disable-line no-unused-vars
|
|
21
|
+
Aptos = "Ed25519AptosAddr",// eslint-disable-line no-unused-vars
|
|
22
|
+
Cardano = "Ed25519CardanoAddrVk",// eslint-disable-line no-unused-vars
|
|
22
23
|
Stellar = "Ed25519StellarAddr"
|
|
23
24
|
}
|
|
24
25
|
/** Mnemonic key type */
|
|
@@ -29,10 +30,6 @@ export declare const Stark: "Stark";
|
|
|
29
30
|
export type Stark = typeof Stark;
|
|
30
31
|
/** Key type */
|
|
31
32
|
export type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark;
|
|
32
|
-
/** Schema key type (i.e., key type at the API level) */
|
|
33
|
-
type SchemaKeyType = components["schemas"]["KeyType"];
|
|
34
|
-
type KeyInfoApi = components["schemas"]["KeyInfo"];
|
|
35
|
-
type KeyTypeApi = components["schemas"]["KeyType"];
|
|
36
33
|
/** Additional properties (for backward compatibility) */
|
|
37
34
|
export interface KeyInfo extends KeyInfoApi {
|
|
38
35
|
/** Alias for key_id */
|
|
@@ -56,24 +53,24 @@ export declare function toKeyInfo(key: KeyInfoApi): KeyInfo;
|
|
|
56
53
|
export declare class Key {
|
|
57
54
|
#private;
|
|
58
55
|
/** The organization that this key is in */
|
|
59
|
-
|
|
56
|
+
get orgId(): string;
|
|
60
57
|
/**
|
|
61
58
|
* The id of the key: "Key#" followed by a unique identifier specific to
|
|
62
59
|
* the type of key (such as a public key for BLS or an ethereum address for Secp)
|
|
63
60
|
* @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148
|
|
64
|
-
|
|
61
|
+
*/
|
|
65
62
|
readonly id: string;
|
|
66
63
|
/**
|
|
67
64
|
* A unique identifier specific to the type of key, such as a public key or an ethereum address
|
|
68
65
|
* @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148
|
|
69
|
-
|
|
66
|
+
*/
|
|
70
67
|
readonly materialId: string;
|
|
71
68
|
/**
|
|
72
69
|
* @description Hex-encoded, serialized public key. The format used depends on the key type:
|
|
73
70
|
* - secp256k1 keys use 65-byte uncompressed SECG format
|
|
74
71
|
* - BLS keys use 48-byte compressed BLS12-381 (ZCash) format
|
|
75
72
|
* @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431
|
|
76
|
-
|
|
73
|
+
*/
|
|
77
74
|
readonly publicKey: string;
|
|
78
75
|
/** The type of key. */
|
|
79
76
|
type(): Promise<KeyType>;
|
|
@@ -101,70 +98,44 @@ export declare class Key {
|
|
|
101
98
|
/**
|
|
102
99
|
* @description Owner of the key
|
|
103
100
|
* @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f
|
|
104
|
-
|
|
101
|
+
*/
|
|
105
102
|
owner(): Promise<string>;
|
|
106
|
-
/**
|
|
103
|
+
/**
|
|
104
|
+
* Set the owner of the key. Only the key (or org) owner can change the owner of the key.
|
|
107
105
|
* @param {string} owner The user-id of the new owner of the key.
|
|
108
|
-
|
|
106
|
+
*/
|
|
109
107
|
setOwner(owner: string): Promise<void>;
|
|
110
108
|
/**
|
|
111
109
|
* Delete this key.
|
|
112
110
|
*/
|
|
113
111
|
delete(): Promise<void>;
|
|
114
|
-
/**
|
|
115
|
-
*
|
|
116
|
-
*
|
|
112
|
+
/**
|
|
113
|
+
* Create a new key.
|
|
114
|
+
*
|
|
115
|
+
* @param {CubeSignerClient} csc The CubeSigner instance to use for signing.
|
|
117
116
|
* @param {KeyInfo} data The JSON response from the API server.
|
|
118
117
|
* @internal
|
|
119
|
-
|
|
120
|
-
constructor(
|
|
121
|
-
/**
|
|
118
|
+
*/
|
|
119
|
+
constructor(csc: CubeSignerClient, data: KeyInfoApi);
|
|
120
|
+
/**
|
|
121
|
+
* Update the key.
|
|
122
122
|
* @param {UpdateKeyRequest} request The JSON request to send to the API server.
|
|
123
123
|
* @return {KeyInfo} The JSON response from the API server.
|
|
124
|
-
|
|
124
|
+
*/
|
|
125
125
|
private update;
|
|
126
|
-
/** Create new signing keys.
|
|
127
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
128
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
129
|
-
* @param {KeyType} keyType The type of key to create.
|
|
130
|
-
* @param {number} count The number of keys to create.
|
|
131
|
-
* @param {string?} ownerId The owner of the keys. Defaults to the session's user.
|
|
132
|
-
* @return {Key[]} The new keys.
|
|
133
|
-
* @internal
|
|
134
|
-
* */
|
|
135
|
-
static createKeys(cs: CubeSigner, orgId: string, keyType: KeyType, count: number, ownerId?: string): Promise<Key[]>;
|
|
136
126
|
/**
|
|
137
|
-
*
|
|
138
|
-
*
|
|
139
|
-
* The owner of the derived key will be the owner of the mnemonic.
|
|
127
|
+
* Fetch the key information.
|
|
140
128
|
*
|
|
141
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for key creation.
|
|
142
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
143
|
-
* @param {KeyType} keyType The type of key to create.
|
|
144
|
-
* @param {string[]} derivationPaths Derivation paths from which to derive new keys.
|
|
145
|
-
* @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
|
|
146
|
-
*
|
|
147
|
-
* @return {Key[]} The newly derived keys.
|
|
148
|
-
*/
|
|
149
|
-
static deriveKeys(cs: CubeSigner, orgId: string, keyType: KeyType, derivationPaths: string[], mnemonicId: string): Promise<Key[]>;
|
|
150
|
-
/** Get a key by id.
|
|
151
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
152
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
153
|
-
* @param {string} keyId The id of the key to get.
|
|
154
|
-
* @return {Key} The key.
|
|
155
|
-
* @internal
|
|
156
|
-
* */
|
|
157
|
-
static getKey(cs: CubeSigner, orgId: string, keyId: string): Promise<Key>;
|
|
158
|
-
/** Fetches the key information.
|
|
159
129
|
* @return {KeyInfo} The key information.
|
|
160
130
|
* @internal
|
|
161
|
-
|
|
131
|
+
*/
|
|
162
132
|
private fetch;
|
|
163
133
|
}
|
|
164
|
-
/**
|
|
134
|
+
/**
|
|
135
|
+
* Convert a schema key type to a key type.
|
|
136
|
+
*
|
|
165
137
|
* @param {SchemaKeyType} ty The schema key type.
|
|
166
138
|
* @return {KeyType} The key type.
|
|
167
139
|
* @internal
|
|
168
|
-
|
|
140
|
+
*/
|
|
169
141
|
export declare function fromSchemaKeyType(ty: SchemaKeyType): KeyType;
|
|
170
|
-
export {};
|
package/dist/src/key.js
CHANGED
|
@@ -10,10 +10,9 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (
|
|
|
10
10
|
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");
|
|
11
11
|
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
12
12
|
};
|
|
13
|
-
var
|
|
13
|
+
var _Key_csc;
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
15
|
exports.fromSchemaKeyType = exports.Key = exports.toKeyInfo = exports.Stark = exports.Mnemonic = exports.Ed25519 = exports.Bls = exports.Secp256k1 = void 0;
|
|
16
|
-
const util_1 = require("./util");
|
|
17
16
|
/** Secp256k1 key type */
|
|
18
17
|
var Secp256k1;
|
|
19
18
|
(function (Secp256k1) {
|
|
@@ -61,6 +60,10 @@ function toKeyInfo(key) {
|
|
|
61
60
|
exports.toKeyInfo = toKeyInfo;
|
|
62
61
|
/** Signing keys. */
|
|
63
62
|
class Key {
|
|
63
|
+
/** The organization that this key is in */
|
|
64
|
+
get orgId() {
|
|
65
|
+
return __classPrivateFieldGet(this, _Key_csc, "f").orgId;
|
|
66
|
+
}
|
|
64
67
|
/** The type of key. */
|
|
65
68
|
async type() {
|
|
66
69
|
const data = await this.fetch();
|
|
@@ -105,14 +108,15 @@ class Key {
|
|
|
105
108
|
/**
|
|
106
109
|
* @description Owner of the key
|
|
107
110
|
* @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f
|
|
108
|
-
|
|
111
|
+
*/
|
|
109
112
|
async owner() {
|
|
110
113
|
const data = await this.fetch();
|
|
111
114
|
return data.owner;
|
|
112
115
|
}
|
|
113
|
-
/**
|
|
116
|
+
/**
|
|
117
|
+
* Set the owner of the key. Only the key (or org) owner can change the owner of the key.
|
|
114
118
|
* @param {string} owner The user-id of the new owner of the key.
|
|
115
|
-
|
|
119
|
+
*/
|
|
116
120
|
async setOwner(owner) {
|
|
117
121
|
await this.update({ owner });
|
|
118
122
|
}
|
|
@@ -120,123 +124,55 @@ class Key {
|
|
|
120
124
|
* Delete this key.
|
|
121
125
|
*/
|
|
122
126
|
async delete() {
|
|
123
|
-
await __classPrivateFieldGet(this,
|
|
127
|
+
await __classPrivateFieldGet(this, _Key_csc, "f").keyDelete(this.id);
|
|
124
128
|
}
|
|
125
129
|
// --------------------------------------------------------------------------
|
|
126
130
|
// -- INTERNAL --------------------------------------------------------------
|
|
127
131
|
// --------------------------------------------------------------------------
|
|
128
|
-
/**
|
|
129
|
-
*
|
|
130
|
-
*
|
|
132
|
+
/**
|
|
133
|
+
* Create a new key.
|
|
134
|
+
*
|
|
135
|
+
* @param {CubeSignerClient} csc The CubeSigner instance to use for signing.
|
|
131
136
|
* @param {KeyInfo} data The JSON response from the API server.
|
|
132
137
|
* @internal
|
|
133
|
-
|
|
134
|
-
constructor(
|
|
138
|
+
*/
|
|
139
|
+
constructor(csc, data) {
|
|
135
140
|
/** The CubeSigner instance that this key is associated with */
|
|
136
|
-
|
|
137
|
-
__classPrivateFieldSet(this,
|
|
138
|
-
this.orgId = orgId;
|
|
141
|
+
_Key_csc.set(this, void 0);
|
|
142
|
+
__classPrivateFieldSet(this, _Key_csc, csc, "f");
|
|
139
143
|
this.id = data.key_id;
|
|
140
144
|
this.materialId = data.material_id;
|
|
141
145
|
this.publicKey = data.public_key;
|
|
142
146
|
}
|
|
143
|
-
/**
|
|
147
|
+
/**
|
|
148
|
+
* Update the key.
|
|
144
149
|
* @param {UpdateKeyRequest} request The JSON request to send to the API server.
|
|
145
150
|
* @return {KeyInfo} The JSON response from the API server.
|
|
146
|
-
|
|
151
|
+
*/
|
|
147
152
|
async update(request) {
|
|
148
|
-
const
|
|
149
|
-
|
|
150
|
-
body: request,
|
|
151
|
-
parseAs: "json",
|
|
152
|
-
});
|
|
153
|
-
return toKeyInfo((0, util_1.assertOk)(resp));
|
|
154
|
-
}
|
|
155
|
-
/** Create new signing keys.
|
|
156
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
157
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
158
|
-
* @param {KeyType} keyType The type of key to create.
|
|
159
|
-
* @param {number} count The number of keys to create.
|
|
160
|
-
* @param {string?} ownerId The owner of the keys. Defaults to the session's user.
|
|
161
|
-
* @return {Key[]} The new keys.
|
|
162
|
-
* @internal
|
|
163
|
-
* */
|
|
164
|
-
static async createKeys(cs, orgId, keyType, count, ownerId) {
|
|
165
|
-
const chain_id = 0; // not used anymore
|
|
166
|
-
const resp = await (await cs.management()).post("/v0/org/{org_id}/keys", {
|
|
167
|
-
params: { path: { org_id: orgId } },
|
|
168
|
-
body: {
|
|
169
|
-
count,
|
|
170
|
-
chain_id,
|
|
171
|
-
key_type: keyType,
|
|
172
|
-
owner: ownerId || null,
|
|
173
|
-
},
|
|
174
|
-
parseAs: "json",
|
|
175
|
-
});
|
|
176
|
-
const data = (0, util_1.assertOk)(resp);
|
|
177
|
-
return data.keys.map((k) => new Key(cs, orgId, k));
|
|
153
|
+
const data = await __classPrivateFieldGet(this, _Key_csc, "f").keyUpdate(this.id, request);
|
|
154
|
+
return toKeyInfo(data);
|
|
178
155
|
}
|
|
179
156
|
/**
|
|
180
|
-
*
|
|
181
|
-
*
|
|
182
|
-
* The owner of the derived key will be the owner of the mnemonic.
|
|
183
|
-
*
|
|
184
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for key creation.
|
|
185
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
186
|
-
* @param {KeyType} keyType The type of key to create.
|
|
187
|
-
* @param {string[]} derivationPaths Derivation paths from which to derive new keys.
|
|
188
|
-
* @param {string} mnemonicId materialId of mnemonic key used to derive the new key.
|
|
157
|
+
* Fetch the key information.
|
|
189
158
|
*
|
|
190
|
-
* @return {Key[]} The newly derived keys.
|
|
191
|
-
*/
|
|
192
|
-
static async deriveKeys(cs, orgId, keyType, derivationPaths, mnemonicId) {
|
|
193
|
-
const resp = await (await cs.management()).put("/v0/org/{org_id}/derive_key", {
|
|
194
|
-
params: { path: { org_id: orgId } },
|
|
195
|
-
body: {
|
|
196
|
-
derivation_path: derivationPaths,
|
|
197
|
-
mnemonic_id: mnemonicId,
|
|
198
|
-
key_type: keyType,
|
|
199
|
-
},
|
|
200
|
-
parseAs: "json",
|
|
201
|
-
});
|
|
202
|
-
const data = (0, util_1.assertOk)(resp);
|
|
203
|
-
return data.keys.map((k) => new Key(cs, orgId, k));
|
|
204
|
-
}
|
|
205
|
-
/** Get a key by id.
|
|
206
|
-
* @param {CubeSigner} cs The CubeSigner instance to use for signing.
|
|
207
|
-
* @param {string} orgId The id of the organization to which the key belongs.
|
|
208
|
-
* @param {string} keyId The id of the key to get.
|
|
209
|
-
* @return {Key} The key.
|
|
210
|
-
* @internal
|
|
211
|
-
* */
|
|
212
|
-
static async getKey(cs, orgId, keyId) {
|
|
213
|
-
const resp = await (await cs.management()).get("/v0/org/{org_id}/keys/{key_id}", {
|
|
214
|
-
params: { path: { org_id: orgId, key_id: keyId } },
|
|
215
|
-
parseAs: "json",
|
|
216
|
-
});
|
|
217
|
-
const data = (0, util_1.assertOk)(resp);
|
|
218
|
-
return new Key(cs, orgId, data);
|
|
219
|
-
}
|
|
220
|
-
/** Fetches the key information.
|
|
221
159
|
* @return {KeyInfo} The key information.
|
|
222
160
|
* @internal
|
|
223
|
-
|
|
161
|
+
*/
|
|
224
162
|
async fetch() {
|
|
225
|
-
const
|
|
226
|
-
params: { path: { org_id: this.orgId, key_id: this.id } },
|
|
227
|
-
parseAs: "json",
|
|
228
|
-
});
|
|
229
|
-
const data = (0, util_1.assertOk)(resp);
|
|
163
|
+
const data = await __classPrivateFieldGet(this, _Key_csc, "f").keyGet(this.id);
|
|
230
164
|
return toKeyInfo(data);
|
|
231
165
|
}
|
|
232
166
|
}
|
|
233
167
|
exports.Key = Key;
|
|
234
|
-
|
|
235
|
-
/**
|
|
168
|
+
_Key_csc = new WeakMap();
|
|
169
|
+
/**
|
|
170
|
+
* Convert a schema key type to a key type.
|
|
171
|
+
*
|
|
236
172
|
* @param {SchemaKeyType} ty The schema key type.
|
|
237
173
|
* @return {KeyType} The key type.
|
|
238
174
|
* @internal
|
|
239
|
-
|
|
175
|
+
*/
|
|
240
176
|
function fromSchemaKeyType(ty) {
|
|
241
177
|
switch (ty) {
|
|
242
178
|
case "SecpEthAddr":
|
|
@@ -270,4 +206,4 @@ function fromSchemaKeyType(ty) {
|
|
|
270
206
|
}
|
|
271
207
|
}
|
|
272
208
|
exports.fromSchemaKeyType = fromSchemaKeyType;
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import { CubeSigner, KeyPolicy } from \".\";\nimport { components } from \"./client\";\nimport { assertOk } from \"./util\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n  Ava = \"SecpAvaAddr\", // eslint-disable-line no-unused-vars\n  AvaTest = \"SecpAvaTestAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n  Cardano = \"Ed25519CardanoAddrVk\", // eslint-disable-line no-unused-vars\n  Stellar = \"Ed25519StellarAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark;\n\n/** Schema key type (i.e., key type at the API level) */\ntype SchemaKeyType = components[\"schemas\"][\"KeyType\"];\n\ntype UpdateKeyRequest = components[\"schemas\"][\"UpdateKeyRequest\"];\ntype KeyInfoApi = components[\"schemas\"][\"KeyInfo\"];\ntype KeyTypeApi = components[\"schemas\"][\"KeyType\"];\n\n/** Additional properties (for backward compatibility) */\nexport interface KeyInfo extends KeyInfoApi {\n  /** Alias for key_id */\n  id: string;\n  /** Alias for key_type */\n  type: KeyTypeApi;\n  /** Alias for material_id */\n  materialId: string;\n  /** Alias for public_key */\n  publicKey: string;\n}\n\n/**\n * Define some additional (backward compatibility) properties\n * on a `KeyInfoApi` object returned from the remote end.\n *\n * @param {KeyInfoApi} key Key information returned from the remote end\n * @return {KeyInfo} The same `key` object extended with some derived properties.\n */\nexport function toKeyInfo(key: KeyInfoApi): KeyInfo {\n  return {\n    ...key,\n    id: key.key_id,\n    type: key.key_type,\n    publicKey: key.public_key,\n    materialId: key.material_id,\n  };\n}\n\n/** Signing keys. */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #cs: CubeSigner;\n  /** The organization that this key is in */\n  readonly orgId: string;\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   * */\n  readonly materialId: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   * */\n  readonly publicKey: string;\n\n  /** The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy} to fetch the current policy and then {@link setPolicy} to set the policy -- and should not be used in across concurrent sessions.\n   * @param {KeyPolicy} policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the org.\n   * @return {Promise<KeyPolicy>} The policy for the org.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * @description Owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   * */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /** Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   * @param {string} owner The user-id of the new owner of the key.\n   * */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  /**\n   * Delete this key.\n   */\n  async delete() {\n    await this.#cs.deleteKey(this.orgId, this.id);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /** Create a new key.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyInfo} data The JSON response from the API server.\n   * @internal\n   * */\n  constructor(cs: CubeSigner, orgId: string, data: KeyInfoApi) {\n    this.#cs = cs;\n    this.orgId = orgId;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n  }\n\n  /** Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   * */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).patch(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      body: request,\n      parseAs: \"json\",\n    });\n    return toKeyInfo(assertOk(resp));\n  }\n\n  /** Create new signing keys.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyType} keyType The type of key to create.\n   * @param {number} count The number of keys to create.\n   * @param {string?} ownerId The owner of the keys. Defaults to the session's user.\n   * @return {Key[]} The new keys.\n   * @internal\n   * */\n  static async createKeys(\n    cs: CubeSigner,\n    orgId: string,\n    keyType: KeyType,\n    count: number,\n    ownerId?: string,\n  ): Promise<Key[]> {\n    const chain_id = 0; // not used anymore\n    const resp = await (\n      await cs.management()\n    ).post(\"/v0/org/{org_id}/keys\", {\n      params: { path: { org_id: orgId } },\n      body: {\n        count,\n        chain_id,\n        key_type: keyType,\n        owner: ownerId || null,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k) => new Key(cs, orgId, k));\n  }\n\n  /**\n   * Derives a key of a specified type using a supplied derivation path and an existing long-lived mnemonic.\n   *\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param {CubeSigner} cs The CubeSigner instance to use for key creation.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {KeyType} keyType The type of key to create.\n   * @param {string[]} derivationPaths Derivation paths from which to derive new keys.\n   * @param {string} mnemonicId materialId of mnemonic key used to derive the new key.\n   *\n   * @return {Key[]} The newly derived keys.\n   */\n  static async deriveKeys(\n    cs: CubeSigner,\n    orgId: string,\n    keyType: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n  ): Promise<Key[]> {\n    const resp = await (\n      await cs.management()\n    ).put(\"/v0/org/{org_id}/derive_key\", {\n      params: { path: { org_id: orgId } },\n      body: {\n        derivation_path: derivationPaths,\n        mnemonic_id: mnemonicId,\n        key_type: keyType,\n      },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return data.keys.map((k) => new Key(cs, orgId, k));\n  }\n\n  /** Get a key by id.\n   * @param {CubeSigner} cs The CubeSigner instance to use for signing.\n   * @param {string} orgId The id of the organization to which the key belongs.\n   * @param {string} keyId The id of the key to get.\n   * @return {Key} The key.\n   * @internal\n   * */\n  static async getKey(cs: CubeSigner, orgId: string, keyId: string): Promise<Key> {\n    const resp = await (\n      await cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: orgId, key_id: keyId } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return new Key(cs, orgId, data);\n  }\n\n  /** Fetches the key information.\n   * @return {KeyInfo} The key information.\n   * @internal\n   * */\n  private async fetch(): Promise<KeyInfo> {\n    const resp = await (\n      await this.#cs.management()\n    ).get(\"/v0/org/{org_id}/keys/{key_id}\", {\n      params: { path: { org_id: this.orgId, key_id: this.id } },\n      parseAs: \"json\",\n    });\n    const data = assertOk(resp);\n    return toKeyInfo(data);\n  }\n}\n\n/** Convert a schema key type to a key type.\n * @param {SchemaKeyType} ty The schema key type.\n * @return {KeyType} The key type.\n * @internal\n * */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n  }\n}\n"]}
|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["../../src/key.ts"],"names":[],"mappings":"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","sourcesContent":["import { KeyPolicy } from \"./role\";\nimport { KeyInfoApi, KeyTypeApi, UpdateKeyRequest, SchemaKeyType } from \"./schema_types\";\nimport { CubeSignerClient } from \"./client\";\n\n/** Secp256k1 key type */\nexport enum Secp256k1 {\n  Evm = \"SecpEthAddr\", // eslint-disable-line no-unused-vars\n  Btc = \"SecpBtc\", // eslint-disable-line no-unused-vars\n  BtcTest = \"SecpBtcTest\", // eslint-disable-line no-unused-vars\n  Ava = \"SecpAvaAddr\", // eslint-disable-line no-unused-vars\n  AvaTest = \"SecpAvaTestAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** BLS key type */\nexport enum Bls {\n  Eth2Deposited = \"BlsPub\", // eslint-disable-line no-unused-vars\n  Eth2Inactive = \"BlsInactive\", // eslint-disable-line no-unused-vars\n}\n\n/** Ed25519 key type */\nexport enum Ed25519 {\n  Solana = \"Ed25519SolanaAddr\", // eslint-disable-line no-unused-vars\n  Sui = \"Ed25519SuiAddr\", // eslint-disable-line no-unused-vars\n  Aptos = \"Ed25519AptosAddr\", // eslint-disable-line no-unused-vars\n  Cardano = \"Ed25519CardanoAddrVk\", // eslint-disable-line no-unused-vars\n  Stellar = \"Ed25519StellarAddr\", // eslint-disable-line no-unused-vars\n}\n\n/** Mnemonic key type */\nexport const Mnemonic = \"Mnemonic\" as const;\nexport type Mnemonic = typeof Mnemonic;\n\n/** Stark key type */\nexport const Stark = \"Stark\" as const;\nexport type Stark = typeof Stark;\n\n/** Key type */\nexport type KeyType = Secp256k1 | Bls | Ed25519 | Mnemonic | Stark;\n\n/** Additional properties (for backward compatibility) */\nexport interface KeyInfo extends KeyInfoApi {\n  /** Alias for key_id */\n  id: string;\n  /** Alias for key_type */\n  type: KeyTypeApi;\n  /** Alias for material_id */\n  materialId: string;\n  /** Alias for public_key */\n  publicKey: string;\n}\n\n/**\n * Define some additional (backward compatibility) properties\n * on a `KeyInfoApi` object returned from the remote end.\n *\n * @param {KeyInfoApi} key Key information returned from the remote end\n * @return {KeyInfo} The same `key` object extended with some derived properties.\n */\nexport function toKeyInfo(key: KeyInfoApi): KeyInfo {\n  return {\n    ...key,\n    id: key.key_id,\n    type: key.key_type,\n    publicKey: key.public_key,\n    materialId: key.material_id,\n  };\n}\n\n/** Signing keys. */\nexport class Key {\n  /** The CubeSigner instance that this key is associated with */\n  readonly #csc: CubeSignerClient;\n\n  /** The organization that this key is in */\n  get orgId() {\n    return this.#csc.orgId;\n  }\n\n  /**\n   * The id of the key: \"Key#\" followed by a unique identifier specific to\n   * the type of key (such as a public key for BLS or an ethereum address for Secp)\n   * @example Key#0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly id: string;\n\n  /**\n   * A unique identifier specific to the type of key, such as a public key or an ethereum address\n   * @example 0x8e3484687e66cdd26cf04c3647633ab4f3570148\n   */\n  readonly materialId: string;\n\n  /**\n   * @description Hex-encoded, serialized public key. The format used depends on the key type:\n   * - secp256k1 keys use 65-byte uncompressed SECG format\n   * - BLS keys use 48-byte compressed BLS12-381 (ZCash) format\n   * @example 0x04d2688b6bc2ce7f9879b9e745f3c4dc177908c5cef0c1b64cff19ae7ff27dee623c64fe9d9c325c7fbbc748bbd5f607ce14dd83e28ebbbb7d3e7f2ffb70a79431\n   */\n  readonly publicKey: string;\n\n  /** The type of key. */\n  async type(): Promise<KeyType> {\n    const data = await this.fetch();\n    return fromSchemaKeyType(data.key_type);\n  }\n\n  /** Is the key enabled? */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the key. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the key. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /**\n   * Set new policy (overwriting any policies previously set for this key)\n   * @param {KeyPolicy} policy The new policy to set\n   */\n  async setPolicy(policy: KeyPolicy) {\n    await this.update({ policy: policy as unknown as Record<string, never>[] });\n  }\n\n  /**\n   * Append to existing key policy. This append is not atomic -- it uses {@link policy} to fetch the current policy and then {@link setPolicy} to set the policy -- and should not be used in across concurrent sessions.\n   * @param {KeyPolicy} policy The policy to append to the existing one.\n   */\n  async appendPolicy(policy: KeyPolicy) {\n    const existing = await this.policy();\n    await this.setPolicy([...existing, ...policy]);\n  }\n\n  /**\n   * Get the policy for the org.\n   * @return {Promise<KeyPolicy>} The policy for the org.\n   */\n  async policy(): Promise<KeyPolicy> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as KeyPolicy;\n  }\n\n  /**\n   * @description Owner of the key\n   * @example User#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  async owner(): Promise<string> {\n    const data = await this.fetch();\n    return data.owner;\n  }\n\n  /**\n   * Set the owner of the key. Only the key (or org) owner can change the owner of the key.\n   * @param {string} owner The user-id of the new owner of the key.\n   */\n  async setOwner(owner: string) {\n    await this.update({ owner });\n  }\n\n  /**\n   * Delete this key.\n   */\n  async delete() {\n    await this.#csc.keyDelete(this.id);\n  }\n\n  // --------------------------------------------------------------------------\n  // -- INTERNAL --------------------------------------------------------------\n  // --------------------------------------------------------------------------\n\n  /**\n   * Create a new key.\n   *\n   * @param {CubeSignerClient} csc The CubeSigner instance to use for signing.\n   * @param {KeyInfo} data The JSON response from the API server.\n   * @internal\n   */\n  constructor(csc: CubeSignerClient, data: KeyInfoApi) {\n    this.#csc = csc;\n    this.id = data.key_id;\n    this.materialId = data.material_id;\n    this.publicKey = data.public_key;\n  }\n\n  /**\n   * Update the key.\n   * @param {UpdateKeyRequest} request The JSON request to send to the API server.\n   * @return {KeyInfo} The JSON response from the API server.\n   */\n  private async update(request: UpdateKeyRequest): Promise<KeyInfo> {\n    const data = await this.#csc.keyUpdate(this.id, request);\n    return toKeyInfo(data);\n  }\n\n  /**\n   * Fetch the key information.\n   *\n   * @return {KeyInfo} The key information.\n   * @internal\n   */\n  private async fetch(): Promise<KeyInfo> {\n    const data = await this.#csc.keyGet(this.id);\n    return toKeyInfo(data);\n  }\n}\n\n/**\n * Convert a schema key type to a key type.\n *\n * @param {SchemaKeyType} ty The schema key type.\n * @return {KeyType} The key type.\n * @internal\n */\nexport function fromSchemaKeyType(ty: SchemaKeyType): KeyType {\n  switch (ty) {\n    case \"SecpEthAddr\":\n      return Secp256k1.Evm;\n    case \"SecpBtc\":\n      return Secp256k1.Btc;\n    case \"SecpBtcTest\":\n      return Secp256k1.BtcTest;\n    case \"SecpAvaAddr\":\n      return Secp256k1.Ava;\n    case \"SecpAvaTestAddr\":\n      return Secp256k1.AvaTest;\n    case \"BlsPub\":\n      return Bls.Eth2Deposited;\n    case \"BlsInactive\":\n      return Bls.Eth2Inactive;\n    case \"Ed25519SolanaAddr\":\n      return Ed25519.Solana;\n    case \"Ed25519SuiAddr\":\n      return Ed25519.Sui;\n    case \"Ed25519AptosAddr\":\n      return Ed25519.Aptos;\n    case \"Ed25519CardanoAddrVk\":\n      return Ed25519.Cardano;\n    case \"Ed25519StellarAddr\":\n      return Ed25519.Stellar;\n    case \"Stark\":\n      return Stark;\n    case \"Mnemonic\":\n      return Mnemonic;\n  }\n}\n"]}
|
package/dist/src/mfa.d.ts
CHANGED
|
@@ -1,23 +1,94 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ApiAddFidoChallenge, ApiMfaFidoChallenge, MfaRequestInfo, TotpInfo } from "./schema_types";
|
|
2
|
+
import { CubeSignerApi } from "./api";
|
|
3
|
+
/** MFA receipt */
|
|
4
|
+
export interface MfaReceipt {
|
|
5
|
+
/** MFA request ID */
|
|
6
|
+
mfaId: string;
|
|
7
|
+
/** Corresponding org ID */
|
|
8
|
+
mfaOrgId: string;
|
|
9
|
+
/** MFA confirmation code */
|
|
10
|
+
mfaConf: string;
|
|
11
|
+
}
|
|
12
|
+
/** TOTP challenge that must be answered before user's TOTP is updated */
|
|
13
|
+
export declare class TotpChallenge {
|
|
14
|
+
#private;
|
|
15
|
+
/** The id of the challenge */
|
|
16
|
+
get totpId(): string;
|
|
17
|
+
/** The new TOTP configuration */
|
|
18
|
+
get totpUrl(): string;
|
|
19
|
+
/**
|
|
20
|
+
* @param {CubeSignerApi} api Used when answering the challenge.
|
|
21
|
+
* @param {TotpInfo} totpInfo TOTP challenge information.
|
|
22
|
+
*/
|
|
23
|
+
constructor(api: CubeSignerApi, totpInfo: TotpInfo);
|
|
24
|
+
/**
|
|
25
|
+
* Answer the challenge with the code that corresponds to `this.totpUrl`.
|
|
26
|
+
* @param {string} code 6-digit code that corresponds to `this.totpUrl`.
|
|
27
|
+
*/
|
|
28
|
+
answer(code: string): Promise<void>;
|
|
29
|
+
}
|
|
2
30
|
/**
|
|
3
|
-
*
|
|
4
|
-
*
|
|
31
|
+
* Returned after creating a request to add a new FIDO device.
|
|
32
|
+
* Provides some helper methods for answering this challenge.
|
|
5
33
|
*/
|
|
6
|
-
export declare class
|
|
34
|
+
export declare class AddFidoChallenge {
|
|
7
35
|
#private;
|
|
36
|
+
readonly challengeId: string;
|
|
37
|
+
readonly options: any;
|
|
38
|
+
/**
|
|
39
|
+
* Constructor
|
|
40
|
+
* @param {CubeSignerApi} api The API client used to request to add a FIDO device
|
|
41
|
+
* @param {ApiAddFidoChallenge} challenge The challenge returned by the remote end.
|
|
42
|
+
*/
|
|
43
|
+
constructor(api: CubeSignerApi, challenge: ApiAddFidoChallenge);
|
|
44
|
+
/**
|
|
45
|
+
* Answers this challenge by using the `CredentialsContainer` API to create a credential
|
|
46
|
+
* based on the the public key credential creation options from this challenge.
|
|
47
|
+
*/
|
|
48
|
+
createCredentialAndAnswer(): Promise<void>;
|
|
8
49
|
/**
|
|
9
|
-
*
|
|
50
|
+
* Answers this challenge using a given credential `cred`;
|
|
51
|
+
* the credential should be obtained by calling
|
|
10
52
|
*
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
*
|
|
53
|
+
* ```
|
|
54
|
+
* const cred = await navigator.credentials.create({ publicKey: this.options });
|
|
55
|
+
* ```
|
|
56
|
+
*
|
|
57
|
+
* @param {any} cred Credential created by calling the `CredentialContainer`'s `create` method
|
|
58
|
+
* based on the public key creation options from this challenge.
|
|
14
59
|
*/
|
|
15
|
-
|
|
16
|
-
|
|
60
|
+
answer(cred: any): Promise<void>;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Returned after initiating MFA approval using FIDO.
|
|
64
|
+
* Provides some helper methods for answering this challenge.
|
|
65
|
+
*/
|
|
66
|
+
export declare class MfaFidoChallenge {
|
|
67
|
+
#private;
|
|
68
|
+
readonly mfaId: string;
|
|
69
|
+
readonly challengeId: string;
|
|
70
|
+
readonly options: any;
|
|
17
71
|
/**
|
|
18
|
-
*
|
|
19
|
-
* @param {
|
|
20
|
-
* @param {
|
|
72
|
+
* @param {CubeSignerApi} api The API client used to initiate MFA approval using FIDO
|
|
73
|
+
* @param {string} mfaId The MFA request id.
|
|
74
|
+
* @param {ApiMfaFidoChallenge} challenge The challenge returned by the remote end
|
|
75
|
+
*/
|
|
76
|
+
constructor(api: CubeSignerApi, mfaId: string, challenge: ApiMfaFidoChallenge);
|
|
77
|
+
/**
|
|
78
|
+
* Answers this challenge by using the `CredentialsContainer` API to get a credential
|
|
79
|
+
* based on the the public key credential request options from this challenge.
|
|
80
|
+
*/
|
|
81
|
+
createCredentialAndAnswer(): Promise<MfaRequestInfo>;
|
|
82
|
+
/**
|
|
83
|
+
* Answers this challenge using a given credential `cred`.
|
|
84
|
+
* To obtain this credential, for example, call
|
|
85
|
+
*
|
|
86
|
+
* ```
|
|
87
|
+
* const cred = await navigator.credentials.get({ publicKey: this.options });
|
|
88
|
+
* ```
|
|
89
|
+
*
|
|
90
|
+
* @param {any} cred Credential created by calling the `CredentialContainer`'s `get` method
|
|
91
|
+
* based on the public key credential request options from this challenge.
|
|
21
92
|
*/
|
|
22
|
-
|
|
93
|
+
answer(cred: any): Promise<MfaRequestInfo>;
|
|
23
94
|
}
|