@cubist-labs/cubesigner-sdk 0.4.222 → 0.4.223
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 +1 -1
- package/dist/src/org.d.ts +22 -1
- package/dist/src/org.d.ts.map +1 -1
- package/dist/src/org.js +35 -1
- package/dist/src/schema.d.ts +207 -10
- package/dist/src/schema.d.ts.map +1 -1
- package/dist/src/schema.js +1 -1
- package/dist/src/schema_types.d.ts +2 -0
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/package.json +1 -1
- package/src/org.ts +42 -0
- package/src/schema.ts +217 -7
- package/src/schema_types.ts +2 -0
package/dist/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"url": "git+https://github.com/cubist-labs/CubeSigner-TypeScript-SDK.git",
|
|
6
6
|
"directory": "packages/sdk"
|
|
7
7
|
},
|
|
8
|
-
"version": "0.4.
|
|
8
|
+
"version": "0.4.223",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
package/dist/src/org.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { KeyType, KeyProperties, NotificationEndpointConfiguration, PageOpts, UserInOrgInfo, ApiClient, OrgInfo, MfaId, ImportKeyRequest, KeyPolicy, QueryMetricsResponse, OrgMetricName, QueryMetricsRequest, KeyTypeAndDerivationPath, JsonValue, EditPolicy, AddressMap, CreateOrgRequest, RolePolicy, C2FConfiguration, MfaProtectedAction, MfaType, PolicyType, PolicyAcl, ContactLabel, ContactAddressData } from ".";
|
|
1
|
+
import type { KeyType, KeyProperties, NotificationEndpointConfiguration, PageOpts, UserInOrgInfo, ApiClient, OrgInfo, MfaId, ImportKeyRequest, KeyPolicy, QueryMetricsResponse, OrgMetricName, QueryMetricsRequest, KeyTypeAndDerivationPath, JsonValue, EditPolicy, AddressMap, CreateOrgRequest, RolePolicy, C2FConfiguration, MfaProtectedAction, MfaType, PolicyType, PolicyAcl, ContactLabel, ContactAddressData, OrgExtProps, OrgExtData } from ".";
|
|
2
2
|
import { Contact } from "./contact";
|
|
3
3
|
import { C2FFunction, Key, MfaRequest, Role } from ".";
|
|
4
4
|
import { type NamedKeyPolicy, NamedPolicy, type NamedRolePolicy } from "./policy";
|
|
@@ -187,6 +187,27 @@ export declare class Org {
|
|
|
187
187
|
* @param policy The new policy for the org.
|
|
188
188
|
*/
|
|
189
189
|
setPolicy(policy: OrgPolicy[]): Promise<void>;
|
|
190
|
+
/**
|
|
191
|
+
* Retrieve the organization's extended properties (uncommon features not used by most users).
|
|
192
|
+
*
|
|
193
|
+
* @returns The extended properties
|
|
194
|
+
*/
|
|
195
|
+
getExtendedProperties(): Promise<OrgExtData | null>;
|
|
196
|
+
/**
|
|
197
|
+
* Update the organization's extended properties (uncommon features not used by most users).
|
|
198
|
+
*
|
|
199
|
+
* @param props The new properties.
|
|
200
|
+
*/
|
|
201
|
+
setExtendedProperties(props: OrgExtProps): Promise<void>;
|
|
202
|
+
/**
|
|
203
|
+
* Update the per-alien key count threshold, which, once exceeded, disallows further key creation by alien users.
|
|
204
|
+
*
|
|
205
|
+
* This setting is checked only when an alien user requests to create or import a new key.
|
|
206
|
+
* In other words, org admins can still assign unlimited number of keys to their alien users.
|
|
207
|
+
*
|
|
208
|
+
* @param alienKeyCountThreshold The new key count threshold.
|
|
209
|
+
*/
|
|
210
|
+
setAlienKeyCountThreshold(alienKeyCountThreshold: number): Promise<void>;
|
|
190
211
|
/**
|
|
191
212
|
* Set the notification endpoints for the org.
|
|
192
213
|
*
|
package/dist/src/org.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"org.d.ts","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,aAAa,EACb,iCAAiC,EACjC,QAAQ,EACR,aAAa,EACb,SAAS,EACT,OAAO,EACP,KAAK,EACL,gBAAgB,EAChB,SAAS,EACT,oBAAoB,EACpB,aAAa,EACb,mBAAmB,EACnB,wBAAwB,EACxB,SAAS,EACT,UAAU,EACV,UAAU,EACV,gBAAgB,EAChB,UAAU,EACV,gBAAgB,EAChB,kBAAkB,EAClB,OAAO,EACP,UAAU,EACV,SAAS,EACT,YAAY,EACZ,kBAAkB,
|
|
1
|
+
{"version":3,"file":"org.d.ts","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":"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"}
|
package/dist/src/org.js
CHANGED
|
@@ -148,6 +148,40 @@ class Org {
|
|
|
148
148
|
const p = policy;
|
|
149
149
|
await this.update({ policy: p });
|
|
150
150
|
}
|
|
151
|
+
/**
|
|
152
|
+
* Retrieve the organization's extended properties (uncommon features not used by most users).
|
|
153
|
+
*
|
|
154
|
+
* @returns The extended properties
|
|
155
|
+
*/
|
|
156
|
+
async getExtendedProperties() {
|
|
157
|
+
const data = await this.fetch();
|
|
158
|
+
return data.ext_data ? data.ext_data : null;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Update the organization's extended properties (uncommon features not used by most users).
|
|
162
|
+
*
|
|
163
|
+
* @param props The new properties.
|
|
164
|
+
*/
|
|
165
|
+
async setExtendedProperties(props) {
|
|
166
|
+
await this.update({ ext_props: props });
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Update the per-alien key count threshold, which, once exceeded, disallows further key creation by alien users.
|
|
170
|
+
*
|
|
171
|
+
* This setting is checked only when an alien user requests to create or import a new key.
|
|
172
|
+
* In other words, org admins can still assign unlimited number of keys to their alien users.
|
|
173
|
+
*
|
|
174
|
+
* @param alienKeyCountThreshold The new key count threshold.
|
|
175
|
+
*/
|
|
176
|
+
async setAlienKeyCountThreshold(alienKeyCountThreshold) {
|
|
177
|
+
const data = { ...((await this.getExtendedProperties()) ?? {}) };
|
|
178
|
+
// erase the metadata that cannot be updated
|
|
179
|
+
data.created = undefined;
|
|
180
|
+
data.last_modified = undefined;
|
|
181
|
+
// update 'alien_key_count_threshold' and keep everything else the same
|
|
182
|
+
data.alien_key_count_threshold = alienKeyCountThreshold;
|
|
183
|
+
await this.update({ ext_props: data });
|
|
184
|
+
}
|
|
151
185
|
/**
|
|
152
186
|
* Set the notification endpoints for the org.
|
|
153
187
|
*
|
|
@@ -708,4 +742,4 @@ class Org {
|
|
|
708
742
|
}
|
|
709
743
|
exports.Org = Org;
|
|
710
744
|
_Org_apiClient = new WeakMap(), _Org_orgId = new WeakMap(), _Org_data = new WeakMap();
|
|
711
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"org.js","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  KeyType,\n  KeyProperties,\n  NotificationEndpointConfiguration,\n  PageOpts,\n  UserInOrgInfo,\n  ApiClient,\n  OrgInfo,\n  MfaId,\n  ImportKeyRequest,\n  KeyPolicy,\n  QueryMetricsResponse,\n  OrgMetricName,\n  QueryMetricsRequest,\n  KeyTypeAndDerivationPath,\n  JsonValue,\n  EditPolicy,\n  AddressMap,\n  CreateOrgRequest,\n  RolePolicy,\n  C2FConfiguration,\n  MfaProtectedAction,\n  MfaType,\n  PolicyType,\n  PolicyAcl,\n  ContactLabel,\n  ContactAddressData,\n} from \".\";\nimport { Contact } from \"./contact\";\nimport { C2FFunction, Key, MfaRequest, Role } from \".\";\nimport {\n  type NamedKeyPolicy,\n  NamedPolicy,\n  type NamedRolePolicy,\n  uploadWasmFunction,\n  type C2FInfo,\n} from \"./policy\";\n\n/** Options pased to createKey and deriveKey */\nexport type CreateKeyProperties = Omit<KeyProperties, \"policy\"> & {\n  /**\n   * Policies to apply to the new key.\n   *\n   * This type makes it possible to assign values like\n   * `[AllowEip191SigningPolicy]`, but remains backwards\n   * compatible with prior versions of the SDK, in which\n   * this property had type `Record<string, never>[] | null`.\n   */\n  policy?: KeyPolicy | unknown[] | null;\n};\n\n/** Options passed to importKey and deriveKey */\nexport type ImportDeriveKeyProperties = CreateKeyProperties & {\n  /**\n   * When true, returns a 'Key' object for both new and existing keys.\n   */\n  idempotent?: boolean;\n};\n\n/** Options passed to deriveMultipleKeyTypes */\nexport type DeriveMultipleKeyTypesProperties = ImportDeriveKeyProperties & {\n  /**\n   * The material_id of the mnemonic used to derive new keys.\n   *\n   * If this argument is undefined or null, a new mnemonic is first created\n   * and any other specified properties are applied to it (in addition to\n   * being applied to the specified keys).\n   *\n   * The newly created mnemonic-id can be retrieved from the `derivation_info`\n   * property of the `KeyInfo` value for a resulting key.\n   */\n  mnemonic_id?: string;\n};\n\n/** Organization id */\nexport type OrgId = string;\n\n/** Org-wide policy */\nexport type OrgPolicy =\n  | SourceIpAllowlistPolicy\n  | OidcAuthSourcesPolicy\n  | OriginAllowlistPolicy\n  | MaxDailyUnstakePolicy\n  | WebAuthnRelyingPartiesPolicy\n  | ExclusiveKeyAccessPolicy;\n\n/**\n * Whether to enforce exclusive access to keys.  Concretely,\n * - if \"LimitToKeyOwner\" is set, only key owners are permitted to access\n *   their keys for signing: a user session (not a role session) is required\n *   for signing, and adding a key to a role is not permitted.\n * - if \"LimitToSingleRole\" is set, each key is permitted to be in at most\n *   one role, and signing is only allowed when authenticating using a role session token.\n */\nexport interface ExclusiveKeyAccessPolicy {\n  ExclusiveKeyAccess: \"LimitToKeyOwner\" | \"LimitToSingleRole\";\n}\n\n/**\n * The set of relying parties to allow for webauthn registration\n * These correspond to domains from which browsers can successfully create credentials.\n */\nexport interface WebAuthnRelyingPartiesPolicy {\n  WebAuthnRelyingParties: { id?: string; name: string }[];\n}\n\n/**\n * Provides an allowlist of OIDC Issuers and audiences that are allowed to authenticate into this org.\n *\n * @example {\"OidcAuthSources\": { \"https://accounts.google.com\": [ \"1234.apps.googleusercontent.com\" ]}}\n */\nexport interface OidcAuthSourcesPolicy {\n  OidcAuthSources: Record<string, string[] | IssuerConfig>;\n}\n\n/** OIDC issuer configuration */\nexport interface IssuerConfig {\n  /** The set of audiences supported for this issuer */\n  auds: string[];\n\n  /** The kinds of user allowed to authenticate with this issuer */\n  users: string[];\n\n  /** Optional nickname for this provider */\n  nickname?: string;\n\n  /** Whether to make this issuer public */\n  public?: boolean;\n}\n\n/**\n * Only allow requests from the specified origins.\n *\n * @example {\"OriginAllowlist\": \"*\"}\n */\nexport interface OriginAllowlistPolicy {\n  OriginAllowlist: string[] | \"*\";\n}\n\n/**\n * Restrict signing to specific source IP addresses.\n *\n * @example {\"SourceIpAllowlist\": [\"10.1.2.3/8\", \"169.254.17.1/16\"]}\n */\nexport interface SourceIpAllowlistPolicy {\n  SourceIpAllowlist: string[];\n}\n\n/**\n * Restrict the number of unstakes per day.\n *\n * @example {\"MaxDailyUnstake\": 5 }\n */\nexport interface MaxDailyUnstakePolicy {\n  MaxDailyUnstake: number;\n}\n\n/**\n * Filter to use when listing keys\n */\nexport interface KeyFilter {\n  /** Filter by key type */\n  type?: KeyType;\n  /** Filter by key owner */\n  owner?: string;\n  /** Search by key's material id and metadata */\n  search?: string;\n  /** Pagination options */\n  page?: PageOpts;\n}\n\n/**\n * An organization.\n *\n * Extends {@link CubeSignerClient} and provides a few org-specific methods on top.\n */\nexport class Org {\n  readonly #apiClient: ApiClient;\n  #orgId: OrgId;\n  /** The org information */\n  #data?: OrgInfo;\n\n  /**\n   * @returns The org id\n   * @example Org#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  get id(): OrgId {\n    return this.#orgId;\n  }\n\n  /**\n   * @returns The cached properties of this org. The cached properties reflect the\n   * state of the last fetch or update.\n   */\n  get cached(): OrgInfo | undefined {\n    return this.#data;\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param orgId The id of the org\n   */\n  constructor(apiClient: ApiClient, orgId: string) {\n    this.#orgId = orgId;\n    this.#apiClient = orgId === apiClient.orgId ? apiClient : apiClient.withTargetOrg(orgId);\n  }\n\n  /**\n   * Create a new organization. The new org is a child of the\n   * current org and inherits its key-export policy. The new org\n   * is created with one owner, the caller of this API.\n   *\n   * @param nameOrRequest The name of the new org or the properties of the new org.\n   * @returns Information about the newly created org.\n   */\n  async createOrg(nameOrRequest: string | CreateOrgRequest): Promise<OrgInfo> {\n    const req = typeof nameOrRequest === \"string\" ? { name: nameOrRequest } : nameOrRequest;\n    if (!/^[a-zA-Z0-9_]{3,30}$/.test(req.name)) {\n      throw new Error(\"Org name must be alphanumeric and between 3 and 30 characters\");\n    }\n    return await this.#apiClient.orgCreateOrg(req);\n  }\n\n  /**\n   * Query org metrics.\n   *\n   * @param metricName The metric name.\n   * @param startTime The start date in seconds since unix epoch.\n   * @param opt Other optional arguments\n   * @param opt.end_time The end date in seconds since unix epoch. If omitted, defaults to 'now'.\n   * @param opt.period The granularity, in seconds, of the returned data points.\n   *   This value is automatically rounded up to a multiple of 3600 (i.e., 1 hour).\n   *   If omitted, defaults to the duration between the start and the end date.\n   *   Must be no less than 1 hour, i.e., 3600 seconds. Additionally, this period must not\n   *   divide the `endTime - startTime` period into more than 100 data points.\n   * @param pageOpts Pagination options.\n   * @returns Metric values (data points) for the requested periods.\n   */\n  async queryMetrics(\n    metricName: OrgMetricName,\n    startTime: EpochTimeStamp,\n    opt?: Omit<QueryMetricsRequest, \"metric_name\" | \"start_time\">,\n    pageOpts?: PageOpts,\n  ): Promise<QueryMetricsResponse> {\n    const req: QueryMetricsRequest = {\n      metric_name: metricName,\n      start_time: startTime,\n      ...opt,\n    };\n    return await this.#apiClient.orgQueryMetrics(req, pageOpts).fetchAll();\n  }\n\n  /**\n   * Fetch the org information.\n   *\n   * @returns The org information.\n   */\n  async fetch(): Promise<OrgInfo> {\n    this.#data = await this.#apiClient.orgGet();\n    return this.#data;\n  }\n\n  /** @returns The human-readable name for the org */\n  async name(): Promise<string | undefined> {\n    const data = await this.fetch();\n    return data.name ?? undefined;\n  }\n\n  /** @returns Whether the org is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the org. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the org. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /** @returns the policy for the org. */\n  async policy(): Promise<OrgPolicy[]> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as OrgPolicy[];\n  }\n\n  /**\n   * Set the policy for the org.\n   *\n   * @param policy The new policy for the org.\n   */\n  async setPolicy(policy: OrgPolicy[]) {\n    const p = policy as unknown as Record<string, never>[];\n    await this.update({ policy: p });\n  }\n\n  /**\n   * Set the notification endpoints for the org.\n   *\n   * @param notification_endpoints Endpoints.\n   */\n  async setNotificationEndpoints(notification_endpoints: NotificationEndpointConfiguration[]) {\n    await this.update({\n      notification_endpoints,\n    });\n  }\n\n  /**\n   * Set required MFA types for actions implicitly requiring MFA (see {@link MfaProtectedAction}).\n   *\n   * @param allowed_mfa_types Assignment of MFA types to actions that implicitly require MFA.\n   */\n  async setAllowedMfaTypes(allowed_mfa_types: Partial<Record<MfaProtectedAction, MfaType[]>>) {\n    await this.update({\n      allowed_mfa_types,\n    });\n  }\n\n  /**\n   * Create a new signing key.\n   *\n   * @param type The type of key to create.\n   * @param ownerId The owner of the key. Defaults to the session's user.\n   * @param props Additional properties to set on the new key.\n   * @returns The new keys.\n   */\n  async createKey(type: KeyType, ownerId?: string, props?: CreateKeyProperties): Promise<Key> {\n    const keys = await this.#apiClient.keysCreate(type, 1, ownerId, props);\n    return new Key(this.#apiClient, keys[0]);\n  }\n\n  /**\n   * Create new signing keys.\n   *\n   * @param type The type of key to create.\n   * @param count The number of keys to create.\n   * @param ownerId The owner of the keys. Defaults to the session's user.\n   * @param props Additional properties to set on the new keys.\n   * @returns The new keys.\n   */\n  async createKeys(\n    type: KeyType,\n    count: number,\n    ownerId?: string,\n    props?: CreateKeyProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysCreate(type, count, ownerId, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Create a new (first-party) user in the organization and sends an invitation to that user.\n   *\n   * Same as {@link ApiClient.orgUserInvite}, see its documentation for more information.\n   *\n   * @returns A function that invites a user\n   */\n  get createUser() {\n    return this.#apiClient.orgUserInvite.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an existing user.\n   *\n   * Same as {@link ApiClient.orgUserDelete}, see its documentation for more information.\n   *\n   * @returns A function that deletes a user\n   */\n  get deleteUser() {\n    return this.#apiClient.orgUserDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   *\n   * Same as {@link ApiClient.orgUserCreateOidc}, see its documentation for more information.\n   *\n   * @returns A function that creates an OIDC user, resolving to the new user's ID\n   */\n  get createOidcUser() {\n    return this.#apiClient.orgUserCreateOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   *\n   * Same as {@link ApiClient.orgUserDeleteOidc}, see its documentation for more information.\n   *\n   * @returns A function that deletes an OIDC user\n   */\n  get deleteOidcUser() {\n    return this.#apiClient.orgUserDeleteOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * List all users in the organization.\n   *\n   * @param searchQuery Optional query string. If defined, all returned users will contain this string in their name or email.\n   * @returns The list of users\n   */\n  async users(searchQuery?: string): Promise<UserInOrgInfo[]> {\n    return await this.#apiClient.orgUsersList(undefined, searchQuery).fetchAll();\n  }\n\n  /**\n   * List users in the organization (paginated).\n   *\n   * Same as {@link ApiClient.orgUsersList}, see its documentation for more information.\n   *\n   * @returns A function that returns a paginated list of users\n   */\n  get usersPaginated() {\n    return this.#apiClient.orgUsersList.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by id.\n   *\n   * Same as {@link ApiClient.orgUserGet}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUser() {\n    return this.#apiClient.orgUserGet.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by email.\n   *\n   * Same as {@link ApiClient.orgUserGetByEmail}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUserByEmail() {\n    return this.#apiClient.orgUserGetByEmail.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by OIDC ID.\n   *\n   * Same as {@link ApiClient.orgUserGetByOidc}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUserByOidc() {\n    return this.#apiClient.orgUserGetByOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * Enable a user in this org\n   *\n   * @param userId The user whose membership to enable\n   * @returns The updated user's membership\n   */\n  async enableUser(userId: string): Promise<UserInOrgInfo> {\n    return await this.#apiClient.orgUpdateUserMembership(userId, { disabled: false });\n  }\n\n  /**\n   * Disable a user in this org\n   *\n   * @param userId The user whose membership to disable\n   * @returns The updated user's membership\n   */\n  async disableUser(userId: string): Promise<UserInOrgInfo> {\n    return await this.#apiClient.orgUpdateUserMembership(userId, { disabled: true });\n  }\n\n  /**\n   * Get the accessible keys in the organization\n   *\n   * @param props Optional filtering properties.\n   * @returns The keys.\n   */\n  async keys(props?: KeyFilter): Promise<Key[]> {\n    const paginator = this.#apiClient.keysList(\n      props?.type,\n      props?.page,\n      props?.owner,\n      props?.search,\n    );\n    const keys = await paginator.fetch();\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Create a new role.\n   *\n   * @param name The name of the role.\n   * @returns The new role.\n   */\n  async createRole(name?: string): Promise<Role> {\n    const roleId = await this.#apiClient.roleCreate(name);\n    const roleInfo = await this.#apiClient.roleGet(roleId);\n    return new Role(this.#apiClient, roleInfo);\n  }\n\n  /**\n   * Get a role by id or name.\n   *\n   * @param roleId The id or name of the role to get.\n   * @returns The role.\n   */\n  async getRole(roleId: string): Promise<Role> {\n    const roleInfo = await this.#apiClient.roleGet(roleId);\n    return new Role(this.#apiClient, roleInfo);\n  }\n\n  /**\n   * Gets all the roles in the org\n   *\n   * @param page The paginator options\n   * @returns The roles\n   */\n  async roles(page: PageOpts): Promise<Role[]> {\n    const roles = await this.#apiClient.rolesList(page).fetch();\n    return roles.map((r) => new Role(this.#apiClient, r));\n  }\n\n  /**\n   * Create a new named policy.\n   *\n   * @param name The name of the policy.\n   * @param type The type of the policy.\n   * @param rules The policy rules.\n   * @param acl Optional list of policy access control entries.\n   * @returns The new policy.\n   */\n  async createPolicy<Type extends \"Key\" | \"Role\">(\n    name: string,\n    type: Type,\n    rules: Type extends \"Key\" ? KeyPolicy : RolePolicy,\n    acl?: PolicyAcl,\n  ): Promise<Type extends \"Key\" ? NamedKeyPolicy : NamedRolePolicy> {\n    const policyInfo = await this.#apiClient.policyCreate(name, type, rules, acl);\n    const policy = NamedPolicy.fromInfo(this.#apiClient, policyInfo);\n    return policy as Type extends \"Key\" ? NamedKeyPolicy : NamedRolePolicy;\n  }\n\n  /**\n   * Get a named policy by id or name.\n   *\n   * @param policyId The id or name of the policy to get.\n   * @returns The policy.\n   */\n  async getPolicy(policyId: string): Promise<NamedPolicy> {\n    const policyInfo = await this.#apiClient.policyGet(policyId, \"latest\");\n    return NamedPolicy.fromInfo(this.#apiClient, policyInfo);\n  }\n\n  /**\n   * Get a Confidential Cloud Function by name or named policy ID.\n   *\n   * @param functionId The name or named policy ID of the function to get.\n   * @returns The C2F function.\n   * @throws if name or ID is not associated to a C2F function (i.e. the name/id is for a key or role named policy)\n   */\n  async getFunction(functionId: string): Promise<C2FFunction> {\n    const functionInfo = await this.#apiClient.policyGet(functionId, \"latest\");\n    if (functionInfo.policy_type !== \"Wasm\") {\n      throw new Error(\n        `${functionId} is not a Wasm function, it is a ${functionInfo.policy_type} named policy`,\n      );\n    }\n    return new C2FFunction(this.#apiClient, functionInfo as C2FInfo);\n  }\n\n  /**\n   * Gets all the named policies in the org.\n   *\n   * @param page Pagination options. Defaults to fetching the entire result set.\n   * @param policyType The optional type of policies to fetch. Defaults to fetching all named policies regardless of type.\n   * @returns The policies.\n   */\n  async policies(page?: PageOpts, policyType?: PolicyType): Promise<NamedPolicy[]> {\n    const policies = await this.#apiClient.policiesList(page, policyType).fetch();\n    return policies.map((p) => NamedPolicy.fromInfo(this.#apiClient, p));\n  }\n\n  /**\n   * Gets all the C2F functions in the org.\n   *\n   * @param page The paginator options.\n   * @returns The C2F functions.\n   */\n  async functions(page?: PageOpts): Promise<C2FFunction[]> {\n    const policies = await this.#apiClient.policiesList(page, \"Wasm\").fetch();\n    return policies.map((data) => new C2FFunction(this.#apiClient, data as C2FInfo));\n  }\n\n  /**\n   * Create a new Confidential Cloud Function.\n   *\n   * @param name The name of the function.\n   * @param policy The Wasm function.\n   * @param acl Optional list of policy access control entries.\n   * @returns The C2F function\n   */\n  async createWasmFunction(\n    name: string,\n    policy: Uint8Array,\n    acl?: PolicyAcl,\n  ): Promise<C2FFunction> {\n    const hash = await uploadWasmFunction(this.#apiClient, policy);\n    const policyInfo = await this.#apiClient.policyCreate(\n      name,\n      \"Wasm\",\n      [\n        {\n          hash,\n        },\n      ],\n      acl,\n    );\n    return new C2FFunction(this.#apiClient, policyInfo as C2FInfo);\n  }\n\n  /** @returns the Confidential Cloud Functions configuration for the org. */\n  async c2fConfiguration(): Promise<C2FConfiguration | undefined> {\n    const data = await this.fetch();\n    return data.policy_engine_configuration;\n  }\n\n  /**\n   * Set the Confidential Cloud Functions configuration for the org.\n   * Note that this overwrites any existing configuration.\n   *\n   * @param configs Confidential Cloud Functions configuration.\n   */\n  async setC2FConfiguration(configs: C2FConfiguration) {\n    await this.update({\n      policy_engine_configuration: configs,\n    });\n  }\n\n  /**\n   * Derive a key of the given type using the given derivation path and mnemonic.\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param type Type of key to derive from the mnemonic.\n   * @param derivationPath Mnemonic derivation path used to generate new key.\n   * @param mnemonicId material_id of mnemonic key used to derive the new key.\n   * @param props Additional properties for derivation.\n   *\n   * @returns newly derived key or undefined if it already exists.\n   */\n  async deriveKey(\n    type: KeyType,\n    derivationPath: string,\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<Key | undefined> {\n    return (await this.deriveKeys(type, [derivationPath], mnemonicId, props))[0];\n  }\n\n  /**\n   * Derive a set of keys of the given type using the given derivation paths and mnemonic.\n   *\n   * The owner of the derived keys will be the owner of the mnemonic.\n   *\n   * @param type Type of key to derive from the mnemonic.\n   * @param derivationPaths Mnemonic derivation paths used to generate new key.\n   * @param mnemonicId material_id of mnemonic key used to derive the new key.\n   * @param props Additional properties for derivation.\n   *\n   * @returns newly derived keys.\n   */\n  async deriveKeys(\n    type: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysDerive(type, derivationPaths, mnemonicId, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Use either a new or existing mnemonic to derive keys of one or more\n   * specified types via specified derivation paths.\n   *\n   * @param keyTypesAndDerivationPaths A list of `KeyTypeAndDerivationPath` objects specifying the keys to be derived\n   * @param props Additional options for derivation.\n   *\n   * @returns The newly derived keys.\n   */\n  async deriveMultipleKeyTypes(\n    keyTypesAndDerivationPaths: KeyTypeAndDerivationPath[],\n    props?: DeriveMultipleKeyTypesProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysDeriveMulti(keyTypesAndDerivationPaths, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Get a key by id.\n   *\n   * @param keyId The id of the key to get.\n   * @returns The key.\n   */\n  async getKey(keyId: string): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGet(keyId);\n    return new Key(this.#apiClient, keyInfo);\n  }\n\n  /**\n   * Get a key by its material id (e.g., address).\n   *\n   * @param keyType The key type.\n   * @param materialId The material id of the key to get.\n   * @returns The key.\n   */\n  async getKeyByMaterialId(keyType: KeyType, materialId: string): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGetByMaterialId(keyType, materialId);\n    return new Key(this.#apiClient, keyInfo);\n  }\n\n  /**\n   * Create a contact.\n   *\n   * @param name The name for the new contact.\n   * @param addresses The addresses associated with the contact.\n   * @param metadata Metadata associated with the contact. Intended for use as a description.\n   * @param editPolicy The edit policy for the contact, determining when and who can edit this contact.\n   * @param labels The optional labels associated with the contact.\n   * @returns The newly-created contact.\n   */\n  async createContact(\n    name: string,\n    addresses?: AddressMap,\n    metadata?: JsonValue,\n    editPolicy?: EditPolicy,\n    labels?: ContactLabel[],\n  ): Promise<Contact> {\n    const contactInfo = await this.#apiClient.contactCreate(\n      name,\n      addresses,\n      metadata,\n      editPolicy,\n      labels,\n    );\n\n    return new Contact(this.#apiClient, contactInfo);\n  }\n\n  /**\n   * Get a contact by its id.\n   *\n   * @param contactId The id of the contact to get.\n   * @returns The contact.\n   */\n  async getContact(contactId: string): Promise<Contact> {\n    const contactInfo = await this.#apiClient.contactGet(contactId);\n\n    return new Contact(this.#apiClient, contactInfo);\n  }\n\n  /**\n   * Get all contacts in the organization, optionally matching the search query.\n   *\n   * @param search The optional search query. Either:\n   *  - `label:...`, which will return contacts with the label provided after the ':',\n   *  - an exact address search, which returns contacts with the provided ContactAddressData,\n   *  - or an address prefix search, where all returned contacts will have an address starting with, or equaling, the given search string.\n   * @returns All contacts.\n   */\n  async contacts(\n    search?: `label${ContactLabel}` | ContactAddressData | string,\n  ): Promise<Contact[]> {\n    let contacts;\n\n    if (search !== undefined && typeof search !== \"string\") {\n      contacts = await this.#apiClient.contactLookupByAddress(search);\n    } else {\n      const paginator = this.#apiClient.contactsList(undefined, search);\n      contacts = await paginator.fetch();\n    }\n\n    return contacts.map((c) => new Contact(this.#apiClient, c));\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * Same as {@link ApiClient.identityProve}, see its documentation for more information.\n   *\n   * @returns A function that resolves to an identity proof\n   */\n  get proveIdentity() {\n    return this.#apiClient.identityProve.bind(this.#apiClient);\n  }\n\n  /**\n   * Check if a given proof of OIDC authentication is valid.\n   *\n   * Same as {@link ApiClient.identityVerify}, see its documentation for more information.\n   *\n   * @returns A function that verifies a proof of identity, throwing if invalid\n   */\n  get verifyIdentity() {\n    return this.#apiClient.identityVerify.bind(this.#apiClient);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   *\n   * @param mfaId MFA request ID\n   * @returns The MFA request\n   */\n  getMfaRequest(mfaId: MfaId): MfaRequest {\n    return new MfaRequest(this.#apiClient, mfaId);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   *\n   * @returns The MFA requests.\n   */\n  async mfaRequests(): Promise<MfaRequest[]> {\n    return await this.#apiClient\n      .mfaList()\n      .then((mfaInfos) => mfaInfos.map((mfaInfo) => new MfaRequest(this.#apiClient, mfaInfo)));\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain deposit (or staking) message.\n   *\n   * Same as {@link ApiClient.signStake}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a stake response.\n   */\n  get stake() {\n    return this.#apiClient.signStake.bind(this.#apiClient);\n  }\n\n  /**\n   * Create new user session (management and/or signing). The lifetime of\n   * the new session is silently truncated to that of the current session.\n   *\n   * Same as {@link ApiClient.sessionCreate}, see its documentation for more information.\n   *\n   * @returns A function that resolves to new signer session info.\n   */\n  get createSession() {\n    return this.#apiClient.sessionCreate.bind(this.#apiClient);\n  }\n\n  /**\n   * Create new user session (management and/or signing) whose lifetime potentially\n   * extends the lifetime of the current session.  MFA is always required.\n   *\n   * Same as {@link ApiClient.sessionCreateExtended}, see its documentation for more information.\n   *\n   * @returns A function that resolves to new signer session info.\n   */\n  get createExtendedSession() {\n    return this.#apiClient.sessionCreateExtended.bind(this.#apiClient);\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * Same as {@link ApiClient.sessionRevoke}, see its documentation for more info.\n   *\n   * @returns A function that revokes a session\n   */\n  get revokeSession() {\n    return this.#apiClient.sessionRevoke.bind(this.#apiClient);\n  }\n\n  /**\n   * Send a heartbeat / upcheck request.\n   *\n   * Same as {@link ApiClient.heartbeat}, see its documentation for more info.\n   *\n   * @returns A function that sends a heartbeat\n   */\n  get heartbeat() {\n    return this.#apiClient.heartbeat.bind(this.#apiClient);\n  }\n\n  /**\n   * List outstanding user-export requests.\n   *\n   * Same as {@link ApiClient.userExportList}, see its documentation for more info.\n   *\n   * @returns A function that resolves to a paginator of user-export requests\n   */\n  get exports() {\n    return this.#apiClient.userExportList.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an outstanding user-export request.\n   *\n   * Same as {@link ApiClient.userExportDelete}, see its documentation for more info.\n   *\n   * @returns A function that deletes a user-export request\n   */\n  get deleteExport() {\n    return this.#apiClient.userExportDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Initiate a user-export request.\n   *\n   * Same as {@link ApiClient.userExportInit}, see its documentation for more info.\n   *\n   * @returns A function that resolves to the request response.\n   */\n  get initExport() {\n    return this.#apiClient.userExportInit.bind(this.#apiClient);\n  }\n\n  /**\n   * Complete a user-export request.\n   *\n   * Same as {@link ApiClient.userExportComplete}, see its documentation for more info.\n   *\n   * @returns A function that resolves to the request response.\n   */\n  get completeExport() {\n    return this.#apiClient.userExportComplete.bind(this.#apiClient);\n  }\n\n  /**\n   * Update the org.\n   *\n   * Same as {@link ApiClient.orgUpdate}, see its documentation for more info.\n   *\n   * @returns A function that updates an org and returns updated org information\n   */\n  get update() {\n    return this.#apiClient.orgUpdate.bind(this.#apiClient);\n  }\n\n  /**\n   * Request a fresh key-import key.\n   *\n   * Same as {@link ApiClient.createKeyImportKey}, see its documentation for more info.\n   *\n   * @returns A function that resolves to a fresh key-import key\n   */\n  get createKeyImportKey() {\n    return this.#apiClient.createKeyImportKey.bind(this.#apiClient);\n  }\n\n  /**\n   * Import one or more keys. To use this functionality, you must first create an\n   * encrypted key-import request using the `@cubist-labs/cubesigner-sdk-key-import`\n   * library. See that library's documentation for more info.\n   *\n   * @param body An encrypted key-import request.\n   * @returns The newly imported keys.\n   */\n  async importKeys(body: ImportKeyRequest): Promise<Key[]> {\n    const keys = await this.#apiClient.importKeys(body);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  // Backwards compatibility aliases for Named Wasm Policy\n\n  /**\n   * Create a new Wasm policy.\n   *\n   * @param name The name of the policy.\n   * @param policy The Wasm policy object.\n   * @param acl Optional list of policy access control entries.\n   * @returns The new policy.\n   */\n  createWasmPolicy = this.createWasmFunction;\n\n  /** @returns the Policy Engine configuration for the org. */\n  policyEngineConfiguration = this.c2fConfiguration;\n\n  /**\n   * Set the Policy Engine configuration for the org.\n   * Note that this overwrites any existing configuration.\n   *\n   * @param configs The Policy Engine configuration.\n   */\n  setPolicyEngineConfiguration = this.setC2FConfiguration;\n}\n"]}
|
|
745
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"org.js","sourceRoot":"","sources":["../../src/org.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  KeyType,\n  KeyProperties,\n  NotificationEndpointConfiguration,\n  PageOpts,\n  UserInOrgInfo,\n  ApiClient,\n  OrgInfo,\n  MfaId,\n  ImportKeyRequest,\n  KeyPolicy,\n  QueryMetricsResponse,\n  OrgMetricName,\n  QueryMetricsRequest,\n  KeyTypeAndDerivationPath,\n  JsonValue,\n  EditPolicy,\n  AddressMap,\n  CreateOrgRequest,\n  RolePolicy,\n  C2FConfiguration,\n  MfaProtectedAction,\n  MfaType,\n  PolicyType,\n  PolicyAcl,\n  ContactLabel,\n  ContactAddressData,\n  OrgExtProps,\n  OrgExtData,\n} from \".\";\nimport { Contact } from \"./contact\";\nimport { C2FFunction, Key, MfaRequest, Role } from \".\";\nimport {\n  type NamedKeyPolicy,\n  NamedPolicy,\n  type NamedRolePolicy,\n  uploadWasmFunction,\n  type C2FInfo,\n} from \"./policy\";\n\n/** Options pased to createKey and deriveKey */\nexport type CreateKeyProperties = Omit<KeyProperties, \"policy\"> & {\n  /**\n   * Policies to apply to the new key.\n   *\n   * This type makes it possible to assign values like\n   * `[AllowEip191SigningPolicy]`, but remains backwards\n   * compatible with prior versions of the SDK, in which\n   * this property had type `Record<string, never>[] | null`.\n   */\n  policy?: KeyPolicy | unknown[] | null;\n};\n\n/** Options passed to importKey and deriveKey */\nexport type ImportDeriveKeyProperties = CreateKeyProperties & {\n  /**\n   * When true, returns a 'Key' object for both new and existing keys.\n   */\n  idempotent?: boolean;\n};\n\n/** Options passed to deriveMultipleKeyTypes */\nexport type DeriveMultipleKeyTypesProperties = ImportDeriveKeyProperties & {\n  /**\n   * The material_id of the mnemonic used to derive new keys.\n   *\n   * If this argument is undefined or null, a new mnemonic is first created\n   * and any other specified properties are applied to it (in addition to\n   * being applied to the specified keys).\n   *\n   * The newly created mnemonic-id can be retrieved from the `derivation_info`\n   * property of the `KeyInfo` value for a resulting key.\n   */\n  mnemonic_id?: string;\n};\n\n/** Organization id */\nexport type OrgId = string;\n\n/** Org-wide policy */\nexport type OrgPolicy =\n  | SourceIpAllowlistPolicy\n  | OidcAuthSourcesPolicy\n  | OriginAllowlistPolicy\n  | MaxDailyUnstakePolicy\n  | WebAuthnRelyingPartiesPolicy\n  | ExclusiveKeyAccessPolicy;\n\n/**\n * Whether to enforce exclusive access to keys.  Concretely,\n * - if \"LimitToKeyOwner\" is set, only key owners are permitted to access\n *   their keys for signing: a user session (not a role session) is required\n *   for signing, and adding a key to a role is not permitted.\n * - if \"LimitToSingleRole\" is set, each key is permitted to be in at most\n *   one role, and signing is only allowed when authenticating using a role session token.\n */\nexport interface ExclusiveKeyAccessPolicy {\n  ExclusiveKeyAccess: \"LimitToKeyOwner\" | \"LimitToSingleRole\";\n}\n\n/**\n * The set of relying parties to allow for webauthn registration\n * These correspond to domains from which browsers can successfully create credentials.\n */\nexport interface WebAuthnRelyingPartiesPolicy {\n  WebAuthnRelyingParties: { id?: string; name: string }[];\n}\n\n/**\n * Provides an allowlist of OIDC Issuers and audiences that are allowed to authenticate into this org.\n *\n * @example {\"OidcAuthSources\": { \"https://accounts.google.com\": [ \"1234.apps.googleusercontent.com\" ]}}\n */\nexport interface OidcAuthSourcesPolicy {\n  OidcAuthSources: Record<string, string[] | IssuerConfig>;\n}\n\n/** OIDC issuer configuration */\nexport interface IssuerConfig {\n  /** The set of audiences supported for this issuer */\n  auds: string[];\n\n  /** The kinds of user allowed to authenticate with this issuer */\n  users: string[];\n\n  /** Optional nickname for this provider */\n  nickname?: string;\n\n  /** Whether to make this issuer public */\n  public?: boolean;\n}\n\n/**\n * Only allow requests from the specified origins.\n *\n * @example {\"OriginAllowlist\": \"*\"}\n */\nexport interface OriginAllowlistPolicy {\n  OriginAllowlist: string[] | \"*\";\n}\n\n/**\n * Restrict signing to specific source IP addresses.\n *\n * @example {\"SourceIpAllowlist\": [\"10.1.2.3/8\", \"169.254.17.1/16\"]}\n */\nexport interface SourceIpAllowlistPolicy {\n  SourceIpAllowlist: string[];\n}\n\n/**\n * Restrict the number of unstakes per day.\n *\n * @example {\"MaxDailyUnstake\": 5 }\n */\nexport interface MaxDailyUnstakePolicy {\n  MaxDailyUnstake: number;\n}\n\n/**\n * Filter to use when listing keys\n */\nexport interface KeyFilter {\n  /** Filter by key type */\n  type?: KeyType;\n  /** Filter by key owner */\n  owner?: string;\n  /** Search by key's material id and metadata */\n  search?: string;\n  /** Pagination options */\n  page?: PageOpts;\n}\n\n/**\n * An organization.\n *\n * Extends {@link CubeSignerClient} and provides a few org-specific methods on top.\n */\nexport class Org {\n  readonly #apiClient: ApiClient;\n  #orgId: OrgId;\n  /** The org information */\n  #data?: OrgInfo;\n\n  /**\n   * @returns The org id\n   * @example Org#c3b9379c-4e8c-4216-bd0a-65ace53cf98f\n   */\n  get id(): OrgId {\n    return this.#orgId;\n  }\n\n  /**\n   * @returns The cached properties of this org. The cached properties reflect the\n   * state of the last fetch or update.\n   */\n  get cached(): OrgInfo | undefined {\n    return this.#data;\n  }\n\n  /**\n   * Constructor.\n   *\n   * @param apiClient The API client to use.\n   * @param orgId The id of the org\n   */\n  constructor(apiClient: ApiClient, orgId: string) {\n    this.#orgId = orgId;\n    this.#apiClient = orgId === apiClient.orgId ? apiClient : apiClient.withTargetOrg(orgId);\n  }\n\n  /**\n   * Create a new organization. The new org is a child of the\n   * current org and inherits its key-export policy. The new org\n   * is created with one owner, the caller of this API.\n   *\n   * @param nameOrRequest The name of the new org or the properties of the new org.\n   * @returns Information about the newly created org.\n   */\n  async createOrg(nameOrRequest: string | CreateOrgRequest): Promise<OrgInfo> {\n    const req = typeof nameOrRequest === \"string\" ? { name: nameOrRequest } : nameOrRequest;\n    if (!/^[a-zA-Z0-9_]{3,30}$/.test(req.name)) {\n      throw new Error(\"Org name must be alphanumeric and between 3 and 30 characters\");\n    }\n    return await this.#apiClient.orgCreateOrg(req);\n  }\n\n  /**\n   * Query org metrics.\n   *\n   * @param metricName The metric name.\n   * @param startTime The start date in seconds since unix epoch.\n   * @param opt Other optional arguments\n   * @param opt.end_time The end date in seconds since unix epoch. If omitted, defaults to 'now'.\n   * @param opt.period The granularity, in seconds, of the returned data points.\n   *   This value is automatically rounded up to a multiple of 3600 (i.e., 1 hour).\n   *   If omitted, defaults to the duration between the start and the end date.\n   *   Must be no less than 1 hour, i.e., 3600 seconds. Additionally, this period must not\n   *   divide the `endTime - startTime` period into more than 100 data points.\n   * @param pageOpts Pagination options.\n   * @returns Metric values (data points) for the requested periods.\n   */\n  async queryMetrics(\n    metricName: OrgMetricName,\n    startTime: EpochTimeStamp,\n    opt?: Omit<QueryMetricsRequest, \"metric_name\" | \"start_time\">,\n    pageOpts?: PageOpts,\n  ): Promise<QueryMetricsResponse> {\n    const req: QueryMetricsRequest = {\n      metric_name: metricName,\n      start_time: startTime,\n      ...opt,\n    };\n    return await this.#apiClient.orgQueryMetrics(req, pageOpts).fetchAll();\n  }\n\n  /**\n   * Fetch the org information.\n   *\n   * @returns The org information.\n   */\n  async fetch(): Promise<OrgInfo> {\n    this.#data = await this.#apiClient.orgGet();\n    return this.#data;\n  }\n\n  /** @returns The human-readable name for the org */\n  async name(): Promise<string | undefined> {\n    const data = await this.fetch();\n    return data.name ?? undefined;\n  }\n\n  /** @returns Whether the org is enabled */\n  async enabled(): Promise<boolean> {\n    const data = await this.fetch();\n    return data.enabled;\n  }\n\n  /** Enable the org. */\n  async enable() {\n    await this.update({ enabled: true });\n  }\n\n  /** Disable the org. */\n  async disable() {\n    await this.update({ enabled: false });\n  }\n\n  /** @returns the policy for the org. */\n  async policy(): Promise<OrgPolicy[]> {\n    const data = await this.fetch();\n    return (data.policy ?? []) as unknown as OrgPolicy[];\n  }\n\n  /**\n   * Set the policy for the org.\n   *\n   * @param policy The new policy for the org.\n   */\n  async setPolicy(policy: OrgPolicy[]) {\n    const p = policy as unknown as Record<string, never>[];\n    await this.update({ policy: p });\n  }\n\n  /**\n   * Retrieve the organization's extended properties (uncommon features not used by most users).\n   *\n   * @returns The extended properties\n   */\n  async getExtendedProperties(): Promise<OrgExtData | null> {\n    const data = await this.fetch();\n    return data.ext_data ? data.ext_data : null;\n  }\n\n  /**\n   * Update the organization's extended properties (uncommon features not used by most users).\n   *\n   * @param props The new properties.\n   */\n  async setExtendedProperties(props: OrgExtProps) {\n    await this.update({ ext_props: props });\n  }\n\n  /**\n   * Update the per-alien key count threshold, which, once exceeded, disallows further key creation by alien users.\n   *\n   * This setting is checked only when an alien user requests to create or import a new key.\n   * In other words, org admins can still assign unlimited number of keys to their alien users.\n   *\n   * @param alienKeyCountThreshold The new key count threshold.\n   */\n  async setAlienKeyCountThreshold(alienKeyCountThreshold: number) {\n    const data = { ...((await this.getExtendedProperties()) ?? {}) };\n\n    // erase the metadata that cannot be updated\n    data.created = undefined;\n    data.last_modified = undefined;\n\n    // update 'alien_key_count_threshold' and keep everything else the same\n    data.alien_key_count_threshold = alienKeyCountThreshold;\n\n    await this.update({ ext_props: data });\n  }\n\n  /**\n   * Set the notification endpoints for the org.\n   *\n   * @param notification_endpoints Endpoints.\n   */\n  async setNotificationEndpoints(notification_endpoints: NotificationEndpointConfiguration[]) {\n    await this.update({\n      notification_endpoints,\n    });\n  }\n\n  /**\n   * Set required MFA types for actions implicitly requiring MFA (see {@link MfaProtectedAction}).\n   *\n   * @param allowed_mfa_types Assignment of MFA types to actions that implicitly require MFA.\n   */\n  async setAllowedMfaTypes(allowed_mfa_types: Partial<Record<MfaProtectedAction, MfaType[]>>) {\n    await this.update({\n      allowed_mfa_types,\n    });\n  }\n\n  /**\n   * Create a new signing key.\n   *\n   * @param type The type of key to create.\n   * @param ownerId The owner of the key. Defaults to the session's user.\n   * @param props Additional properties to set on the new key.\n   * @returns The new keys.\n   */\n  async createKey(type: KeyType, ownerId?: string, props?: CreateKeyProperties): Promise<Key> {\n    const keys = await this.#apiClient.keysCreate(type, 1, ownerId, props);\n    return new Key(this.#apiClient, keys[0]);\n  }\n\n  /**\n   * Create new signing keys.\n   *\n   * @param type The type of key to create.\n   * @param count The number of keys to create.\n   * @param ownerId The owner of the keys. Defaults to the session's user.\n   * @param props Additional properties to set on the new keys.\n   * @returns The new keys.\n   */\n  async createKeys(\n    type: KeyType,\n    count: number,\n    ownerId?: string,\n    props?: CreateKeyProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysCreate(type, count, ownerId, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Create a new (first-party) user in the organization and sends an invitation to that user.\n   *\n   * Same as {@link ApiClient.orgUserInvite}, see its documentation for more information.\n   *\n   * @returns A function that invites a user\n   */\n  get createUser() {\n    return this.#apiClient.orgUserInvite.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an existing user.\n   *\n   * Same as {@link ApiClient.orgUserDelete}, see its documentation for more information.\n   *\n   * @returns A function that deletes a user\n   */\n  get deleteUser() {\n    return this.#apiClient.orgUserDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Create a new OIDC user. This can be a first-party \"Member\" or third-party \"Alien\".\n   *\n   * Same as {@link ApiClient.orgUserCreateOidc}, see its documentation for more information.\n   *\n   * @returns A function that creates an OIDC user, resolving to the new user's ID\n   */\n  get createOidcUser() {\n    return this.#apiClient.orgUserCreateOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an existing OIDC user.\n   *\n   * Same as {@link ApiClient.orgUserDeleteOidc}, see its documentation for more information.\n   *\n   * @returns A function that deletes an OIDC user\n   */\n  get deleteOidcUser() {\n    return this.#apiClient.orgUserDeleteOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * List all users in the organization.\n   *\n   * @param searchQuery Optional query string. If defined, all returned users will contain this string in their name or email.\n   * @returns The list of users\n   */\n  async users(searchQuery?: string): Promise<UserInOrgInfo[]> {\n    return await this.#apiClient.orgUsersList(undefined, searchQuery).fetchAll();\n  }\n\n  /**\n   * List users in the organization (paginated).\n   *\n   * Same as {@link ApiClient.orgUsersList}, see its documentation for more information.\n   *\n   * @returns A function that returns a paginated list of users\n   */\n  get usersPaginated() {\n    return this.#apiClient.orgUsersList.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by id.\n   *\n   * Same as {@link ApiClient.orgUserGet}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUser() {\n    return this.#apiClient.orgUserGet.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by email.\n   *\n   * Same as {@link ApiClient.orgUserGetByEmail}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUserByEmail() {\n    return this.#apiClient.orgUserGetByEmail.bind(this.#apiClient);\n  }\n\n  /**\n   * Get user by OIDC ID.\n   *\n   * Same as {@link ApiClient.orgUserGetByOidc}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a user's info\n   */\n  get getUserByOidc() {\n    return this.#apiClient.orgUserGetByOidc.bind(this.#apiClient);\n  }\n\n  /**\n   * Enable a user in this org\n   *\n   * @param userId The user whose membership to enable\n   * @returns The updated user's membership\n   */\n  async enableUser(userId: string): Promise<UserInOrgInfo> {\n    return await this.#apiClient.orgUpdateUserMembership(userId, { disabled: false });\n  }\n\n  /**\n   * Disable a user in this org\n   *\n   * @param userId The user whose membership to disable\n   * @returns The updated user's membership\n   */\n  async disableUser(userId: string): Promise<UserInOrgInfo> {\n    return await this.#apiClient.orgUpdateUserMembership(userId, { disabled: true });\n  }\n\n  /**\n   * Get the accessible keys in the organization\n   *\n   * @param props Optional filtering properties.\n   * @returns The keys.\n   */\n  async keys(props?: KeyFilter): Promise<Key[]> {\n    const paginator = this.#apiClient.keysList(\n      props?.type,\n      props?.page,\n      props?.owner,\n      props?.search,\n    );\n    const keys = await paginator.fetch();\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Create a new role.\n   *\n   * @param name The name of the role.\n   * @returns The new role.\n   */\n  async createRole(name?: string): Promise<Role> {\n    const roleId = await this.#apiClient.roleCreate(name);\n    const roleInfo = await this.#apiClient.roleGet(roleId);\n    return new Role(this.#apiClient, roleInfo);\n  }\n\n  /**\n   * Get a role by id or name.\n   *\n   * @param roleId The id or name of the role to get.\n   * @returns The role.\n   */\n  async getRole(roleId: string): Promise<Role> {\n    const roleInfo = await this.#apiClient.roleGet(roleId);\n    return new Role(this.#apiClient, roleInfo);\n  }\n\n  /**\n   * Gets all the roles in the org\n   *\n   * @param page The paginator options\n   * @returns The roles\n   */\n  async roles(page: PageOpts): Promise<Role[]> {\n    const roles = await this.#apiClient.rolesList(page).fetch();\n    return roles.map((r) => new Role(this.#apiClient, r));\n  }\n\n  /**\n   * Create a new named policy.\n   *\n   * @param name The name of the policy.\n   * @param type The type of the policy.\n   * @param rules The policy rules.\n   * @param acl Optional list of policy access control entries.\n   * @returns The new policy.\n   */\n  async createPolicy<Type extends \"Key\" | \"Role\">(\n    name: string,\n    type: Type,\n    rules: Type extends \"Key\" ? KeyPolicy : RolePolicy,\n    acl?: PolicyAcl,\n  ): Promise<Type extends \"Key\" ? NamedKeyPolicy : NamedRolePolicy> {\n    const policyInfo = await this.#apiClient.policyCreate(name, type, rules, acl);\n    const policy = NamedPolicy.fromInfo(this.#apiClient, policyInfo);\n    return policy as Type extends \"Key\" ? NamedKeyPolicy : NamedRolePolicy;\n  }\n\n  /**\n   * Get a named policy by id or name.\n   *\n   * @param policyId The id or name of the policy to get.\n   * @returns The policy.\n   */\n  async getPolicy(policyId: string): Promise<NamedPolicy> {\n    const policyInfo = await this.#apiClient.policyGet(policyId, \"latest\");\n    return NamedPolicy.fromInfo(this.#apiClient, policyInfo);\n  }\n\n  /**\n   * Get a Confidential Cloud Function by name or named policy ID.\n   *\n   * @param functionId The name or named policy ID of the function to get.\n   * @returns The C2F function.\n   * @throws if name or ID is not associated to a C2F function (i.e. the name/id is for a key or role named policy)\n   */\n  async getFunction(functionId: string): Promise<C2FFunction> {\n    const functionInfo = await this.#apiClient.policyGet(functionId, \"latest\");\n    if (functionInfo.policy_type !== \"Wasm\") {\n      throw new Error(\n        `${functionId} is not a Wasm function, it is a ${functionInfo.policy_type} named policy`,\n      );\n    }\n    return new C2FFunction(this.#apiClient, functionInfo as C2FInfo);\n  }\n\n  /**\n   * Gets all the named policies in the org.\n   *\n   * @param page Pagination options. Defaults to fetching the entire result set.\n   * @param policyType The optional type of policies to fetch. Defaults to fetching all named policies regardless of type.\n   * @returns The policies.\n   */\n  async policies(page?: PageOpts, policyType?: PolicyType): Promise<NamedPolicy[]> {\n    const policies = await this.#apiClient.policiesList(page, policyType).fetch();\n    return policies.map((p) => NamedPolicy.fromInfo(this.#apiClient, p));\n  }\n\n  /**\n   * Gets all the C2F functions in the org.\n   *\n   * @param page The paginator options.\n   * @returns The C2F functions.\n   */\n  async functions(page?: PageOpts): Promise<C2FFunction[]> {\n    const policies = await this.#apiClient.policiesList(page, \"Wasm\").fetch();\n    return policies.map((data) => new C2FFunction(this.#apiClient, data as C2FInfo));\n  }\n\n  /**\n   * Create a new Confidential Cloud Function.\n   *\n   * @param name The name of the function.\n   * @param policy The Wasm function.\n   * @param acl Optional list of policy access control entries.\n   * @returns The C2F function\n   */\n  async createWasmFunction(\n    name: string,\n    policy: Uint8Array,\n    acl?: PolicyAcl,\n  ): Promise<C2FFunction> {\n    const hash = await uploadWasmFunction(this.#apiClient, policy);\n    const policyInfo = await this.#apiClient.policyCreate(\n      name,\n      \"Wasm\",\n      [\n        {\n          hash,\n        },\n      ],\n      acl,\n    );\n    return new C2FFunction(this.#apiClient, policyInfo as C2FInfo);\n  }\n\n  /** @returns the Confidential Cloud Functions configuration for the org. */\n  async c2fConfiguration(): Promise<C2FConfiguration | undefined> {\n    const data = await this.fetch();\n    return data.policy_engine_configuration;\n  }\n\n  /**\n   * Set the Confidential Cloud Functions configuration for the org.\n   * Note that this overwrites any existing configuration.\n   *\n   * @param configs Confidential Cloud Functions configuration.\n   */\n  async setC2FConfiguration(configs: C2FConfiguration) {\n    await this.update({\n      policy_engine_configuration: configs,\n    });\n  }\n\n  /**\n   * Derive a key of the given type using the given derivation path and mnemonic.\n   * The owner of the derived key will be the owner of the mnemonic.\n   *\n   * @param type Type of key to derive from the mnemonic.\n   * @param derivationPath Mnemonic derivation path used to generate new key.\n   * @param mnemonicId material_id of mnemonic key used to derive the new key.\n   * @param props Additional properties for derivation.\n   *\n   * @returns newly derived key or undefined if it already exists.\n   */\n  async deriveKey(\n    type: KeyType,\n    derivationPath: string,\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<Key | undefined> {\n    return (await this.deriveKeys(type, [derivationPath], mnemonicId, props))[0];\n  }\n\n  /**\n   * Derive a set of keys of the given type using the given derivation paths and mnemonic.\n   *\n   * The owner of the derived keys will be the owner of the mnemonic.\n   *\n   * @param type Type of key to derive from the mnemonic.\n   * @param derivationPaths Mnemonic derivation paths used to generate new key.\n   * @param mnemonicId material_id of mnemonic key used to derive the new key.\n   * @param props Additional properties for derivation.\n   *\n   * @returns newly derived keys.\n   */\n  async deriveKeys(\n    type: KeyType,\n    derivationPaths: string[],\n    mnemonicId: string,\n    props?: ImportDeriveKeyProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysDerive(type, derivationPaths, mnemonicId, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Use either a new or existing mnemonic to derive keys of one or more\n   * specified types via specified derivation paths.\n   *\n   * @param keyTypesAndDerivationPaths A list of `KeyTypeAndDerivationPath` objects specifying the keys to be derived\n   * @param props Additional options for derivation.\n   *\n   * @returns The newly derived keys.\n   */\n  async deriveMultipleKeyTypes(\n    keyTypesAndDerivationPaths: KeyTypeAndDerivationPath[],\n    props?: DeriveMultipleKeyTypesProperties,\n  ): Promise<Key[]> {\n    const keys = await this.#apiClient.keysDeriveMulti(keyTypesAndDerivationPaths, props);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  /**\n   * Get a key by id.\n   *\n   * @param keyId The id of the key to get.\n   * @returns The key.\n   */\n  async getKey(keyId: string): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGet(keyId);\n    return new Key(this.#apiClient, keyInfo);\n  }\n\n  /**\n   * Get a key by its material id (e.g., address).\n   *\n   * @param keyType The key type.\n   * @param materialId The material id of the key to get.\n   * @returns The key.\n   */\n  async getKeyByMaterialId(keyType: KeyType, materialId: string): Promise<Key> {\n    const keyInfo = await this.#apiClient.keyGetByMaterialId(keyType, materialId);\n    return new Key(this.#apiClient, keyInfo);\n  }\n\n  /**\n   * Create a contact.\n   *\n   * @param name The name for the new contact.\n   * @param addresses The addresses associated with the contact.\n   * @param metadata Metadata associated with the contact. Intended for use as a description.\n   * @param editPolicy The edit policy for the contact, determining when and who can edit this contact.\n   * @param labels The optional labels associated with the contact.\n   * @returns The newly-created contact.\n   */\n  async createContact(\n    name: string,\n    addresses?: AddressMap,\n    metadata?: JsonValue,\n    editPolicy?: EditPolicy,\n    labels?: ContactLabel[],\n  ): Promise<Contact> {\n    const contactInfo = await this.#apiClient.contactCreate(\n      name,\n      addresses,\n      metadata,\n      editPolicy,\n      labels,\n    );\n\n    return new Contact(this.#apiClient, contactInfo);\n  }\n\n  /**\n   * Get a contact by its id.\n   *\n   * @param contactId The id of the contact to get.\n   * @returns The contact.\n   */\n  async getContact(contactId: string): Promise<Contact> {\n    const contactInfo = await this.#apiClient.contactGet(contactId);\n\n    return new Contact(this.#apiClient, contactInfo);\n  }\n\n  /**\n   * Get all contacts in the organization, optionally matching the search query.\n   *\n   * @param search The optional search query. Either:\n   *  - `label:...`, which will return contacts with the label provided after the ':',\n   *  - an exact address search, which returns contacts with the provided ContactAddressData,\n   *  - or an address prefix search, where all returned contacts will have an address starting with, or equaling, the given search string.\n   * @returns All contacts.\n   */\n  async contacts(\n    search?: `label${ContactLabel}` | ContactAddressData | string,\n  ): Promise<Contact[]> {\n    let contacts;\n\n    if (search !== undefined && typeof search !== \"string\") {\n      contacts = await this.#apiClient.contactLookupByAddress(search);\n    } else {\n      const paginator = this.#apiClient.contactsList(undefined, search);\n      contacts = await paginator.fetch();\n    }\n\n    return contacts.map((c) => new Contact(this.#apiClient, c));\n  }\n\n  /**\n   * Obtain a proof of authentication.\n   *\n   * Same as {@link ApiClient.identityProve}, see its documentation for more information.\n   *\n   * @returns A function that resolves to an identity proof\n   */\n  get proveIdentity() {\n    return this.#apiClient.identityProve.bind(this.#apiClient);\n  }\n\n  /**\n   * Check if a given proof of OIDC authentication is valid.\n   *\n   * Same as {@link ApiClient.identityVerify}, see its documentation for more information.\n   *\n   * @returns A function that verifies a proof of identity, throwing if invalid\n   */\n  get verifyIdentity() {\n    return this.#apiClient.identityVerify.bind(this.#apiClient);\n  }\n\n  /**\n   * Get a pending MFA request by its id.\n   *\n   * @param mfaId MFA request ID\n   * @returns The MFA request\n   */\n  getMfaRequest(mfaId: MfaId): MfaRequest {\n    return new MfaRequest(this.#apiClient, mfaId);\n  }\n\n  /**\n   * List pending MFA requests accessible to the current user.\n   *\n   * @returns The MFA requests.\n   */\n  async mfaRequests(): Promise<MfaRequest[]> {\n    return await this.#apiClient\n      .mfaList()\n      .then((mfaInfos) => mfaInfos.map((mfaInfo) => new MfaRequest(this.#apiClient, mfaInfo)));\n  }\n\n  /**\n   * Sign an Eth2/Beacon-chain deposit (or staking) message.\n   *\n   * Same as {@link ApiClient.signStake}, see its documentation for more information.\n   *\n   * @returns A function that resolves to a stake response.\n   */\n  get stake() {\n    return this.#apiClient.signStake.bind(this.#apiClient);\n  }\n\n  /**\n   * Create new user session (management and/or signing). The lifetime of\n   * the new session is silently truncated to that of the current session.\n   *\n   * Same as {@link ApiClient.sessionCreate}, see its documentation for more information.\n   *\n   * @returns A function that resolves to new signer session info.\n   */\n  get createSession() {\n    return this.#apiClient.sessionCreate.bind(this.#apiClient);\n  }\n\n  /**\n   * Create new user session (management and/or signing) whose lifetime potentially\n   * extends the lifetime of the current session.  MFA is always required.\n   *\n   * Same as {@link ApiClient.sessionCreateExtended}, see its documentation for more information.\n   *\n   * @returns A function that resolves to new signer session info.\n   */\n  get createExtendedSession() {\n    return this.#apiClient.sessionCreateExtended.bind(this.#apiClient);\n  }\n\n  /**\n   * Revoke a session.\n   *\n   * Same as {@link ApiClient.sessionRevoke}, see its documentation for more info.\n   *\n   * @returns A function that revokes a session\n   */\n  get revokeSession() {\n    return this.#apiClient.sessionRevoke.bind(this.#apiClient);\n  }\n\n  /**\n   * Send a heartbeat / upcheck request.\n   *\n   * Same as {@link ApiClient.heartbeat}, see its documentation for more info.\n   *\n   * @returns A function that sends a heartbeat\n   */\n  get heartbeat() {\n    return this.#apiClient.heartbeat.bind(this.#apiClient);\n  }\n\n  /**\n   * List outstanding user-export requests.\n   *\n   * Same as {@link ApiClient.userExportList}, see its documentation for more info.\n   *\n   * @returns A function that resolves to a paginator of user-export requests\n   */\n  get exports() {\n    return this.#apiClient.userExportList.bind(this.#apiClient);\n  }\n\n  /**\n   * Delete an outstanding user-export request.\n   *\n   * Same as {@link ApiClient.userExportDelete}, see its documentation for more info.\n   *\n   * @returns A function that deletes a user-export request\n   */\n  get deleteExport() {\n    return this.#apiClient.userExportDelete.bind(this.#apiClient);\n  }\n\n  /**\n   * Initiate a user-export request.\n   *\n   * Same as {@link ApiClient.userExportInit}, see its documentation for more info.\n   *\n   * @returns A function that resolves to the request response.\n   */\n  get initExport() {\n    return this.#apiClient.userExportInit.bind(this.#apiClient);\n  }\n\n  /**\n   * Complete a user-export request.\n   *\n   * Same as {@link ApiClient.userExportComplete}, see its documentation for more info.\n   *\n   * @returns A function that resolves to the request response.\n   */\n  get completeExport() {\n    return this.#apiClient.userExportComplete.bind(this.#apiClient);\n  }\n\n  /**\n   * Update the org.\n   *\n   * Same as {@link ApiClient.orgUpdate}, see its documentation for more info.\n   *\n   * @returns A function that updates an org and returns updated org information\n   */\n  get update() {\n    return this.#apiClient.orgUpdate.bind(this.#apiClient);\n  }\n\n  /**\n   * Request a fresh key-import key.\n   *\n   * Same as {@link ApiClient.createKeyImportKey}, see its documentation for more info.\n   *\n   * @returns A function that resolves to a fresh key-import key\n   */\n  get createKeyImportKey() {\n    return this.#apiClient.createKeyImportKey.bind(this.#apiClient);\n  }\n\n  /**\n   * Import one or more keys. To use this functionality, you must first create an\n   * encrypted key-import request using the `@cubist-labs/cubesigner-sdk-key-import`\n   * library. See that library's documentation for more info.\n   *\n   * @param body An encrypted key-import request.\n   * @returns The newly imported keys.\n   */\n  async importKeys(body: ImportKeyRequest): Promise<Key[]> {\n    const keys = await this.#apiClient.importKeys(body);\n    return keys.map((k) => new Key(this.#apiClient, k));\n  }\n\n  // Backwards compatibility aliases for Named Wasm Policy\n\n  /**\n   * Create a new Wasm policy.\n   *\n   * @param name The name of the policy.\n   * @param policy The Wasm policy object.\n   * @param acl Optional list of policy access control entries.\n   * @returns The new policy.\n   */\n  createWasmPolicy = this.createWasmFunction;\n\n  /** @returns the Policy Engine configuration for the org. */\n  policyEngineConfiguration = this.c2fConfiguration;\n\n  /**\n   * Set the Policy Engine configuration for the org.\n   * Note that this overwrites any existing configuration.\n   *\n   * @param configs The Policy Engine configuration.\n   */\n  setPolicyEngineConfiguration = this.setC2FConfiguration;\n}\n"]}
|