deso-protocol
Advanced tools
Comparing version 2.2.2 to 2.3.0
{ | ||
"name": "deso-protocol", | ||
"version": "2.2.2", | ||
"version": "2.3.0", | ||
"license": "MIT", | ||
@@ -5,0 +5,0 @@ "description": "Client side typescript/javascript SDK for building web3 applications for the DeSo blockchain.", |
@@ -116,3 +116,3 @@ import { AccessGroupEntryResponse, DecryptedMessageEntryResponse, NewMessageEntryResponse, SubmitTransactionResponse, type TransactionSpendingLimitResponse } from '../backend-types/index.js'; | ||
*/ | ||
login({ getFreeDeso }?: LoginOptions): Promise<IdentityDerivePayload>; | ||
login({ getFreeDeso, derivedKeyLogin, }?: LoginOptions): Promise<IdentityDerivePayload>; | ||
/** | ||
@@ -119,0 +119,0 @@ * @param ownerSeedHex This is the seed hex of the owner key. This must be provided by the app. |
@@ -160,3 +160,4 @@ import { AccessGroupLimitMapItem, AccessGroupMemberLimitMapItem, AssociationLimitMapItem, TransactionSpendingLimitResponse, TransactionType } from '../backend-types/index.js'; | ||
export interface LoginOptions { | ||
getFreeDeso: boolean; | ||
getFreeDeso?: boolean; | ||
derivedKeyLogin?: boolean; | ||
} | ||
@@ -163,0 +164,0 @@ export type PrimaryDerivedKeyInfo = IdentityDerivePayload & { |
@@ -73,2 +73,2 @@ export var NOTIFICATION_EVENTS; | ||
})(NOTIFICATION_EVENTS || (NOTIFICATION_EVENTS = {})); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/identity/types.ts"],"names":[],"mappings":"AAsQA,MAAM,CAAN,IAAY,mBAoFX;AApFD,WAAY,mBAAmB;IAC7B;;OAEG;IACH,8CAAuB,CAAA;IAEvB;;;;OAIG;IACH,kFAA2D,CAAA;IAE3D;;;;OAIG;IACH,8EAAuD,CAAA;IAEvD;;OAEG;IACH,gFAAyD,CAAA;IAEzD;;OAEG;IACH,8EAAuD,CAAA;IAEvD;;;OAGG;IACH,0EAAmD,CAAA;IAEnD;;OAEG;IACH,kDAA2B,CAAA;IAE3B;;;OAGG;IACH,8CAAuB,CAAA;IAEvB;;OAEG;IACH,oDAA6B,CAAA;IAE7B;;;OAGG;IACH,gDAAyB,CAAA;IAEzB;;OAEG;IACH,kEAA2C,CAAA;IAE3C;;;OAGG;IACH,8DAAuC,CAAA;IAEvC;;OAEG;IACH,8EAAuD,CAAA;IAEvD;;;OAGG;IACH,0EAAmD,CAAA;IAEnD;;OAEG;IACH,gEAAyC,CAAA;AAC3C,CAAC,EApFW,mBAAmB,KAAnB,mBAAmB,QAoF9B","sourcesContent":["import {\n  AccessGroupLimitMapItem,\n  AccessGroupMemberLimitMapItem,\n  AssociationLimitMapItem,\n  TransactionSpendingLimitResponse,\n  TransactionType,\n} from '../backend-types/index.js';\nexport type Network = 'mainnet' | 'testnet';\n\nexport interface IdentityResponse {\n  service: 'identity';\n  method: 'derive' | 'login' | 'initialize';\n  payload?: any;\n  id?: string;\n}\n\nexport interface IdentityDerivePayload {\n  derivedSeedHex?: string;\n  derivedPublicKeyBase58Check: string;\n  publicKeyBase58Check: string;\n  btcDepositAddress: string;\n  ethDepositAddress: string;\n  expirationBlock: number;\n  network: Network;\n  accessSignature: string;\n  jwt: string;\n  derivedJwt: string;\n  messagingPublicKeyBase58Check: string;\n  messagingPrivateKey: string;\n  messagingKeyName: string;\n  messagingKeySignature: string;\n  transactionSpendingLimitHex: string;\n  signedUp: boolean;\n  publicKeyAdded?: string;\n}\n\nexport interface TransactionSpendingLimitResponseOptions {\n  GlobalDESOLimit?: number;\n  TransactionCountLimitMap?: Partial<\n    Record<TransactionType, number | 'UNLIMITED'>\n  >;\n  CreatorCoinOperationLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  DAOCoinOperationLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  NFTOperationLimitMap?: {\n    [key: string]: { [key: number]: { [key: string]: number | 'UNLIMITED' } };\n  };\n  DAOCoinLimitOrderLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  AssociationLimitMap?: (Omit<AssociationLimitMapItem, 'OpCount'> & {\n    OpCount: number | 'UNLIMITED';\n  })[];\n  AccessGroupLimitMap?: (Omit<AccessGroupLimitMapItem, 'OpCount'> & {\n    OpCount: number | 'UNLIMITED';\n  })[];\n  AccessGroupMemberLimitMap?: (Omit<\n    AccessGroupMemberLimitMapItem,\n    'OpCount'\n  > & { OpCount: number | 'UNLIMITED' })[];\n  IsUnlimited?: boolean;\n}\n\nexport type jwtAlgorithm = 'ES256K' | 'ES256';\nexport interface IdentityConfiguration {\n  /**\n   * The identity domain. Defaults to https://identity.deso.org\n   */\n  identityURI?: string;\n\n  /**\n   * The current network. If not provided, we will assume mainnet.\n   */\n  network?: Network;\n\n  /**\n   * The deso node used for any api calls (get balance, derived key authorization, etc)\n   */\n  nodeURI?: string;\n\n  /**\n   * Optional redirect URI. If provided, we do a hard redirect to the identity\n   * domain and pass data via query params back to the provided uri.\n   */\n  redirectURI?: string;\n\n  /**\n   * The default permissions and spending limits that will be presented to the user\n   * during login. If not provided, we will assume no permissions.\n   */\n  spendingLimitOptions?: TransactionSpendingLimitResponseOptions;\n\n  /**\n   * The name of the app used to authorize derived keys. Defaults to unknown.\n   */\n  appName?: string;\n\n  /**\n   * Since our keys are generated using the secp256k1 curve, the correct\n   * JWT algorithm header *should* be ES256K.\n   * See: https://www.rfc-editor.org/rfc/rfc8812.html#name-jose-algorithms-registratio\n   *\n   * HOWEVER, the backend jwt lib used by deso foundation -\n   * https://github.com/golang-jwt/jwt - (as well as many other jwt libraries)\n   * do not support ES256K. So instead, we default to the more widely supported ES256 algo,\n   * which can still work for verifying our signatures. But if a consumer of this lib is using a\n   * jwt lib that supports ES256K they can specify that here.\n   * See this github issue\n   * for more context: https://github.com/auth0/node-jsonwebtoken/issues/862\n   * If ES256K is ever supported by the backend jwt lib, we should change this.\n   */\n  jwtAlgorithm?: jwtAlgorithm;\n\n  /**\n   * An optional storage provider. If not provided, we will assume localStorage\n   * is available.\n   */\n  storageProvider?: StorageProvider;\n\n  /**\n   * An optional function that is provided the identity url that needs to be\n   * opened. This can be used to customize how the identity url is opened. For\n   * example, if you are using react native, you might want to use the Linking\n   * API to open the url in a system browser window.\n   * @example\n   * ```ts\n   * identityPresenter: async (url) => {\n   *   const result = await WebBrowser.openAuthSessionAsync(url);\n   *   if (result.type === 'success') {\n   *     identity.handleRedirectURI(result.url);\n   *   }\n   * },\n   * ```\n   */\n  identityPresenter?: (url: string) => void;\n\n  /**\n   * An optional flag that allows users to skip the \"get deso\" step during\n   * login. If set to true, the user will be able to login without having to\n   * get deso. Defaults to false.  NOTE: if you choose to set this to true, you\n   * should make sure that the user has a way to get deso after logging in.\n   * Otherwise, they will not be able to do anything with their account.\n   */\n  showSkip?: boolean;\n}\n\nexport interface APIProvider {\n  post: (url: string, data: any) => Promise<any>;\n  get: (url: string) => Promise<any>;\n}\n\nexport interface WindowProvider {\n  location: { search: string; pathname: string; href: string };\n  history: { replaceState: (state: any, title: string, url: string) => void };\n  localStorage: {\n    getItem: (key: string) => string | null;\n    setItem: (key: string, value: string) => void;\n    removeItem: (key: string) => void;\n  };\n  open: (\n    url: string,\n    title: string | undefined,\n    options: string\n  ) => Window | null;\n  addEventListener: (event: string, callback: (event: any) => void) => void;\n  removeEventListener: (event: string, callback: (event: any) => void) => void;\n}\n\nexport interface LoginOptions {\n  getFreeDeso: boolean;\n}\n\nexport type PrimaryDerivedKeyInfo = IdentityDerivePayload & {\n  transactionSpendingLimits: TransactionSpendingLimitResponse;\n  IsValid?: boolean;\n  derivedKeyRegistered?: boolean;\n};\n\nexport type StoredUser = {\n  publicKey: string;\n  primaryDerivedKey: PrimaryDerivedKeyInfo;\n};\n\nexport interface IdentityUser {\n  accessLevel: number;\n  accessLevelHmac: string;\n  btcDepositAddress: string;\n  encryptedSeedHex: string;\n  ethDepositAddress: string;\n  derivedPublicKeyBase58Check?: string;\n  hasExtraText: boolean;\n  network: string;\n  version: number;\n}\n\nexport interface IdentityLoginPayload {\n  users: Record<string, IdentityUser>;\n  publicKeyAdded: string;\n  phoneNumberSuccess: boolean;\n  signedUp: boolean;\n}\n\nexport interface IdentityState {\n  currentUser: StoredUser | null;\n  alternateUsers: Record<string, StoredUser> | null;\n}\n\nexport interface Deferred {\n  resolve: (args: any) => void;\n  reject: (args: any) => void;\n}\n\nexport interface KeyPair {\n  seedHex: string;\n  private: Uint8Array;\n  public: Uint8Array;\n}\n\nexport interface SubscriberNotification {\n  event: NOTIFICATION_EVENTS;\n  currentUser: StoredUser | null;\n  alternateUsers: Record<string, StoredUser> | null;\n}\n\nexport interface EtherscanTransactionsByAddressResponse {\n  status: string;\n  message: string;\n  result: EtherscanTransaction[];\n}\n\nexport interface EtherscanTransaction {\n  blockNumber: string;\n  timestamp: string;\n  hash: string;\n  nonce: string;\n  blockHash: string;\n  transactionIndex: string;\n  from: string;\n  to: string;\n  value: string;\n  gas: string;\n  gasPrice: string;\n  isError: string;\n  txreceipt_status: string;\n  input: string;\n  contractAddress: string;\n  cumulativeGasUsed: string;\n  gasUsed: string;\n  confirmations: string;\n  methodId: string;\n  functionName: string;\n}\n\nexport interface AccessGroupPrivateInfo {\n  AccessGroupPublicKeyBase58Check: string;\n  AccessGroupPrivateKeyHex: string;\n  AccessGroupKeyName: string;\n}\n\nexport enum NOTIFICATION_EVENTS {\n  /**\n   * This event is fired when the consuming app initially subscribes to identity.\n   */\n  SUBSCRIBE = 'SUBSCRIBE',\n\n  /**\n   * This is an intermediate event fired AFTER the user completes an identity flow\n   * that requires a derived key authorization. This event is fired BEFORE the\n   * request to authorize the derived key is made.\n   */\n  AUTHORIZE_DERIVED_KEY_START = 'AUTHORIZE_DERIVED_KEY_START',\n\n  /**\n   * This is an intermediate event fired AFTER the user completes an identity\n   * flow that requires a derived key authorization. This event is fired AFTER\n   * the request to authorize the derived key is made.\n   */\n  AUTHORIZE_DERIVED_KEY_END = 'AUTHORIZE_DERIVED_KEY_END',\n\n  /**\n   * This event is fired if the request to authorize a derived key fails.\n   */\n  AUTHORIZE_DERIVED_KEY_FAIL = 'AUTHORIZE_DERIVED_KEY_FAIL',\n\n  /**\n   * This event is fired when the user opens the permissions approval popup.\n   */\n  REQUEST_PERMISSIONS_START = 'REQUEST_PERMISSIONS_START',\n\n  /**\n   * This event is fired when the user completes approving permissions, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  REQUEST_PERMISSIONS_END = 'REQUEST_PERMISSIONS_END',\n\n  /**\n   * This event is fired when the user opens the login popup.\n   */\n  LOGIN_START = 'LOGIN_START',\n\n  /**\n   * This event is fired when the user completes logging in, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  LOGIN_END = 'LOGIN_END',\n\n  /**\n   * This event is fired when the user opens the logout popup.\n   */\n  LOGOUT_START = 'LOGOUT_START',\n\n  /**\n   * This event is fired when the user completes logging out, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  LOGOUT_END = 'LOGOUT_END',\n\n  /**\n   * This event is fired when the user opens the get deso popup.\n   */\n  GET_FREE_DESO_START = 'GET_FREE_DESO_START',\n\n  /**\n   * This event is fired when the user completes the get deso flow, and comes\n   * AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  GET_FREE_DESO_END = 'GET_FREE_DESO_END',\n\n  /**\n   * This event is fired when the user opens the verify phone number popup.\n   */\n  VERIFY_PHONE_NUMBER_START = 'VERIFY_PHONE_NUMBER_START',\n\n  /**\n   * This event is fired when the user completes the verify phone number flow,\n   * and comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  VERIFY_PHONE_NUMBER_END = 'VERIFY_PHONE_NUMBER_END',\n\n  /**\n   * This event is fired when the consuming app switches the active user.\n   */\n  CHANGE_ACTIVE_USER = 'CHANGE_ACTIVE_USER',\n}\n\nexport interface AsyncStorage {\n  getItem: (key: string) => Promise<string | null>;\n  setItem: (key: string, value: string) => Promise<void>;\n  removeItem: (key: string) => Promise<void>;\n  clear: () => Promise<void>;\n}\n\nexport type StorageProvider = Storage | AsyncStorage;\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/identity/types.ts"],"names":[],"mappings":"AAuQA,MAAM,CAAN,IAAY,mBAoFX;AApFD,WAAY,mBAAmB;IAC7B;;OAEG;IACH,8CAAuB,CAAA;IAEvB;;;;OAIG;IACH,kFAA2D,CAAA;IAE3D;;;;OAIG;IACH,8EAAuD,CAAA;IAEvD;;OAEG;IACH,gFAAyD,CAAA;IAEzD;;OAEG;IACH,8EAAuD,CAAA;IAEvD;;;OAGG;IACH,0EAAmD,CAAA;IAEnD;;OAEG;IACH,kDAA2B,CAAA;IAE3B;;;OAGG;IACH,8CAAuB,CAAA;IAEvB;;OAEG;IACH,oDAA6B,CAAA;IAE7B;;;OAGG;IACH,gDAAyB,CAAA;IAEzB;;OAEG;IACH,kEAA2C,CAAA;IAE3C;;;OAGG;IACH,8DAAuC,CAAA;IAEvC;;OAEG;IACH,8EAAuD,CAAA;IAEvD;;;OAGG;IACH,0EAAmD,CAAA;IAEnD;;OAEG;IACH,gEAAyC,CAAA;AAC3C,CAAC,EApFW,mBAAmB,KAAnB,mBAAmB,QAoF9B","sourcesContent":["import {\n  AccessGroupLimitMapItem,\n  AccessGroupMemberLimitMapItem,\n  AssociationLimitMapItem,\n  TransactionSpendingLimitResponse,\n  TransactionType,\n} from '../backend-types/index.js';\nexport type Network = 'mainnet' | 'testnet';\n\nexport interface IdentityResponse {\n  service: 'identity';\n  method: 'derive' | 'login' | 'initialize';\n  payload?: any;\n  id?: string;\n}\n\nexport interface IdentityDerivePayload {\n  derivedSeedHex?: string;\n  derivedPublicKeyBase58Check: string;\n  publicKeyBase58Check: string;\n  btcDepositAddress: string;\n  ethDepositAddress: string;\n  expirationBlock: number;\n  network: Network;\n  accessSignature: string;\n  jwt: string;\n  derivedJwt: string;\n  messagingPublicKeyBase58Check: string;\n  messagingPrivateKey: string;\n  messagingKeyName: string;\n  messagingKeySignature: string;\n  transactionSpendingLimitHex: string;\n  signedUp: boolean;\n  publicKeyAdded?: string;\n}\n\nexport interface TransactionSpendingLimitResponseOptions {\n  GlobalDESOLimit?: number;\n  TransactionCountLimitMap?: Partial<\n    Record<TransactionType, number | 'UNLIMITED'>\n  >;\n  CreatorCoinOperationLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  DAOCoinOperationLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  NFTOperationLimitMap?: {\n    [key: string]: { [key: number]: { [key: string]: number | 'UNLIMITED' } };\n  };\n  DAOCoinLimitOrderLimitMap?: {\n    [key: string]: { [key: string]: number | 'UNLIMITED' };\n  };\n  AssociationLimitMap?: (Omit<AssociationLimitMapItem, 'OpCount'> & {\n    OpCount: number | 'UNLIMITED';\n  })[];\n  AccessGroupLimitMap?: (Omit<AccessGroupLimitMapItem, 'OpCount'> & {\n    OpCount: number | 'UNLIMITED';\n  })[];\n  AccessGroupMemberLimitMap?: (Omit<\n    AccessGroupMemberLimitMapItem,\n    'OpCount'\n  > & { OpCount: number | 'UNLIMITED' })[];\n  IsUnlimited?: boolean;\n}\n\nexport type jwtAlgorithm = 'ES256K' | 'ES256';\nexport interface IdentityConfiguration {\n  /**\n   * The identity domain. Defaults to https://identity.deso.org\n   */\n  identityURI?: string;\n\n  /**\n   * The current network. If not provided, we will assume mainnet.\n   */\n  network?: Network;\n\n  /**\n   * The deso node used for any api calls (get balance, derived key authorization, etc)\n   */\n  nodeURI?: string;\n\n  /**\n   * Optional redirect URI. If provided, we do a hard redirect to the identity\n   * domain and pass data via query params back to the provided uri.\n   */\n  redirectURI?: string;\n\n  /**\n   * The default permissions and spending limits that will be presented to the user\n   * during login. If not provided, we will assume no permissions.\n   */\n  spendingLimitOptions?: TransactionSpendingLimitResponseOptions;\n\n  /**\n   * The name of the app used to authorize derived keys. Defaults to unknown.\n   */\n  appName?: string;\n\n  /**\n   * Since our keys are generated using the secp256k1 curve, the correct\n   * JWT algorithm header *should* be ES256K.\n   * See: https://www.rfc-editor.org/rfc/rfc8812.html#name-jose-algorithms-registratio\n   *\n   * HOWEVER, the backend jwt lib used by deso foundation -\n   * https://github.com/golang-jwt/jwt - (as well as many other jwt libraries)\n   * do not support ES256K. So instead, we default to the more widely supported ES256 algo,\n   * which can still work for verifying our signatures. But if a consumer of this lib is using a\n   * jwt lib that supports ES256K they can specify that here.\n   * See this github issue\n   * for more context: https://github.com/auth0/node-jsonwebtoken/issues/862\n   * If ES256K is ever supported by the backend jwt lib, we should change this.\n   */\n  jwtAlgorithm?: jwtAlgorithm;\n\n  /**\n   * An optional storage provider. If not provided, we will assume localStorage\n   * is available.\n   */\n  storageProvider?: StorageProvider;\n\n  /**\n   * An optional function that is provided the identity url that needs to be\n   * opened. This can be used to customize how the identity url is opened. For\n   * example, if you are using react native, you might want to use the Linking\n   * API to open the url in a system browser window.\n   * @example\n   * ```ts\n   * identityPresenter: async (url) => {\n   *   const result = await WebBrowser.openAuthSessionAsync(url);\n   *   if (result.type === 'success') {\n   *     identity.handleRedirectURI(result.url);\n   *   }\n   * },\n   * ```\n   */\n  identityPresenter?: (url: string) => void;\n\n  /**\n   * An optional flag that allows users to skip the \"get deso\" step during\n   * login. If set to true, the user will be able to login without having to\n   * get deso. Defaults to false.  NOTE: if you choose to set this to true, you\n   * should make sure that the user has a way to get deso after logging in.\n   * Otherwise, they will not be able to do anything with their account.\n   */\n  showSkip?: boolean;\n}\n\nexport interface APIProvider {\n  post: (url: string, data: any) => Promise<any>;\n  get: (url: string) => Promise<any>;\n}\n\nexport interface WindowProvider {\n  location: { search: string; pathname: string; href: string };\n  history: { replaceState: (state: any, title: string, url: string) => void };\n  localStorage: {\n    getItem: (key: string) => string | null;\n    setItem: (key: string, value: string) => void;\n    removeItem: (key: string) => void;\n  };\n  open: (\n    url: string,\n    title: string | undefined,\n    options: string\n  ) => Window | null;\n  addEventListener: (event: string, callback: (event: any) => void) => void;\n  removeEventListener: (event: string, callback: (event: any) => void) => void;\n}\n\nexport interface LoginOptions {\n  getFreeDeso?: boolean;\n  derivedKeyLogin?: boolean;\n}\n\nexport type PrimaryDerivedKeyInfo = IdentityDerivePayload & {\n  transactionSpendingLimits: TransactionSpendingLimitResponse;\n  IsValid?: boolean;\n  derivedKeyRegistered?: boolean;\n};\n\nexport type StoredUser = {\n  publicKey: string;\n  primaryDerivedKey: PrimaryDerivedKeyInfo;\n};\n\nexport interface IdentityUser {\n  accessLevel: number;\n  accessLevelHmac: string;\n  btcDepositAddress: string;\n  encryptedSeedHex: string;\n  ethDepositAddress: string;\n  derivedPublicKeyBase58Check?: string;\n  hasExtraText: boolean;\n  network: string;\n  version: number;\n}\n\nexport interface IdentityLoginPayload {\n  users: Record<string, IdentityUser>;\n  publicKeyAdded: string;\n  phoneNumberSuccess: boolean;\n  signedUp: boolean;\n}\n\nexport interface IdentityState {\n  currentUser: StoredUser | null;\n  alternateUsers: Record<string, StoredUser> | null;\n}\n\nexport interface Deferred {\n  resolve: (args: any) => void;\n  reject: (args: any) => void;\n}\n\nexport interface KeyPair {\n  seedHex: string;\n  private: Uint8Array;\n  public: Uint8Array;\n}\n\nexport interface SubscriberNotification {\n  event: NOTIFICATION_EVENTS;\n  currentUser: StoredUser | null;\n  alternateUsers: Record<string, StoredUser> | null;\n}\n\nexport interface EtherscanTransactionsByAddressResponse {\n  status: string;\n  message: string;\n  result: EtherscanTransaction[];\n}\n\nexport interface EtherscanTransaction {\n  blockNumber: string;\n  timestamp: string;\n  hash: string;\n  nonce: string;\n  blockHash: string;\n  transactionIndex: string;\n  from: string;\n  to: string;\n  value: string;\n  gas: string;\n  gasPrice: string;\n  isError: string;\n  txreceipt_status: string;\n  input: string;\n  contractAddress: string;\n  cumulativeGasUsed: string;\n  gasUsed: string;\n  confirmations: string;\n  methodId: string;\n  functionName: string;\n}\n\nexport interface AccessGroupPrivateInfo {\n  AccessGroupPublicKeyBase58Check: string;\n  AccessGroupPrivateKeyHex: string;\n  AccessGroupKeyName: string;\n}\n\nexport enum NOTIFICATION_EVENTS {\n  /**\n   * This event is fired when the consuming app initially subscribes to identity.\n   */\n  SUBSCRIBE = 'SUBSCRIBE',\n\n  /**\n   * This is an intermediate event fired AFTER the user completes an identity flow\n   * that requires a derived key authorization. This event is fired BEFORE the\n   * request to authorize the derived key is made.\n   */\n  AUTHORIZE_DERIVED_KEY_START = 'AUTHORIZE_DERIVED_KEY_START',\n\n  /**\n   * This is an intermediate event fired AFTER the user completes an identity\n   * flow that requires a derived key authorization. This event is fired AFTER\n   * the request to authorize the derived key is made.\n   */\n  AUTHORIZE_DERIVED_KEY_END = 'AUTHORIZE_DERIVED_KEY_END',\n\n  /**\n   * This event is fired if the request to authorize a derived key fails.\n   */\n  AUTHORIZE_DERIVED_KEY_FAIL = 'AUTHORIZE_DERIVED_KEY_FAIL',\n\n  /**\n   * This event is fired when the user opens the permissions approval popup.\n   */\n  REQUEST_PERMISSIONS_START = 'REQUEST_PERMISSIONS_START',\n\n  /**\n   * This event is fired when the user completes approving permissions, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  REQUEST_PERMISSIONS_END = 'REQUEST_PERMISSIONS_END',\n\n  /**\n   * This event is fired when the user opens the login popup.\n   */\n  LOGIN_START = 'LOGIN_START',\n\n  /**\n   * This event is fired when the user completes logging in, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  LOGIN_END = 'LOGIN_END',\n\n  /**\n   * This event is fired when the user opens the logout popup.\n   */\n  LOGOUT_START = 'LOGOUT_START',\n\n  /**\n   * This event is fired when the user completes logging out, and\n   * comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  LOGOUT_END = 'LOGOUT_END',\n\n  /**\n   * This event is fired when the user opens the get deso popup.\n   */\n  GET_FREE_DESO_START = 'GET_FREE_DESO_START',\n\n  /**\n   * This event is fired when the user completes the get deso flow, and comes\n   * AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  GET_FREE_DESO_END = 'GET_FREE_DESO_END',\n\n  /**\n   * This event is fired when the user opens the verify phone number popup.\n   */\n  VERIFY_PHONE_NUMBER_START = 'VERIFY_PHONE_NUMBER_START',\n\n  /**\n   * This event is fired when the user completes the verify phone number flow,\n   * and comes AFTER the intermediate AUTHORIZE_DERIVED_KEY events.\n   */\n  VERIFY_PHONE_NUMBER_END = 'VERIFY_PHONE_NUMBER_END',\n\n  /**\n   * This event is fired when the consuming app switches the active user.\n   */\n  CHANGE_ACTIVE_USER = 'CHANGE_ACTIVE_USER',\n}\n\nexport interface AsyncStorage {\n  getItem: (key: string) => Promise<string | null>;\n  setItem: (key: string, value: string) => Promise<void>;\n  removeItem: (key: string) => Promise<void>;\n  clear: () => Promise<void>;\n}\n\nexport type StorageProvider = Storage | AsyncStorage;\n"]} |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
1522280
14053