@cubist-labs/cubesigner-sdk 0.4.237 → 0.4.241
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 +3 -2
- package/dist/src/audit_log.d.ts +336 -0
- package/dist/src/audit_log.d.ts.map +1 -0
- package/dist/src/audit_log.js +180 -0
- package/dist/src/client/api_client.d.ts +26 -13
- package/dist/src/client/api_client.d.ts.map +1 -1
- package/dist/src/client/api_client.js +48 -30
- package/dist/src/client/base_client.d.ts +7 -0
- package/dist/src/client/base_client.d.ts.map +1 -1
- package/dist/src/client/base_client.js +14 -6
- package/dist/src/client.d.ts +24 -32
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/client.js +21 -29
- package/dist/src/schema_types.d.ts +1 -1
- package/dist/src/schema_types.d.ts.map +1 -1
- package/dist/src/schema_types.js +1 -1
- package/package.json +3 -2
- package/src/audit_log.ts +195 -0
- package/src/client/api_client.ts +58 -19
- package/src/client/base_client.ts +21 -8
- package/src/client.ts +23 -57
- package/src/schema_types.ts +1 -1
package/dist/src/schema_types.js
CHANGED
|
@@ -40,4 +40,4 @@ exports.ALL_OPERATION_KINDS = Object.keys(AllOperationKinds);
|
|
|
40
40
|
function coercePolicyInfo(p) {
|
|
41
41
|
return p;
|
|
42
42
|
}
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema_types.js","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":";;;AA+SA,4CAEC;AA1QD,QAAQ;AACR,8EAA8E;AAC9E,oFAAoF;AACpF,MAAM,iBAAiB,GAAgC;IACrD,OAAO,EAAE,IAAI;IACb,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE,IAAI;IACpB,mBAAmB,EAAE,IAAI;IACzB,cAAc,EAAE,IAAI;IACpB,QAAQ,EAAE,IAAI;IACd,cAAc,EAAE,IAAI;IACpB,OAAO,EAAE,IAAI;IACb,aAAa,EAAE,IAAI;IACnB,QAAQ,EAAE,IAAI;IACd,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI;IACf,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE,IAAI;IACb,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,IAAI;CACjB,CAAC;AACW,QAAA,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAA6B,CAAC;AAsO9F;;;;;GAKG;AACH,SAAgB,gBAAgB,CAAC,CAAwB;IACvD,OAAO,CAAe,CAAC;AACzB,CAAC","sourcesContent":["import type { components, operations, paths } from \"./schema\";\nimport type { JsonMap, JsonValue } from \"./util\";\n\nexport type schemas = components[\"schemas\"];\n\nexport type UserInfo = schemas[\"UserInfo\"];\nexport type UserInOrgMembership = schemas[\"UserInOrgMembership\"];\nexport type ConfiguredMfa = schemas[\"ConfiguredMfa\"];\nexport type RatchetConfig = schemas[\"RatchetConfig\"];\nexport type IdentityProof = schemas[\"IdentityProof\"];\nexport type AddIdentityRequest = schemas[\"AddIdentityRequest\"];\nexport type ListIdentityResponse = schemas[\"ListIdentitiesResponse\"];\nexport type TotpInfo = schemas[\"TotpInfo\"];\n\nexport type OidcAuthResponse = schemas[\"NewSessionResponse\"];\nexport type ApiAddFidoChallenge = schemas[\"FidoCreateChallengeResponse\"];\nexport type ApiMfaFidoChallenge = schemas[\"FidoAssertChallenge\"];\n\nexport type PublicKeyCredentialCreationOptions = schemas[\"PublicKeyCredentialCreationOptions\"];\nexport type PublicKeyCredentialRequestOptions = schemas[\"PublicKeyCredentialRequestOptions\"];\nexport type PublicKeyCredentialParameters = schemas[\"PublicKeyCredentialParameters\"];\nexport type PublicKeyCredentialDescriptor = schemas[\"PublicKeyCredentialDescriptor\"];\nexport type AuthenticatorSelectionCriteria = schemas[\"AuthenticatorSelectionCriteria\"];\nexport type PublicKeyCredentialUserEntity = schemas[\"PublicKeyCredentialUserEntity\"];\nexport type PublicKeyCredential = schemas[\"PublicKeyCredential\"];\n\nexport type OrgInfo = schemas[\"OrgInfo\"];\nexport type OrgExtData = NonNullable<OrgInfo[\"ext_data\"]>;\nexport type PublicOrgInfo = schemas[\"PublicOrgInfo\"];\nexport type UserInOrgInfo = schemas[\"UserInOrgInfo\"];\nexport type UpdateOrgRequest = schemas[\"UpdateOrgRequest\"];\nexport type OrgExtProps = NonNullable<UpdateOrgRequest[\"ext_props\"]>;\nexport type UpdateOrgResponse = schemas[\"UpdateOrgResponse\"];\nexport type UpdateUserMembershipRequest = schemas[\"UpdateUserMembershipRequest\"];\nexport type NotificationEndpointConfiguration = schemas[\"NotificationEndpointConfiguration\"];\nexport type OrgEvents = schemas[\"OrgEventDiscriminants\"];\nexport type BillingEvent = schemas[\"BillingEvent\"];\nexport type OperationKind = schemas[\"OperationKind\"];\n\n// NOTE:\n//   we use `Record<OperationKind, ...>` (instead of `OperationKind[]`) to get\n//   the type checker to complain unless this record includes every single operation\nconst AllOperationKinds: Record<OperationKind, true> = {\n  AvaSign: true,\n  AvaChainTxSign: true,\n  BabylonCovSign: true,\n  BabylonRegistration: true,\n  BabylonStaking: true,\n  BlobSign: true,\n  BtcMessageSign: true,\n  BtcSign: true,\n  DiffieHellman: true,\n  PsbtSign: true,\n  TaprootSign: true,\n  Eip191Sign: true,\n  Eip712Sign: true,\n  EotsNonces: true,\n  EotsSign: true,\n  Eth1Sign: true,\n  Eth2Sign: true,\n  Eth2Stake: true,\n  Eth2Unstake: true,\n  SolanaSign: true,\n  SuiSign: true,\n  TendermintSign: true,\n  RoleUpdate: true,\n};\nexport const ALL_OPERATION_KINDS = Object.keys(AllOperationKinds) as readonly OperationKind[];\n\nexport type OrgData = schemas[\"OrgData\"];\nexport type UserOrgsResponse = schemas[\"UserOrgsResponse\"];\n\nexport type OidcIdentity = schemas[\"OidcIdentity\"];\nexport type MemberRole = schemas[\"MemberRole\"];\n\nexport type SchemaKeyType = schemas[\"KeyType\"];\n\nexport type ListKeysResponse = schemas[\"PaginatedListKeysResponse\"];\nexport type UpdateKeyRequest = schemas[\"UpdateKeyRequest\"];\nexport type KeyProperties = schemas[\"CreateAndUpdateKeyProperties\"];\nexport type CreateKeyRequest = schemas[\"CreateKeyRequest\"];\nexport type KeyInfo = schemas[\"KeyInfo\"];\nexport type KeyInfoJwt = schemas[\"KeyInfoJwt\"];\nexport type KeyAttestationClaims = schemas[\"KeyAttestationClaims\"];\nexport type KeyAttestationQuery =\n  paths[\"/v0/org/{org_id}/keys/{key_id}/attest\"][\"get\"][\"parameters\"][\"query\"];\nexport type RoleInfoJwt = schemas[\"RoleInfoJwt\"];\nexport type RoleAttestationClaims = schemas[\"RoleAttestationClaims\"];\nexport type RoleAttestationQuery =\n  paths[\"/v0/org/{org_id}/roles/{role_id}/attest\"][\"get\"][\"parameters\"][\"query\"];\nexport type RoleAttestationVerbosity = schemas[\"RoleAttestationVerbosity\"];\nexport type KeyInRoleInfo = schemas[\"KeyInRoleInfo\"];\nexport type GetUsersInOrgResponse = schemas[\"PaginatedGetUsersInOrgResponse\"];\nexport type GetUserByEmailResponse = schemas[\"GetUserByEmailResponse\"];\nexport type GetUserByOidcResponse = schemas[\"GetUserByOidcResponse\"];\n\nexport type UserInRoleInfo = schemas[\"UserInRoleInfo\"];\nexport type KeyTypeApi = schemas[\"KeyType\"];\n\nexport type ListKeyRolesResponse = schemas[\"PaginatedListKeyRolesResponse\"];\nexport type ListRolesResponse = schemas[\"PaginatedListRolesResponse\"];\nexport type ListRoleKeysResponse = schemas[\"PaginatedListRoleKeysResponse\"];\nexport type ListRoleUsersResponse = schemas[\"PaginatedListRoleUsersResponse\"];\nexport type UpdateRoleRequest = schemas[\"UpdateRoleRequest\"];\nexport type KeyWithPoliciesInfo = schemas[\"KeyInRoleInfo\"];\nexport type RoleInfo = schemas[\"RoleInfo\"];\nexport type RoleAction = schemas[\"RoleAction\"];\nexport type RestrictedActionsMap = Partial<Record<RoleAction, MemberRole[]>>;\n\nexport type SessionInfo = schemas[\"SessionInfo\"];\nexport type ClientSessionInfo = schemas[\"ClientSessionInfo\"];\nexport type NewSessionResponse = schemas[\"NewSessionResponse\"];\nexport type SessionsResponse = schemas[\"PaginatedSessionsResponse\"];\n\nexport type EditPolicy = schemas[\"EditPolicy\"];\n\nexport type ContactInfo = schemas[\"ContactInfoResponse\"];\nexport type AddressMap = schemas[\"AddressMap\"];\nexport type BtcChain = schemas[\"BtcChain\"];\nexport type SuiChain = schemas[\"SuiChain\"];\nexport type CreateContactRequest = schemas[\"CreateContactRequest\"];\nexport type UpdateContactRequest = schemas[\"UpdateContactRequest\"];\nexport type ListContactsResponse = schemas[\"PaginatedListContactsResponse\"];\nexport type ContactLabel = schemas[\"ContactLabel\"];\nexport type ContactAddressData = schemas[\"ContactAddressData\"];\n\nexport type CreateSignerSessionRequest = schemas[\"CreateTokenRequest\"];\nexport type RefreshSignerSessionRequest = schemas[\"AuthData\"];\n\nexport type EvmSignRequest = schemas[\"Eth1SignRequest\"];\nexport type EvmSignResponse = schemas[\"Eth1SignResponse\"];\nexport type Eip191SignRequest = schemas[\"Eip191SignRequest\"];\nexport type Eip712SignRequest = schemas[\"Eip712SignRequest\"];\nexport type Eip191Or712SignResponse = schemas[\"SignResponse\"];\nexport type Eth2SignRequest = schemas[\"Eth2SignRequest\"];\nexport type Eth2SignResponse = schemas[\"SignResponse\"];\nexport type Eth2StakeRequest = schemas[\"StakeRequest\"];\nexport type Eth2StakeResponse = schemas[\"StakeResponse\"];\nexport type Eth2UnstakeRequest = schemas[\"UnstakeRequest\"];\nexport type Eth2UnstakeResponse = schemas[\"UnstakeResponse\"];\nexport type BlobSignRequest = schemas[\"BlobSignRequest\"];\nexport type BlobSignResponse = schemas[\"SignResponse\"];\nexport type BtcSignRequest = schemas[\"BtcSignRequest\"];\nexport type BtcSignResponse = schemas[\"SignResponse\"];\nexport type BtcMessageSignRequest = schemas[\"BtcMessageSignRequest\"];\nexport type BtcMessageSignResponse = schemas[\"BtcMessageSignResponse\"];\nexport type PsbtSignRequest = schemas[\"PsbtSignRequest\"];\nexport type PsbtSignResponse = schemas[\"PsbtSignResponse\"];\nexport type TaprootSignRequest = schemas[\"TaprootSignRequest\"];\nexport type TaprootSignResponse = schemas[\"SignResponse\"];\nexport type EotsSignRequest = schemas[\"EotsSignRequest\"];\nexport type EotsSignResponse = schemas[\"SignResponse\"];\nexport type EotsCreateNonceRequest = schemas[\"EotsCreateNonceRequest\"];\nexport type EotsCreateNonceResponse = schemas[\"EotsCreateNonceResponse\"];\nexport type BabylonStakingRequest = schemas[\"BabylonStakingRequest\"];\nexport type BabylonStakingResponse = schemas[\"BabylonStakingResponse\"];\nexport type BabylonStakingEarlyUnbond = schemas[\"BabylonStakingEarlyUnbond\"];\nexport type BabylonStakingWithdrawal = schemas[\"BabylonStakingWithdrawal\"];\nexport type BabylonRegistrationRequest = schemas[\"BabylonRegistrationRequest\"];\nexport type BabylonRegistrationResponse = schemas[\"BabylonRegistrationResponse\"];\nexport type SolanaSignRequest = schemas[\"SolanaSignRequest\"];\nexport type SolanaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSignRequest = schemas[\"AvaSignRequest\"];\nexport type AvaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSerializedTxSignRequest = schemas[\"AvaSerializedTxSignRequest\"];\nexport type SuiSignRequest = schemas[\"SuiSignRequest\"];\nexport type SuiSignResponse = schemas[\"SignResponse\"];\n\nexport type PendingMessageSignResponse = schemas[\"PendingMessageSignResponse\"];\nexport type PendingMessageInfo = schemas[\"PendingMessageInfo\"];\nexport type EvmTransaction = schemas[\"Transaction\"];\nexport type TypedTransaction = schemas[\"TypedTransaction\"];\nexport type TransactionAndStatus = schemas[\"TransactionAndStatus\"];\nexport type SignedMessage = schemas[\"SignedMessage\"];\nexport type MmiMetadata = schemas[\"MmiMetadata\"];\nexport type MmiStatus = schemas[\"MmiStatus\"];\nexport type Eip191Message = NonNullable<PendingMessageInfo[\"message_eip191\"]>;\nexport type Eip712Message = NonNullable<PendingMessageInfo[\"message_eip712\"]>;\n\nexport type JrpcResponse = schemas[\"JrpcResponse\"];\nexport type MmiJrpcMethod =\n  | \"custodian_listAccounts\"\n  | \"custodian_listAccountsSigned\"\n  | \"custodian_listAccountChainIds\"\n  | \"custodian_createTransaction\"\n  | \"custodian_sign\"\n  | \"custodian_signTypedData\"\n  | \"custodian_getSignedMessageById\"\n  | \"custodian_getTransactionById\"\n  | \"custodian_getCustomerProof\"\n  | \"custodian_replaceTransaction\"\n  | \"custodian_getTransactionLink\"\n  | \"custodian_getSignedMessageLink\";\n\nexport type AcceptedResponse = schemas[\"AcceptedResponse\"];\nexport type ErrorResponse = schemas[\"ErrorResponse\"];\nexport type BtcSignatureKind = schemas[\"BtcSignatureKind\"];\nexport type CsErrCode = schemas[\"SignerErrorCode\"];\n\nexport type MfaType =\n  | \"CubeSigner\"\n  | \"Fido\"\n  | `FidoKey#${string}`\n  | \"Totp\"\n  | \"EmailOtp\"\n  | `EmailOtp#${number}`;\nexport type MfaPolicy = Omit<schemas[\"MfaPolicy\"], \"allowed_mfa_types\"> & {\n  /** Allowed approval types. When omitted, defaults to any. */\n  allowed_mfa_types?: MfaType[] | null; // overriding to use a stronger `MfaType` type\n};\nexport type MfaVote = schemas[\"MfaVote\"];\nexport type MfaRequestInfo = schemas[\"MfaRequestInfo\"];\nexport type MfaProtectedAction = schemas[\"MfaProtectedAction\"];\nexport type MfaRequired = schemas[\"AcceptedValue\"][\"MfaRequired\"];\nexport type EvmTxCmp = schemas[\"EvmTxCmp\"];\nexport type SolanaTxCmp = schemas[\"SolanaTxCmp\"];\n\nexport type CreateOrgRequest = schemas[\"CreateOrgRequest\"];\nexport type OrgMetricName = schemas[\"MetricName\"];\nexport type QueryMetricsRequest = schemas[\"QueryMetricsRequest\"];\nexport type QueryMetricsResponse = schemas[\"QueryMetricsResponse\"];\nexport type AuditLogRequest = schemas[\"AuditLogRequest\"];\nexport type AuditLogResponse = schemas[\"PaginatedAuditLogResponse\"];\nexport type AuditLogEntry = schemas[\"AuditLogEntry\"];\n\nexport type DiffieHellmanRequest = schemas[\"DiffieHellmanRequest\"];\nexport type DiffieHellmanResponse = schemas[\"DiffieHellmanResponse\"];\n\nexport type UserExportInitRequest = schemas[\"UserExportInitRequest\"];\nexport type UserExportInitResponse = schemas[\"UserExportInitResponse\"];\nexport type UserExportCompleteRequest = schemas[\"UserExportCompleteRequest\"];\nexport type UserExportCompleteResponse = schemas[\"UserExportCompleteResponse\"];\nexport type UserExportListResponse = schemas[\"PaginatedUserExportListResponse\"];\nexport type UserExportKeyMaterial = schemas[\"JsonKeyPackage\"];\n\nexport type HistoricalTx = schemas[\"HistoricalTx\"];\nexport type ListHistoricalTxResponse = schemas[\"PaginatedListHistoricalTxResponse\"];\n\nexport type LoginRequest = schemas[\"LoginRequest\"];\nexport type PasskeyAssertChallenge = schemas[\"PasskeyAssertChallenge\"];\nexport type PasskeyAssertAnswer = schemas[\"PasskeyAssertAnswer\"];\nexport type AuthenticationRequest = schemas[\"AuthenticationRequest\"];\nexport type AuthenticationResponse = schemas[\"AuthenticationResponse\"];\nexport type PasswordResetRequest = schemas[\"PasswordResetRequest\"];\nexport type PasswordResetConfirmRequest = schemas[\"PasswordResetConfirmRequest\"];\nexport type EmailOtpResponse = schemas[\"EmailOtpResponse\"];\nexport type EmailTemplatePurpose = schemas[\"Purpose\"];\nexport type GetEmailConfigResponse = schemas[\"GetEmailConfigResponse\"];\n\nexport type Empty = schemas[\"EmptyImpl\"];\n\nexport type ExplicitScope = schemas[\"ExplicitScope\"];\nexport type Scope = schemas[\"Scope\"];\n\n/** Options for a new OIDC user */\nexport interface CreateOidcUserOptions {\n  /** Optional name */\n  name?: string | null;\n  /** The role of an OIDC user, default is \"Alien\" */\n  memberRole?: MemberRole;\n  /** Optional MFA policy to associate with the user account */\n  mfaPolicy?: MfaPolicy;\n}\n\nexport type GetRoleKeyOptions = operations[\"getRoleKey\"][\"parameters\"][\"query\"];\n\n/** Ava P- or X-chain transaction */\nexport type AvaTx = { P: AvaPChainTx } | { X: AvaXChainTx };\n\n/** Ava P-chain transaction */\nexport type AvaPChainTx =\n  | { AddPermissionlessValidator: JsonMap }\n  | { AddSubnetValidator: JsonMap }\n  | { AddValidator: JsonMap }\n  | { CreateChain: JsonMap }\n  | { CreateSubnet: JsonMap }\n  | { Export: JsonMap }\n  | { Import: JsonMap };\n\n/** Ava X-chain transaction */\nexport type AvaXChainTx = { Base: JsonMap } | { Export: JsonMap } | { Import: JsonMap };\n\n/** Ava chains */\nexport type AvaChain = \"C\" | \"X\" | \"P\";\n\n/** Key import */\nexport type CreateKeyImportKeyResponse = schemas[\"CreateKeyImportKeyResponse\"];\nexport type ImportKeyRequest = schemas[\"ImportKeyRequest\"];\nexport type ImportKeyRequestMaterial = schemas[\"ImportKeyRequestMaterial\"];\n\nexport type InvitationAcceptRequest = schemas[\"InvitationAcceptRequest\"];\n\nexport type KeyTypeAndDerivationPath = schemas[\"KeyTypeAndDerivationPath\"];\nexport type PolicyInfo = schemas[\"PolicyInfo\"] & {\n  acl?: JsonValue[];\n};\n\n/**\n * Coerce the less accurate `PolicyInfo` type from the OpenAPI schema to a more accurate {@link PolicyInfo}.\n *\n * @param p The policy info received on the wire\n * @returns The same value coerced to {@link PolicyInfo}\n */\nexport function coercePolicyInfo(p: schemas[\"PolicyInfo\"]): PolicyInfo {\n  return p as PolicyInfo;\n}\n\nexport type UpdatePolicyRequest = schemas[\"UpdatePolicyRequest\"] & {\n  rules?: JsonValue[];\n  acl?: JsonValue[];\n};\nexport type ListPoliciesResponse = schemas[\"PaginatedListPoliciesResponse\"];\nexport type PolicyType = schemas[\"PolicyType\"];\nexport type PolicyAttachedToId = schemas[\"PolicyAttachedToId\"];\n\nexport type ListBucketsResponse = schemas[\"PaginatedListBucketsResponse\"];\nexport type UpdateBucketRequest = schemas[\"UpdateBucketRequest\"];\nexport type BucketAction = schemas[\"BucketAction\"];\n\nexport type UploadWasmPolicyRequest = schemas[\"UploadWasmPolicyRequest\"];\nexport type UploadWasmPolicyResponse = schemas[\"UploadWasmPolicyResponse\"];\nexport type InvokePolicyRequest = schemas[\"InvokePolicyRequest\"];\n\nexport type WasmRule = schemas[\"WasmRule\"];\nexport type InvokeC2FResponse = InvokePolicyResponse;\nexport type InvokePolicyResponse = schemas[\"InvokePolicyResponse\"];\nexport type C2FResponse = WasmPolicyResponse;\nexport type WasmPolicyResponse = schemas[\"WasmPolicyResponse\"];\nexport type C2FConfiguration = PolicyEngineConfiguration;\nexport type PolicyEngineConfiguration = schemas[\"PolicyEngineConfiguration\"];\n\nexport type PolicyAction = schemas[\"PolicyAction\"];\nexport type SecretAction = schemas[\"SecretAction\"];\n"]}
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema_types.js","sourceRoot":"","sources":["../../src/schema_types.ts"],"names":[],"mappings":";;;AA+SA,4CAEC;AA1QD,QAAQ;AACR,8EAA8E;AAC9E,oFAAoF;AACpF,MAAM,iBAAiB,GAAgC;IACrD,OAAO,EAAE,IAAI;IACb,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE,IAAI;IACpB,mBAAmB,EAAE,IAAI;IACzB,cAAc,EAAE,IAAI;IACpB,QAAQ,EAAE,IAAI;IACd,cAAc,EAAE,IAAI;IACpB,OAAO,EAAE,IAAI;IACb,aAAa,EAAE,IAAI;IACnB,QAAQ,EAAE,IAAI;IACd,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI;IACf,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE,IAAI;IACb,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,IAAI;CACjB,CAAC;AACW,QAAA,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAA6B,CAAC;AAsO9F;;;;;GAKG;AACH,SAAgB,gBAAgB,CAAC,CAAwB;IACvD,OAAO,CAAe,CAAC;AACzB,CAAC","sourcesContent":["import type { components, operations, paths } from \"./schema\";\nimport type { JsonMap, JsonValue } from \"./util\";\n\nexport type schemas = components[\"schemas\"];\n\nexport type UserInfo = schemas[\"UserInfo\"];\nexport type UserInOrgMembership = schemas[\"UserInOrgMembership\"];\nexport type ConfiguredMfa = schemas[\"ConfiguredMfa\"];\nexport type RatchetConfig = schemas[\"RatchetConfig\"];\nexport type IdentityProof = schemas[\"IdentityProof\"];\nexport type AddIdentityRequest = schemas[\"AddIdentityRequest\"];\nexport type ListIdentityResponse = schemas[\"ListIdentitiesResponse\"];\nexport type TotpInfo = schemas[\"TotpInfo\"];\n\nexport type OidcAuthResponse = schemas[\"NewSessionResponse\"];\nexport type ApiAddFidoChallenge = schemas[\"FidoCreateChallengeResponse\"];\nexport type ApiMfaFidoChallenge = schemas[\"FidoAssertChallenge\"];\n\nexport type PublicKeyCredentialCreationOptions = schemas[\"PublicKeyCredentialCreationOptions\"];\nexport type PublicKeyCredentialRequestOptions = schemas[\"PublicKeyCredentialRequestOptions\"];\nexport type PublicKeyCredentialParameters = schemas[\"PublicKeyCredentialParameters\"];\nexport type PublicKeyCredentialDescriptor = schemas[\"PublicKeyCredentialDescriptor\"];\nexport type AuthenticatorSelectionCriteria = schemas[\"AuthenticatorSelectionCriteria\"];\nexport type PublicKeyCredentialUserEntity = schemas[\"PublicKeyCredentialUserEntity\"];\nexport type PublicKeyCredential = schemas[\"PublicKeyCredential\"];\n\nexport type OrgInfo = schemas[\"OrgInfo\"];\nexport type OrgExtData = NonNullable<OrgInfo[\"ext_data\"]>;\nexport type PublicOrgInfo = schemas[\"PublicOrgInfo\"];\nexport type UserInOrgInfo = schemas[\"UserInOrgInfo\"];\nexport type UpdateOrgRequest = schemas[\"UpdateOrgRequest\"];\nexport type OrgExtProps = NonNullable<UpdateOrgRequest[\"ext_props\"]>;\nexport type UpdateOrgResponse = schemas[\"UpdateOrgResponse\"];\nexport type UpdateUserMembershipRequest = schemas[\"UpdateUserMembershipRequest\"];\nexport type NotificationEndpointConfiguration = schemas[\"NotificationEndpointConfiguration\"];\nexport type OrgEvents = schemas[\"OrgEventDiscriminants\"];\nexport type BillingEvent = schemas[\"BillingEvent\"];\nexport type OperationKind = schemas[\"OperationKind\"];\n\n// NOTE:\n//   we use `Record<OperationKind, ...>` (instead of `OperationKind[]`) to get\n//   the type checker to complain unless this record includes every single operation\nconst AllOperationKinds: Record<OperationKind, true> = {\n  AvaSign: true,\n  AvaChainTxSign: true,\n  BabylonCovSign: true,\n  BabylonRegistration: true,\n  BabylonStaking: true,\n  BlobSign: true,\n  BtcMessageSign: true,\n  BtcSign: true,\n  DiffieHellman: true,\n  PsbtSign: true,\n  TaprootSign: true,\n  Eip191Sign: true,\n  Eip712Sign: true,\n  EotsNonces: true,\n  EotsSign: true,\n  Eth1Sign: true,\n  Eth2Sign: true,\n  Eth2Stake: true,\n  Eth2Unstake: true,\n  SolanaSign: true,\n  SuiSign: true,\n  TendermintSign: true,\n  RoleUpdate: true,\n};\nexport const ALL_OPERATION_KINDS = Object.keys(AllOperationKinds) as readonly OperationKind[];\n\nexport type OrgData = schemas[\"OrgData\"];\nexport type UserOrgsResponse = schemas[\"UserOrgsResponse\"];\n\nexport type OidcIdentity = schemas[\"OidcIdentity\"];\nexport type MemberRole = schemas[\"MemberRole\"];\n\nexport type SchemaKeyType = schemas[\"KeyType\"];\n\nexport type ListKeysResponse = schemas[\"PaginatedListKeysResponse\"];\nexport type UpdateKeyRequest = schemas[\"UpdateKeyRequest\"];\nexport type KeyProperties = schemas[\"CreateAndUpdateKeyProperties\"];\nexport type CreateKeyRequest = schemas[\"CreateKeyRequest\"];\nexport type KeyInfo = schemas[\"KeyInfo\"];\nexport type KeyInfoJwt = schemas[\"KeyInfoJwt\"];\nexport type KeyAttestationClaims = schemas[\"KeyAttestationClaims\"];\nexport type KeyAttestationQuery =\n  paths[\"/v0/org/{org_id}/keys/{key_id}/attest\"][\"get\"][\"parameters\"][\"query\"];\nexport type RoleInfoJwt = schemas[\"RoleInfoJwt\"];\nexport type RoleAttestationClaims = schemas[\"RoleAttestationClaims\"];\nexport type RoleAttestationQuery =\n  paths[\"/v0/org/{org_id}/roles/{role_id}/attest\"][\"get\"][\"parameters\"][\"query\"];\nexport type RoleAttestationVerbosity = schemas[\"RoleAttestationVerbosity\"];\nexport type KeyInRoleInfo = schemas[\"KeyInRoleInfo\"];\nexport type GetUsersInOrgResponse = schemas[\"PaginatedGetUsersInOrgResponse\"];\nexport type GetUserByEmailResponse = schemas[\"GetUserByEmailResponse\"];\nexport type GetUserByOidcResponse = schemas[\"GetUserByOidcResponse\"];\n\nexport type UserInRoleInfo = schemas[\"UserInRoleInfo\"];\nexport type KeyTypeApi = schemas[\"KeyType\"];\n\nexport type ListKeyRolesResponse = schemas[\"PaginatedListKeyRolesResponse\"];\nexport type ListRolesResponse = schemas[\"PaginatedListRolesResponse\"];\nexport type ListRoleKeysResponse = schemas[\"PaginatedListRoleKeysResponse\"];\nexport type ListRoleUsersResponse = schemas[\"PaginatedListRoleUsersResponse\"];\nexport type UpdateRoleRequest = schemas[\"UpdateRoleRequest\"];\nexport type KeyWithPoliciesInfo = schemas[\"KeyInRoleInfo\"];\nexport type RoleInfo = schemas[\"RoleInfo\"];\nexport type RoleAction = schemas[\"RoleAction\"];\nexport type RestrictedActionsMap = Partial<Record<RoleAction, MemberRole[]>>;\n\nexport type SessionInfo = schemas[\"SessionInfo\"];\nexport type ClientSessionInfo = schemas[\"ClientSessionInfo\"];\nexport type NewSessionResponse = schemas[\"NewSessionResponse\"];\nexport type SessionsResponse = schemas[\"PaginatedSessionsResponse\"];\n\nexport type EditPolicy = schemas[\"EditPolicy\"];\n\nexport type ContactInfo = schemas[\"ContactInfoResponse\"];\nexport type AddressMap = schemas[\"AddressMap\"];\nexport type BtcChain = schemas[\"BtcChain\"];\nexport type SuiChain = schemas[\"SuiChain\"];\nexport type CreateContactRequest = schemas[\"CreateContactRequest\"];\nexport type UpdateContactRequest = schemas[\"UpdateContactRequest\"];\nexport type ListContactsResponse = schemas[\"PaginatedListContactsResponse\"];\nexport type ContactLabel = schemas[\"ContactLabel\"];\nexport type ContactAddressData = schemas[\"ContactAddressData\"];\n\nexport type CreateSignerSessionRequest = schemas[\"CreateTokenRequest\"];\nexport type RefreshSignerSessionRequest = schemas[\"AuthData\"];\n\nexport type EvmSignRequest = schemas[\"Eth1SignRequest\"];\nexport type EvmSignResponse = schemas[\"Eth1SignResponse\"];\nexport type Eip191SignRequest = schemas[\"Eip191SignRequest\"];\nexport type Eip712SignRequest = schemas[\"Eip712SignRequest\"];\nexport type Eip191Or712SignResponse = schemas[\"SignResponse\"];\nexport type Eth2SignRequest = schemas[\"Eth2SignRequest\"];\nexport type Eth2SignResponse = schemas[\"SignResponse\"];\nexport type Eth2StakeRequest = schemas[\"StakeRequest\"];\nexport type Eth2StakeResponse = schemas[\"StakeResponse\"];\nexport type Eth2UnstakeRequest = schemas[\"UnstakeRequest\"];\nexport type Eth2UnstakeResponse = schemas[\"UnstakeResponse\"];\nexport type BlobSignRequest = schemas[\"BlobSignRequest\"];\nexport type BlobSignResponse = schemas[\"SignResponse\"];\nexport type BtcSignRequest = schemas[\"BtcSignRequest\"];\nexport type BtcSignResponse = schemas[\"SignResponse\"];\nexport type BtcMessageSignRequest = schemas[\"BtcMessageSignRequest\"];\nexport type BtcMessageSignResponse = schemas[\"BtcMessageSignResponse\"];\nexport type PsbtSignRequest = schemas[\"PsbtSignRequest\"];\nexport type PsbtSignResponse = schemas[\"PsbtSignResponse\"];\nexport type TaprootSignRequest = schemas[\"TaprootSignRequest\"];\nexport type TaprootSignResponse = schemas[\"SignResponse\"];\nexport type EotsSignRequest = schemas[\"EotsSignRequest\"];\nexport type EotsSignResponse = schemas[\"SignResponse\"];\nexport type EotsCreateNonceRequest = schemas[\"EotsCreateNonceRequest\"];\nexport type EotsCreateNonceResponse = schemas[\"EotsCreateNonceResponse\"];\nexport type BabylonStakingRequest = schemas[\"BabylonStakingRequest\"];\nexport type BabylonStakingResponse = schemas[\"BabylonStakingResponse\"];\nexport type BabylonStakingEarlyUnbond = schemas[\"BabylonStakingEarlyUnbond\"];\nexport type BabylonStakingWithdrawal = schemas[\"BabylonStakingWithdrawal\"];\nexport type BabylonRegistrationRequest = schemas[\"BabylonRegistrationRequest\"];\nexport type BabylonRegistrationResponse = schemas[\"BabylonRegistrationResponse\"];\nexport type SolanaSignRequest = schemas[\"SolanaSignRequest\"];\nexport type SolanaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSignRequest = schemas[\"AvaSignRequest\"];\nexport type AvaSignResponse = schemas[\"SignResponse\"];\nexport type AvaSerializedTxSignRequest = schemas[\"AvaSerializedTxSignRequest\"];\nexport type SuiSignRequest = schemas[\"SuiSignRequest\"];\nexport type SuiSignResponse = schemas[\"SignResponse\"];\n\nexport type PendingMessageSignResponse = schemas[\"PendingMessageSignResponse\"];\nexport type PendingMessageInfo = schemas[\"PendingMessageInfo\"];\nexport type EvmTransaction = schemas[\"Transaction\"];\nexport type TypedTransaction = schemas[\"TypedTransaction\"];\nexport type TransactionAndStatus = schemas[\"TransactionAndStatus\"];\nexport type SignedMessage = schemas[\"SignedMessage\"];\nexport type MmiMetadata = schemas[\"MmiMetadata\"];\nexport type MmiStatus = schemas[\"MmiStatus\"];\nexport type Eip191Message = NonNullable<PendingMessageInfo[\"message_eip191\"]>;\nexport type Eip712Message = NonNullable<PendingMessageInfo[\"message_eip712\"]>;\n\nexport type JrpcResponse = schemas[\"JrpcResponse\"];\nexport type MmiJrpcMethod =\n  | \"custodian_listAccounts\"\n  | \"custodian_listAccountsSigned\"\n  | \"custodian_listAccountChainIds\"\n  | \"custodian_createTransaction\"\n  | \"custodian_sign\"\n  | \"custodian_signTypedData\"\n  | \"custodian_getSignedMessageById\"\n  | \"custodian_getTransactionById\"\n  | \"custodian_getCustomerProof\"\n  | \"custodian_replaceTransaction\"\n  | \"custodian_getTransactionLink\"\n  | \"custodian_getSignedMessageLink\";\n\nexport type AcceptedResponse = schemas[\"AcceptedResponse\"];\nexport type ErrorResponse = schemas[\"ErrorResponse\"];\nexport type BtcSignatureKind = schemas[\"BtcSignatureKind\"];\nexport type CsErrCode = schemas[\"SignerErrorCode\"];\n\nexport type MfaType =\n  | \"CubeSigner\"\n  | \"Fido\"\n  | `FidoKey#${string}`\n  | \"Totp\"\n  | \"EmailOtp\"\n  | `EmailOtp#${number}`;\nexport type MfaPolicy = Omit<schemas[\"MfaPolicy\"], \"allowed_mfa_types\"> & {\n  /** Allowed approval types. When omitted, defaults to any. */\n  allowed_mfa_types?: MfaType[] | null; // overriding to use a stronger `MfaType` type\n};\nexport type MfaVote = schemas[\"MfaVote\"];\nexport type MfaRequestInfo = schemas[\"MfaRequestInfo\"];\nexport type MfaProtectedAction = schemas[\"MfaProtectedAction\"];\nexport type MfaRequired = schemas[\"AcceptedValue\"][\"MfaRequired\"];\nexport type EvmTxCmp = schemas[\"EvmTxCmp\"];\nexport type SolanaTxCmp = schemas[\"SolanaTxCmp\"];\n\nexport type CreateOrgRequest = schemas[\"CreateOrgRequest\"];\nexport type OrgMetricName = schemas[\"MetricName\"];\nexport type QueryMetricsRequest = schemas[\"QueryMetricsRequest\"];\nexport type QueryMetricsResponse = schemas[\"QueryMetricsResponse\"];\nexport type AuditLogRequest = schemas[\"AuditLogRequest\"];\nexport type AuditLogResponse = schemas[\"PaginatedAuditLogResponse\"];\nexport type { AuditLogEntry } from \"./audit_log\";\n\nexport type DiffieHellmanRequest = schemas[\"DiffieHellmanRequest\"];\nexport type DiffieHellmanResponse = schemas[\"DiffieHellmanResponse\"];\n\nexport type UserExportInitRequest = schemas[\"UserExportInitRequest\"];\nexport type UserExportInitResponse = schemas[\"UserExportInitResponse\"];\nexport type UserExportCompleteRequest = schemas[\"UserExportCompleteRequest\"];\nexport type UserExportCompleteResponse = schemas[\"UserExportCompleteResponse\"];\nexport type UserExportListResponse = schemas[\"PaginatedUserExportListResponse\"];\nexport type UserExportKeyMaterial = schemas[\"JsonKeyPackage\"];\n\nexport type HistoricalTx = schemas[\"HistoricalTx\"];\nexport type ListHistoricalTxResponse = schemas[\"PaginatedListHistoricalTxResponse\"];\n\nexport type LoginRequest = schemas[\"LoginRequest\"];\nexport type PasskeyAssertChallenge = schemas[\"PasskeyAssertChallenge\"];\nexport type PasskeyAssertAnswer = schemas[\"PasskeyAssertAnswer\"];\nexport type AuthenticationRequest = schemas[\"AuthenticationRequest\"];\nexport type AuthenticationResponse = schemas[\"AuthenticationResponse\"];\nexport type PasswordResetRequest = schemas[\"PasswordResetRequest\"];\nexport type PasswordResetConfirmRequest = schemas[\"PasswordResetConfirmRequest\"];\nexport type EmailOtpResponse = schemas[\"EmailOtpResponse\"];\nexport type EmailTemplatePurpose = schemas[\"Purpose\"];\nexport type GetEmailConfigResponse = schemas[\"GetEmailConfigResponse\"];\n\nexport type Empty = schemas[\"EmptyImpl\"];\n\nexport type ExplicitScope = schemas[\"ExplicitScope\"];\nexport type Scope = schemas[\"Scope\"];\n\n/** Options for a new OIDC user */\nexport interface CreateOidcUserOptions {\n  /** Optional name */\n  name?: string | null;\n  /** The role of an OIDC user, default is \"Alien\" */\n  memberRole?: MemberRole;\n  /** Optional MFA policy to associate with the user account */\n  mfaPolicy?: MfaPolicy;\n}\n\nexport type GetRoleKeyOptions = operations[\"getRoleKey\"][\"parameters\"][\"query\"];\n\n/** Ava P- or X-chain transaction */\nexport type AvaTx = { P: AvaPChainTx } | { X: AvaXChainTx };\n\n/** Ava P-chain transaction */\nexport type AvaPChainTx =\n  | { AddPermissionlessValidator: JsonMap }\n  | { AddSubnetValidator: JsonMap }\n  | { AddValidator: JsonMap }\n  | { CreateChain: JsonMap }\n  | { CreateSubnet: JsonMap }\n  | { Export: JsonMap }\n  | { Import: JsonMap };\n\n/** Ava X-chain transaction */\nexport type AvaXChainTx = { Base: JsonMap } | { Export: JsonMap } | { Import: JsonMap };\n\n/** Ava chains */\nexport type AvaChain = \"C\" | \"X\" | \"P\";\n\n/** Key import */\nexport type CreateKeyImportKeyResponse = schemas[\"CreateKeyImportKeyResponse\"];\nexport type ImportKeyRequest = schemas[\"ImportKeyRequest\"];\nexport type ImportKeyRequestMaterial = schemas[\"ImportKeyRequestMaterial\"];\n\nexport type InvitationAcceptRequest = schemas[\"InvitationAcceptRequest\"];\n\nexport type KeyTypeAndDerivationPath = schemas[\"KeyTypeAndDerivationPath\"];\nexport type PolicyInfo = schemas[\"PolicyInfo\"] & {\n  acl?: JsonValue[];\n};\n\n/**\n * Coerce the less accurate `PolicyInfo` type from the OpenAPI schema to a more accurate {@link PolicyInfo}.\n *\n * @param p The policy info received on the wire\n * @returns The same value coerced to {@link PolicyInfo}\n */\nexport function coercePolicyInfo(p: schemas[\"PolicyInfo\"]): PolicyInfo {\n  return p as PolicyInfo;\n}\n\nexport type UpdatePolicyRequest = schemas[\"UpdatePolicyRequest\"] & {\n  rules?: JsonValue[];\n  acl?: JsonValue[];\n};\nexport type ListPoliciesResponse = schemas[\"PaginatedListPoliciesResponse\"];\nexport type PolicyType = schemas[\"PolicyType\"];\nexport type PolicyAttachedToId = schemas[\"PolicyAttachedToId\"];\n\nexport type ListBucketsResponse = schemas[\"PaginatedListBucketsResponse\"];\nexport type UpdateBucketRequest = schemas[\"UpdateBucketRequest\"];\nexport type BucketAction = schemas[\"BucketAction\"];\n\nexport type UploadWasmPolicyRequest = schemas[\"UploadWasmPolicyRequest\"];\nexport type UploadWasmPolicyResponse = schemas[\"UploadWasmPolicyResponse\"];\nexport type InvokePolicyRequest = schemas[\"InvokePolicyRequest\"];\n\nexport type WasmRule = schemas[\"WasmRule\"];\nexport type InvokeC2FResponse = InvokePolicyResponse;\nexport type InvokePolicyResponse = schemas[\"InvokePolicyResponse\"];\nexport type C2FResponse = WasmPolicyResponse;\nexport type WasmPolicyResponse = schemas[\"WasmPolicyResponse\"];\nexport type C2FConfiguration = PolicyEngineConfiguration;\nexport type PolicyEngineConfiguration = schemas[\"PolicyEngineConfiguration\"];\n\nexport type PolicyAction = schemas[\"PolicyAction\"];\nexport type SecretAction = schemas[\"SecretAction\"];\n"]}
|
package/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.241",
|
|
9
9
|
"description": "CubeSigner TypeScript SDK",
|
|
10
10
|
"license": "MIT OR Apache-2.0",
|
|
11
11
|
"author": "Cubist, Inc.",
|
|
@@ -26,7 +26,8 @@
|
|
|
26
26
|
"typedoc": "typedoc"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"openapi-fetch": "0.8.2"
|
|
29
|
+
"openapi-fetch": "0.8.2",
|
|
30
|
+
"zod": "^4.3.6"
|
|
30
31
|
},
|
|
31
32
|
"optionalDependencies": {
|
|
32
33
|
"@hpke/core": "^1.2.7"
|
package/src/audit_log.ts
ADDED
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { z } from "zod/mini";
|
|
2
|
+
import type { components } from "./schema";
|
|
3
|
+
|
|
4
|
+
type OrgEventDiscriminants = components["schemas"]["OrgEventDiscriminants"];
|
|
5
|
+
type BillingEvent = components["schemas"]["BillingEvent"];
|
|
6
|
+
type MemberRole = components["schemas"]["MemberRole"];
|
|
7
|
+
type OperationKind = components["schemas"]["OperationKind"];
|
|
8
|
+
type KeyType = components["schemas"]["KeyType"];
|
|
9
|
+
|
|
10
|
+
const schemaString = <T extends string>() => z.custom<T>((val) => typeof val === "string");
|
|
11
|
+
|
|
12
|
+
const baseFields = {
|
|
13
|
+
/** The type of org event. */
|
|
14
|
+
event: z.string(),
|
|
15
|
+
/** UUID uniquely identifying this event across all events. */
|
|
16
|
+
event_id: z.string(),
|
|
17
|
+
/** The org in which this event occurred. */
|
|
18
|
+
org_id: z.string(),
|
|
19
|
+
/** ID of the HTTP request that triggered this event (one request can trigger multiple events). */
|
|
20
|
+
request_id: z.string(),
|
|
21
|
+
/** Timestamp of when the event was logged, formatted like YYYY-MM-DD HH:MM:SS.NNNNNNNNN */
|
|
22
|
+
time: z.string(),
|
|
23
|
+
/** ID of the user or role that triggered the event; absent for unauthenticated endpoints. */
|
|
24
|
+
triggered_by: z.nullable(z.string()),
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export const auditLogEntrySchema = z.discriminatedUnion("event", [
|
|
28
|
+
z.object({
|
|
29
|
+
...baseFields,
|
|
30
|
+
event: z.literal("Billing"),
|
|
31
|
+
kind: schemaString<BillingEvent>(),
|
|
32
|
+
user_id: z.optional(z.string()),
|
|
33
|
+
role_id: z.optional(z.string()),
|
|
34
|
+
key_id: z.optional(z.string()),
|
|
35
|
+
}),
|
|
36
|
+
z.object({
|
|
37
|
+
...baseFields,
|
|
38
|
+
event: z.literal("Response"),
|
|
39
|
+
kind: schemaString<BillingEvent>(),
|
|
40
|
+
status: z.coerce.number(),
|
|
41
|
+
duration_ms: z.coerce.number(),
|
|
42
|
+
}),
|
|
43
|
+
z.object({
|
|
44
|
+
...baseFields,
|
|
45
|
+
event: z.literal("OidcAuth"),
|
|
46
|
+
issuer: z.string(),
|
|
47
|
+
membership: schemaString<MemberRole>(),
|
|
48
|
+
email: z.optional(z.string()),
|
|
49
|
+
username: z.optional(z.string()),
|
|
50
|
+
scopes: z.array(z.string()),
|
|
51
|
+
}),
|
|
52
|
+
z.object({
|
|
53
|
+
...baseFields,
|
|
54
|
+
event: z.literal("Signed"),
|
|
55
|
+
kind: schemaString<OperationKind>(),
|
|
56
|
+
key_type: schemaString<KeyType>(),
|
|
57
|
+
key_id: z.string(),
|
|
58
|
+
}),
|
|
59
|
+
z.object({
|
|
60
|
+
...baseFields,
|
|
61
|
+
event: z.literal("BabylonEotsConcurrentSigning"),
|
|
62
|
+
key_id: z.string(),
|
|
63
|
+
chain_id: z.string(),
|
|
64
|
+
prev_block_height: z.coerce.number(),
|
|
65
|
+
prev_signing_hash: z.string(),
|
|
66
|
+
req_block_height: z.coerce.number(),
|
|
67
|
+
req_signing_hash: z.string(),
|
|
68
|
+
}),
|
|
69
|
+
z.object({
|
|
70
|
+
...baseFields,
|
|
71
|
+
event: z.literal("Eth2ConcurrentAttestationSigning"),
|
|
72
|
+
key_id: z.string(),
|
|
73
|
+
}),
|
|
74
|
+
z.object({
|
|
75
|
+
...baseFields,
|
|
76
|
+
event: z.literal("Eth2ConcurrentBlockSigning"),
|
|
77
|
+
key_id: z.string(),
|
|
78
|
+
}),
|
|
79
|
+
z.object({
|
|
80
|
+
...baseFields,
|
|
81
|
+
event: z.literal("Eth2InvalidBlockProposerSlotTooLow"),
|
|
82
|
+
slot: z.coerce.number(),
|
|
83
|
+
signing_root: z.string(),
|
|
84
|
+
last_slot: z.coerce.number(),
|
|
85
|
+
last_signing_root: z.string(),
|
|
86
|
+
enforced: z.coerce.boolean(),
|
|
87
|
+
}),
|
|
88
|
+
z.object({
|
|
89
|
+
...baseFields,
|
|
90
|
+
event: z.literal("Eth2InvalidAttestationSourceEpochTooLow"),
|
|
91
|
+
source_epoch: z.coerce.number(),
|
|
92
|
+
signing_root: z.string(),
|
|
93
|
+
last_target_epoch: z.coerce.number(),
|
|
94
|
+
last_signing_root: z.string(),
|
|
95
|
+
enforced: z.coerce.boolean(),
|
|
96
|
+
}),
|
|
97
|
+
z.object({
|
|
98
|
+
...baseFields,
|
|
99
|
+
event: z.literal("Eth2InvalidAttestationTargetEpochTooLow"),
|
|
100
|
+
target_epoch: z.coerce.number(),
|
|
101
|
+
signing_root: z.string(),
|
|
102
|
+
last_target_epoch: z.coerce.number(),
|
|
103
|
+
last_signing_root: z.string(),
|
|
104
|
+
enforced: z.coerce.boolean(),
|
|
105
|
+
}),
|
|
106
|
+
z.object({
|
|
107
|
+
...baseFields,
|
|
108
|
+
event: z.literal("Eth2Unstake"),
|
|
109
|
+
key_id: z.string(),
|
|
110
|
+
validator_index: z.coerce.number(),
|
|
111
|
+
daily_unstake_count: z.coerce.number(),
|
|
112
|
+
}),
|
|
113
|
+
z.object({
|
|
114
|
+
...baseFields,
|
|
115
|
+
event: z.literal("Eth2ExceededMaxUnstake"),
|
|
116
|
+
max: z.coerce.number(),
|
|
117
|
+
date: z.string(),
|
|
118
|
+
}),
|
|
119
|
+
z.object({
|
|
120
|
+
...baseFields,
|
|
121
|
+
event: z.literal("KeyCreated"),
|
|
122
|
+
key_type: schemaString<KeyType>(),
|
|
123
|
+
owner_id: z.string(),
|
|
124
|
+
count: z.coerce.number(),
|
|
125
|
+
}),
|
|
126
|
+
z.object({
|
|
127
|
+
...baseFields,
|
|
128
|
+
event: z.literal("MfaApproved"),
|
|
129
|
+
mfa_id: z.string(),
|
|
130
|
+
meets_approval_criteria: z.coerce.boolean(),
|
|
131
|
+
}),
|
|
132
|
+
z.object({
|
|
133
|
+
...baseFields,
|
|
134
|
+
event: z.literal("MfaRejected"),
|
|
135
|
+
mfa_id: z.string(),
|
|
136
|
+
}),
|
|
137
|
+
z.object({
|
|
138
|
+
...baseFields,
|
|
139
|
+
event: z.literal("PolicyChanged"),
|
|
140
|
+
}),
|
|
141
|
+
z.object({
|
|
142
|
+
...baseFields,
|
|
143
|
+
event: z.literal("TendermintConcurrentSigning"),
|
|
144
|
+
key_id: z.string(),
|
|
145
|
+
chain_id: z.string(),
|
|
146
|
+
last_state: z.string(),
|
|
147
|
+
current_state: z.string(),
|
|
148
|
+
}),
|
|
149
|
+
z.object({
|
|
150
|
+
...baseFields,
|
|
151
|
+
event: z.literal("InvitationCreated"),
|
|
152
|
+
email: z.string(),
|
|
153
|
+
role: z.string(),
|
|
154
|
+
}),
|
|
155
|
+
z.object({
|
|
156
|
+
...baseFields,
|
|
157
|
+
event: z.literal("InvitationCanceled"),
|
|
158
|
+
email: z.string(),
|
|
159
|
+
}),
|
|
160
|
+
z.object({
|
|
161
|
+
...baseFields,
|
|
162
|
+
event: z.literal("UserExportInit"),
|
|
163
|
+
key_id: z.string(),
|
|
164
|
+
valid_epoch: z.coerce.number(),
|
|
165
|
+
}),
|
|
166
|
+
z.object({
|
|
167
|
+
...baseFields,
|
|
168
|
+
event: z.literal("UserExportComplete"),
|
|
169
|
+
key_id: z.string(),
|
|
170
|
+
}),
|
|
171
|
+
z.object({
|
|
172
|
+
...baseFields,
|
|
173
|
+
event: z.literal("WasmPolicyExecuted"),
|
|
174
|
+
source: z.string(),
|
|
175
|
+
key_id: z.optional(z.string()),
|
|
176
|
+
policy: z.string(),
|
|
177
|
+
policy_hash: z.string(),
|
|
178
|
+
stdout: z.string(),
|
|
179
|
+
stderr: z.string(),
|
|
180
|
+
response: z.string(),
|
|
181
|
+
reason: z.optional(z.string()),
|
|
182
|
+
error: z.optional(z.string()),
|
|
183
|
+
}),
|
|
184
|
+
]);
|
|
185
|
+
|
|
186
|
+
export type AuditLogEntry = z.infer<typeof auditLogEntrySchema>;
|
|
187
|
+
|
|
188
|
+
// Compile-time check: errors if a variant is added to OrgEventDiscriminants but not handled here.
|
|
189
|
+
type _AllVariantsCovered = [OrgEventDiscriminants] extends [AuditLogEntry["event"]]
|
|
190
|
+
? [AuditLogEntry["event"]] extends [OrgEventDiscriminants]
|
|
191
|
+
? true
|
|
192
|
+
: never
|
|
193
|
+
: never;
|
|
194
|
+
const _allVariantsCovered: _AllVariantsCovered = true;
|
|
195
|
+
void _allVariantsCovered;
|
package/src/client/api_client.ts
CHANGED
|
@@ -71,6 +71,7 @@ import type {
|
|
|
71
71
|
PolicyInfo,
|
|
72
72
|
} from "../schema_types";
|
|
73
73
|
import { encodeToBase64 } from "../util";
|
|
74
|
+
import { auditLogEntrySchema } from "../audit_log";
|
|
74
75
|
import {
|
|
75
76
|
AddFidoChallenge,
|
|
76
77
|
MfaFidoChallenge,
|
|
@@ -159,13 +160,19 @@ import {
|
|
|
159
160
|
type BucketInfo,
|
|
160
161
|
} from "../index";
|
|
161
162
|
import { assertOk, op, type Op, type Operation, apiFetch } from "../fetch";
|
|
162
|
-
import {
|
|
163
|
+
import {
|
|
164
|
+
authHeader,
|
|
165
|
+
BaseClient,
|
|
166
|
+
type ClientConfig,
|
|
167
|
+
signerSessionFromSessionInfo,
|
|
168
|
+
} from "./base_client";
|
|
163
169
|
import { retryOn5XX } from "../retry";
|
|
164
170
|
import { PasskeyLoginChallenge } from "../passkey";
|
|
165
171
|
|
|
166
172
|
// these types are used in doc comments only
|
|
167
173
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
168
174
|
import type { RoleAttestationClaims, KeyAttestationClaims } from "../schema_types";
|
|
175
|
+
import { mergeHeaders } from "openapi-fetch";
|
|
169
176
|
|
|
170
177
|
/**
|
|
171
178
|
* String returned by API when a user does not have an email address (for backwards compatibility)
|
|
@@ -216,10 +223,7 @@ export class ApiClient extends BaseClient {
|
|
|
216
223
|
return new ApiClient(this.sessionMeta, this.sessionManager, this.orgId, {
|
|
217
224
|
...this.config,
|
|
218
225
|
...cfg,
|
|
219
|
-
headers:
|
|
220
|
-
...(this.config.headers ?? {}),
|
|
221
|
-
...(cfg.headers ?? {}),
|
|
222
|
-
},
|
|
226
|
+
headers: mergeHeaders(this.config.headers, cfg.headers),
|
|
223
227
|
});
|
|
224
228
|
}
|
|
225
229
|
|
|
@@ -257,12 +261,14 @@ export class ApiClient extends BaseClient {
|
|
|
257
261
|
* @param env The environment to use
|
|
258
262
|
* @param orgId The org to login to
|
|
259
263
|
* @param email The email to send the signature to
|
|
264
|
+
* @param headers Optional headers to set
|
|
260
265
|
* @returns The partial OIDC token that must be combined with the signature in the email
|
|
261
266
|
*/
|
|
262
267
|
static async initEmailOtpAuth(
|
|
263
268
|
env: EnvInterface,
|
|
264
269
|
orgId: string,
|
|
265
270
|
email: string,
|
|
271
|
+
headers?: HeadersInit,
|
|
266
272
|
): Promise<EmailOtpResponse> {
|
|
267
273
|
const o = op("/v0/org/{org_id}/oidc/email-otp", "post");
|
|
268
274
|
|
|
@@ -271,6 +277,7 @@ export class ApiClient extends BaseClient {
|
|
|
271
277
|
baseUrl: env.SignerApiRoot,
|
|
272
278
|
params: { path: { org_id: orgId } },
|
|
273
279
|
body: { email },
|
|
280
|
+
headers,
|
|
274
281
|
}),
|
|
275
282
|
).then(assertOk);
|
|
276
283
|
}
|
|
@@ -565,7 +572,11 @@ export class ApiClient extends BaseClient {
|
|
|
565
572
|
return Paginator.items(
|
|
566
573
|
page ?? Page.default(),
|
|
567
574
|
(query) => this.exec(o, { body, params: { query } }),
|
|
568
|
-
(r) =>
|
|
575
|
+
(r) =>
|
|
576
|
+
r.entries.flatMap((entry) => {
|
|
577
|
+
const result = auditLogEntrySchema.safeParse(entry);
|
|
578
|
+
return result.success ? [result.data] : [];
|
|
579
|
+
}),
|
|
569
580
|
(r) => r.last_evaluated_key,
|
|
570
581
|
);
|
|
571
582
|
}
|
|
@@ -2929,14 +2940,16 @@ export class ApiClient extends BaseClient {
|
|
|
2929
2940
|
*
|
|
2930
2941
|
* @param env The environment to use
|
|
2931
2942
|
* @param email The user's email
|
|
2943
|
+
* @param headers Optional headers to set
|
|
2932
2944
|
* @returns Empty response
|
|
2933
2945
|
*/
|
|
2934
|
-
static async emailMyOrgs(env: EnvInterface, email: string) {
|
|
2946
|
+
static async emailMyOrgs(env: EnvInterface, email: string, headers?: HeadersInit) {
|
|
2935
2947
|
const o = op("/v0/email/orgs", "get");
|
|
2936
2948
|
return await retryOn5XX(() =>
|
|
2937
2949
|
o({
|
|
2938
2950
|
baseUrl: env.SignerApiRoot,
|
|
2939
2951
|
params: { query: { email } },
|
|
2952
|
+
headers,
|
|
2940
2953
|
}),
|
|
2941
2954
|
).then(assertOk);
|
|
2942
2955
|
}
|
|
@@ -2951,6 +2964,7 @@ export class ApiClient extends BaseClient {
|
|
|
2951
2964
|
* @param lifetimes Lifetimes of the new session.
|
|
2952
2965
|
* @param mfaReceipt Optional MFA receipt(s)
|
|
2953
2966
|
* @param purpose Optional session description.
|
|
2967
|
+
* @param headers Additional headers to set
|
|
2954
2968
|
* @returns The session data.
|
|
2955
2969
|
*/
|
|
2956
2970
|
static async oidcSessionCreate(
|
|
@@ -2961,18 +2975,16 @@ export class ApiClient extends BaseClient {
|
|
|
2961
2975
|
lifetimes?: RatchetConfig,
|
|
2962
2976
|
mfaReceipt?: MfaReceipts,
|
|
2963
2977
|
purpose?: string,
|
|
2978
|
+
headers?: HeadersInit,
|
|
2964
2979
|
): Promise<CubeSignerResponse<SessionData>> {
|
|
2965
2980
|
const o = op("/v0/org/{org_id}/oidc", "post");
|
|
2966
2981
|
|
|
2967
|
-
const loginFn = async (
|
|
2982
|
+
const loginFn = async (mfaHeaders?: HeadersInit) => {
|
|
2968
2983
|
const data = await retryOn5XX(() =>
|
|
2969
2984
|
o({
|
|
2970
2985
|
baseUrl: env.SignerApiRoot,
|
|
2971
2986
|
params: { path: { org_id: orgId } },
|
|
2972
|
-
headers:
|
|
2973
|
-
...headers,
|
|
2974
|
-
Authorization: token,
|
|
2975
|
-
},
|
|
2987
|
+
headers: mergeHeaders(headers, mfaHeaders, authHeader(token)),
|
|
2976
2988
|
body: {
|
|
2977
2989
|
scopes,
|
|
2978
2990
|
purpose,
|
|
@@ -3008,12 +3020,14 @@ export class ApiClient extends BaseClient {
|
|
|
3008
3020
|
* @param env The environment to use
|
|
3009
3021
|
* @param orgId The org to login to
|
|
3010
3022
|
* @param body The request body
|
|
3023
|
+
* @param headers Optional headers to set
|
|
3011
3024
|
* @returns The challenge that needs to be answered via {@link siweLoginComplete}
|
|
3012
3025
|
*/
|
|
3013
3026
|
static async siweLoginInit(
|
|
3014
3027
|
env: EnvInterface,
|
|
3015
3028
|
orgId: string,
|
|
3016
3029
|
body: schemas["SiweInitRequest"],
|
|
3030
|
+
headers?: HeadersInit,
|
|
3017
3031
|
): Promise<schemas["SiweInitResponse"]> {
|
|
3018
3032
|
const o = op("/v0/org/{org_id}/oidc/siwe", "post");
|
|
3019
3033
|
return await retryOn5XX(() =>
|
|
@@ -3021,6 +3035,7 @@ export class ApiClient extends BaseClient {
|
|
|
3021
3035
|
baseUrl: env.SignerApiRoot,
|
|
3022
3036
|
params: { path: { org_id: orgId } },
|
|
3023
3037
|
body,
|
|
3038
|
+
headers,
|
|
3024
3039
|
}),
|
|
3025
3040
|
).then(assertOk);
|
|
3026
3041
|
}
|
|
@@ -3035,12 +3050,14 @@ export class ApiClient extends BaseClient {
|
|
|
3035
3050
|
* @param env The environment to use
|
|
3036
3051
|
* @param orgId The org to login to
|
|
3037
3052
|
* @param body The request body
|
|
3053
|
+
* @param headers Optional headers to set
|
|
3038
3054
|
* @returns An OIDC token which can be used to log in via OIDC (see {@link oidcSessionCreate})
|
|
3039
3055
|
*/
|
|
3040
3056
|
static async siweLoginComplete(
|
|
3041
3057
|
env: EnvInterface,
|
|
3042
3058
|
orgId: string,
|
|
3043
3059
|
body: schemas["SiweCompleteRequest"],
|
|
3060
|
+
headers?: HeadersInit,
|
|
3044
3061
|
): Promise<schemas["SiweCompleteResponse"]> {
|
|
3045
3062
|
const o = op("/v0/org/{org_id}/oidc/siwe", "patch");
|
|
3046
3063
|
return await retryOn5XX(() =>
|
|
@@ -3048,6 +3065,7 @@ export class ApiClient extends BaseClient {
|
|
|
3048
3065
|
baseUrl: env.SignerApiRoot,
|
|
3049
3066
|
params: { path: { org_id: orgId } },
|
|
3050
3067
|
body,
|
|
3068
|
+
headers,
|
|
3051
3069
|
}),
|
|
3052
3070
|
).then(assertOk);
|
|
3053
3071
|
}
|
|
@@ -3057,17 +3075,20 @@ export class ApiClient extends BaseClient {
|
|
|
3057
3075
|
*
|
|
3058
3076
|
* @param env The environment to log into
|
|
3059
3077
|
* @param body The login request
|
|
3078
|
+
* @param headers Optional headers to set
|
|
3060
3079
|
* @returns The challenge that must be answered (see {@link passkeyLoginComplete}) to log in.
|
|
3061
3080
|
*/
|
|
3062
3081
|
static async passkeyLoginInit(
|
|
3063
3082
|
env: EnvInterface,
|
|
3064
3083
|
body: LoginRequest,
|
|
3084
|
+
headers?: HeadersInit,
|
|
3065
3085
|
): Promise<PasskeyLoginChallenge> {
|
|
3066
3086
|
const o = op("/v0/passkey", "post");
|
|
3067
3087
|
const resp = await retryOn5XX(() =>
|
|
3068
3088
|
o({
|
|
3069
3089
|
baseUrl: env.SignerApiRoot,
|
|
3070
3090
|
body,
|
|
3091
|
+
headers,
|
|
3071
3092
|
}),
|
|
3072
3093
|
).then(assertOk);
|
|
3073
3094
|
return new PasskeyLoginChallenge(env, resp, body.purpose);
|
|
@@ -3079,18 +3100,21 @@ export class ApiClient extends BaseClient {
|
|
|
3079
3100
|
* @param env The environment to log into
|
|
3080
3101
|
* @param body The request body
|
|
3081
3102
|
* @param purpose Optional descriptive session purpose
|
|
3103
|
+
* @param headers Optional headers to set
|
|
3082
3104
|
* @returns The session data
|
|
3083
3105
|
*/
|
|
3084
3106
|
static async passkeyLoginComplete(
|
|
3085
3107
|
env: EnvInterface,
|
|
3086
3108
|
body: PasskeyAssertAnswer,
|
|
3087
3109
|
purpose?: string | null,
|
|
3110
|
+
headers?: HeadersInit,
|
|
3088
3111
|
): Promise<SessionData> {
|
|
3089
3112
|
const o = op("/v0/passkey", "patch");
|
|
3090
3113
|
const resp = await retryOn5XX(() =>
|
|
3091
3114
|
o({
|
|
3092
3115
|
baseUrl: env.SignerApiRoot,
|
|
3093
3116
|
body,
|
|
3117
|
+
headers,
|
|
3094
3118
|
}),
|
|
3095
3119
|
).then(assertOk);
|
|
3096
3120
|
return {
|
|
@@ -3112,11 +3136,13 @@ export class ApiClient extends BaseClient {
|
|
|
3112
3136
|
* @param env The environment to log into
|
|
3113
3137
|
* @param orgId The id of the organization
|
|
3114
3138
|
* @param body The request body
|
|
3139
|
+
* @param headers Optional headers to set
|
|
3115
3140
|
*/
|
|
3116
3141
|
static async idpAcceptInvite(
|
|
3117
3142
|
env: EnvInterface,
|
|
3118
3143
|
orgId: string,
|
|
3119
3144
|
body: InvitationAcceptRequest,
|
|
3145
|
+
headers?: HeadersInit,
|
|
3120
3146
|
): Promise<void> {
|
|
3121
3147
|
const o = op("/v0/org/{org_id}/invitation/accept", "post");
|
|
3122
3148
|
await retryOn5XX(() =>
|
|
@@ -3124,6 +3150,7 @@ export class ApiClient extends BaseClient {
|
|
|
3124
3150
|
baseUrl: env.SignerApiRoot,
|
|
3125
3151
|
params: { path: { org_id: orgId } },
|
|
3126
3152
|
body,
|
|
3153
|
+
headers,
|
|
3127
3154
|
}),
|
|
3128
3155
|
).then(assertOk);
|
|
3129
3156
|
}
|
|
@@ -3134,6 +3161,7 @@ export class ApiClient extends BaseClient {
|
|
|
3134
3161
|
* @param env The environment to log into
|
|
3135
3162
|
* @param orgId The id of the organization
|
|
3136
3163
|
* @param body The request body
|
|
3164
|
+
* @param headers Optional headers to set
|
|
3137
3165
|
* @returns Returns an OIDC token which can be used
|
|
3138
3166
|
* to log in via OIDC (see {@link oidcSessionCreate}).
|
|
3139
3167
|
*/
|
|
@@ -3141,6 +3169,7 @@ export class ApiClient extends BaseClient {
|
|
|
3141
3169
|
env: EnvInterface,
|
|
3142
3170
|
orgId: string,
|
|
3143
3171
|
body: AuthenticationRequest,
|
|
3172
|
+
headers?: HeadersInit,
|
|
3144
3173
|
): Promise<AuthenticationResponse> {
|
|
3145
3174
|
const o = op("/v0/org/{org_id}/idp/authenticate", "post");
|
|
3146
3175
|
return retryOn5XX(() =>
|
|
@@ -3148,6 +3177,7 @@ export class ApiClient extends BaseClient {
|
|
|
3148
3177
|
baseUrl: env.SignerApiRoot,
|
|
3149
3178
|
params: { path: { org_id: orgId } },
|
|
3150
3179
|
body,
|
|
3180
|
+
headers,
|
|
3151
3181
|
}),
|
|
3152
3182
|
).then(assertOk);
|
|
3153
3183
|
}
|
|
@@ -3158,12 +3188,14 @@ export class ApiClient extends BaseClient {
|
|
|
3158
3188
|
* @param env The environment to log into
|
|
3159
3189
|
* @param orgId The id of the organization
|
|
3160
3190
|
* @param body The request body
|
|
3191
|
+
* @param headers Optional headers to set
|
|
3161
3192
|
* @returns Returns the partial token (`${header}.${claims}.`) while the signature is sent via email.
|
|
3162
3193
|
*/
|
|
3163
3194
|
static async idpPasswordResetRequest(
|
|
3164
3195
|
env: EnvInterface,
|
|
3165
3196
|
orgId: string,
|
|
3166
3197
|
body: PasswordResetRequest,
|
|
3198
|
+
headers?: HeadersInit,
|
|
3167
3199
|
): Promise<EmailOtpResponse> {
|
|
3168
3200
|
const o = op("/v0/org/{org_id}/idp/password_reset", "post");
|
|
3169
3201
|
return retryOn5XX(() =>
|
|
@@ -3171,6 +3203,7 @@ export class ApiClient extends BaseClient {
|
|
|
3171
3203
|
baseUrl: env.SignerApiRoot,
|
|
3172
3204
|
params: { path: { org_id: orgId } },
|
|
3173
3205
|
body,
|
|
3206
|
+
headers,
|
|
3174
3207
|
}),
|
|
3175
3208
|
).then(assertOk);
|
|
3176
3209
|
}
|
|
@@ -3183,6 +3216,7 @@ export class ApiClient extends BaseClient {
|
|
|
3183
3216
|
* @param partialToken The partial token returned by {@link passwordResetRequest}
|
|
3184
3217
|
* @param signature The one-time code (signature in this case) sent via email
|
|
3185
3218
|
* @param newPassword The new password
|
|
3219
|
+
* @param headers Optional headers to set
|
|
3186
3220
|
*/
|
|
3187
3221
|
static async idpPasswordResetConfirm(
|
|
3188
3222
|
env: EnvInterface,
|
|
@@ -3190,6 +3224,7 @@ export class ApiClient extends BaseClient {
|
|
|
3190
3224
|
partialToken: string,
|
|
3191
3225
|
signature: string,
|
|
3192
3226
|
newPassword: string,
|
|
3227
|
+
headers?: HeadersInit,
|
|
3193
3228
|
): Promise<void> {
|
|
3194
3229
|
const o = op("/v0/org/{org_id}/idp/password_reset", "patch");
|
|
3195
3230
|
await retryOn5XX(() =>
|
|
@@ -3200,6 +3235,7 @@ export class ApiClient extends BaseClient {
|
|
|
3200
3235
|
token: `${partialToken}${signature}`,
|
|
3201
3236
|
new_password: newPassword,
|
|
3202
3237
|
},
|
|
3238
|
+
headers,
|
|
3203
3239
|
}),
|
|
3204
3240
|
).then(assertOk);
|
|
3205
3241
|
}
|
|
@@ -3210,21 +3246,21 @@ export class ApiClient extends BaseClient {
|
|
|
3210
3246
|
* @param env The environment to log into
|
|
3211
3247
|
* @param orgId The org id in which to generate proof
|
|
3212
3248
|
* @param token The oidc token
|
|
3249
|
+
* @param headers Optional headers to set
|
|
3213
3250
|
* @returns Proof of authentication
|
|
3214
3251
|
*/
|
|
3215
3252
|
static async identityProveOidc(
|
|
3216
3253
|
env: EnvInterface,
|
|
3217
3254
|
orgId: string,
|
|
3218
3255
|
token: string,
|
|
3256
|
+
headers?: HeadersInit,
|
|
3219
3257
|
): Promise<IdentityProof> {
|
|
3220
3258
|
const o = op("/v0/org/{org_id}/identity/prove/oidc", "post");
|
|
3221
3259
|
return retryOn5XX(() =>
|
|
3222
3260
|
o({
|
|
3223
3261
|
baseUrl: env.SignerApiRoot,
|
|
3224
3262
|
params: { path: { org_id: orgId } },
|
|
3225
|
-
headers:
|
|
3226
|
-
Authorization: token,
|
|
3227
|
-
},
|
|
3263
|
+
headers: mergeHeaders(headers, authHeader(token)),
|
|
3228
3264
|
}),
|
|
3229
3265
|
).then(assertOk);
|
|
3230
3266
|
}
|
|
@@ -3234,16 +3270,19 @@ export class ApiClient extends BaseClient {
|
|
|
3234
3270
|
*
|
|
3235
3271
|
* @param env The environment to log into
|
|
3236
3272
|
* @param token The oidc token identifying the user
|
|
3273
|
+
* @param headers Optional headers to set
|
|
3237
3274
|
* @returns The organization the user belongs to
|
|
3238
3275
|
*/
|
|
3239
|
-
static async userOrgs(
|
|
3276
|
+
static async userOrgs(
|
|
3277
|
+
env: EnvInterface,
|
|
3278
|
+
token: string,
|
|
3279
|
+
headers?: HeadersInit,
|
|
3280
|
+
): Promise<UserOrgsResponse> {
|
|
3240
3281
|
const o = op("/v0/user/orgs", "get");
|
|
3241
3282
|
return retryOn5XX(() =>
|
|
3242
3283
|
o({
|
|
3243
3284
|
baseUrl: env.SignerApiRoot,
|
|
3244
|
-
headers:
|
|
3245
|
-
Authorization: token,
|
|
3246
|
-
},
|
|
3285
|
+
headers: mergeHeaders(headers, authHeader(token)),
|
|
3247
3286
|
}),
|
|
3248
3287
|
).then(assertOk);
|
|
3249
3288
|
}
|