@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.
@@ -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.237",
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"
@@ -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;
@@ -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 { BaseClient, type ClientConfig, signerSessionFromSessionInfo } from "./base_client";
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) => r.entries,
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 (headers?: HeadersInit) => {
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(env: EnvInterface, token: string): Promise<UserOrgsResponse> {
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
  }