@lifeready/core 5.0.3 → 5.0.5

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.
@@ -135,4 +135,4 @@ export var PlanStateField;
135
135
  PlanStateField["CANCELLED"] = "CANCELLED";
136
136
  PlanStateField["EXPIRED"] = "EXPIRED";
137
137
  })(PlanStateField || (PlanStateField = {}));
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.types.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/types/lr-graphql.types.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Connection,\n  DateTime,\n  GenericScalar,\n  ID,\n  JSONObject,\n  JSONString,\n  LrEmail,\n  Node,\n  TimeStamped,\n} from './graphql.types';\n\nexport function mapEdges<T>(connection: Connection<T>) {\n  return connection.edges.map((edge) => edge.node);\n}\n\nexport interface FeaturesNode {\n  myVault?: string[];\n  tpVault?: string[];\n  shareVault?: string[];\n}\n\nexport enum UserDeleteState {\n  REQUESTED = 'REQUESTED',\n}\n\nexport interface UserDeleteNode extends Node, TimeStamped {\n  state?: UserDeleteState;\n}\n\nexport enum PlanState {\n  ENABLED = 'ENABLED',\n  DISABLED = 'DISABLED',\n}\n\nexport interface PlanNode extends Node {\n  name?: string;\n  data?: JSONString;\n  state?: PlanState;\n}\n\nexport interface UserPlanStripeNode extends Node, TimeStamped {\n  subscriptionId?: string;\n  priceId?: string;\n}\n\nexport interface UserPlanNode extends Node, TimeStamped {\n  user?: UserNode;\n  plan?: PlanNode;\n  periodEnd?: DateTime;\n  stripe?: UserPlanStripeNode;\n  issuer?: UserNode;\n}\n\nexport interface UserStripeNode extends Node, TimeStamped {\n  customer?: GenericScalar;\n}\n\nexport interface PassKeyNode extends Node, TimeStamped {\n  passKeyParams?: GenericScalar;\n  passIdpParams?: GenericScalar;\n  wrappedPassIdpVerifierPrk?: GenericScalar;\n}\n\nexport interface CurrentUserKeyNode extends Node, TimeStamped {\n  passKeys?: PassKeyNode[];\n  passKey?: PassKeyNode;\n  rootKey?: KeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sigPxk?: KeyNode;\n}\n\n// ------------------------------------------------------\n// Node types\n// ------------------------------------------------------\nexport interface UserNode extends Node {\n  username?: string;\n  contactCards?: Connection<ContactCardNode>;\n  currentUserKey?: CurrentUserKeyNode;\n  ownedContactCard?: SharedContactCardNode;\n  receivedContactCard?: SharedContactCardNode;\n  isCurrentUser?: boolean;\n  haveTp?: boolean;\n  stripe?: UserStripeNode;\n  userPlans?: Connection<UserPlanNode>;\n  userDelete?: UserDeleteNode;\n  features?: FeaturesNode;\n  featureState?: UserFeatureState;\n  sessionEncryptionKey?: string;\n  plans?: IssuedPlanNode[];\n  paymentMethods?: PaymentMethodNode[];\n  billingHistory?: BillingField[];\n  availablePlans?: AvailablePlanField[];\n}\n\nexport interface UserFeatureState extends TimeStamped {\n  notificationsLastViewed?: DateTime;\n}\n\nexport interface ServerTime {\n  timestamp?: string;\n}\n\nexport interface KeyNode extends Node, TimeStamped {\n  pbk?: string;\n}\n\nexport interface ContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  publicDataSig?: string;\n  publicSearchableSig?: string;\n  sigPxk?: KeyNode;\n  defaultFrom?: DateTime;\n  publicData?: string;\n  publicSearchable?: string;\n  cipherData?: string;\n  cipherDataClearJson?: JSONObject;\n  key?: KeyNode;\n  plainData?: string;\n  plainDataSig?: string;\n}\n\nexport interface AccessControlledResource {\n  accessRole?: AccessRoleChoice;\n  permissions?: PermissionChoice[];\n  tpAccessRoles?: AccessRole[];\n  confidentiality?: ConfidentialResource;\n}\n\nexport interface DirectoryNode\n  extends Node,\n    TimeStamped,\n    AccessControlledResource {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  archived?: boolean;\n  keyId?: ID;\n  childFileLinks?: Connection<FileLinkNode>;\n  childDirectoryLinks?: Connection<DirectoryLinkNode>;\n  parentDirectoryLinks?: Connection<DirectoryLinkNode>;\n  nParentDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildFileLinks?: FileLinkNodeLrNList;\n  descendants?: Descendants;\n  lock?: LockField;\n  lockVersion?: string;\n}\n\nexport interface FileNode extends Node, TimeStamped, AccessControlledResource {\n  currentVersion?: FileVersionNode;\n  archived?: boolean;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n  parentDirectoryLinks?: Connection<FileLinkNode>;\n  nParentDirectoryLinks?: FileLinkNodeLrNList;\n  lock?: LockField;\n  lockVersion?: string;\n}\n\nexport interface DirectoryLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childDirectory?: DirectoryNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface FileLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childFile?: FileNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface DirectoryLinkNodeLrNList {\n  list?: DirectoryLinkNode[];\n}\n\nexport interface FileLinkNodeLrNList {\n  list?: FileLinkNode[];\n}\n\nexport interface Descendants {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n  directoriesCount?: number;\n  filesCount?: number;\n}\n\nexport enum AccessRoleChoice {\n  READER = 'READER',\n  WRITER = 'WRITER',\n  ADMIN = 'ADMIN',\n  DENY = 'DENY',\n  OWNER = 'OWNER',\n}\n\nexport enum AccessRoleMethodChoice {\n  INHERITED = 'INHERITED',\n  DIRECT = 'DIRECT',\n}\n\nexport enum PermissionChoice {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  DELETE = 'DELETE',\n  SHARE = 'SHARE',\n  ARCHIVE = 'ARCHIVE',\n  ACCESS_ARCHIVED = 'ACCESS_ARCHIVED',\n  UNARCHIVE = 'UNARCHIVE',\n  SET_CONFIDENTIAL = 'SET_CONFIDENTIAL',\n}\n\nexport interface ConfidentialResource {\n  isConfidential?: boolean;\n  method?: AccessRoleMethodChoice;\n}\n\nexport interface AccessRole {\n  issuer?: UserNode;\n  subject?: UserNode;\n  role?: AccessRoleChoice;\n  method?: AccessRoleMethodChoice;\n  inheritedFrom?: DirectoryNode;\n  tp?: TpNode;\n  isIssuer?: boolean;\n}\n\nexport enum FileOperationField {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  REVERT = 'REVERT',\n  DELETE = 'DELETE',\n}\n\nexport interface FileVersionNode extends Node, TimeStamped {\n  file?: FileNode;\n  state?: FileStateNode;\n  operation?: FileOperationField;\n  author?: UserNode;\n}\nexport interface FileStateNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  contentResource?: string;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n}\n\nexport enum KeyExchangeOtkState {\n  OTK_INITIATED = 'OTK_INITIATED',\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\n  OTK_COMPLETED = 'OTK_COMPLETED',\n}\n\n// These fields are not optional because they are not within the user's control to select in a gql query.\nexport interface ContactCardSharedCipherData {\n  // Shared read access between initiator and responder. But only the initiator has write access.\n  sharedCipherDataClearJson: JSONObject;\n}\n\n/**\n * The contents of the one-time key cipher\n * These fields are not optional because they are not within the user's control to select in a gql query.\n */\nexport interface OtKeyCipherClearJson2 {\n  // Used to confirm to the initiator that the responder has access to the one-time key.\n  nonce: string;\n  // Data sent from initiator to the responder\n  initiator: {\n    oneTimePbk: Record<string, JSONObject>; // one-time public encryption key the responder will use to send data back to the initiator\n    pbk: Record<string, JSONObject>; // public encryption key\n    sigPbk: Record<string, JSONObject>; // public signing key\n    message?: JSONObject;\n    contactCard?: ContactCardSharedCipherData;\n  };\n}\n\nexport interface KeyExchangeOtkNode extends Node, TimeStamped {\n  state?: KeyExchangeOtkState;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  initiatorSigPxk?: KeyNode;\n  responderSigPxk?: KeyNode;\n  initiatorOneTimePbkCipher?: string;\n  otKeyParams?: string;\n  otKeyCipher?: string;\n  otKeyCipherClearJson?: OtKeyCipherClearJson2;\n  responderPbkCipher?: string;\n}\n\nexport enum KeyExchangeState {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETED = 'COMPLETED',\n  DECLINED = 'DECLINED',\n  CANCELLED = 'CANCELLED',\n  DELETED = 'DELETED',\n}\n\nexport enum KeyExchangeMode {\n  OTK = 'OTK',\n}\n\nexport interface KeyExchangeNode extends Node, TimeStamped {\n  expiryTime?: DateTime;\n  token?: string;\n  tokenExpiryTime?: DateTime;\n  state?: KeyExchangeState;\n  mode?: KeyExchangeMode;\n  initiator?: UserNode;\n  responder?: UserNode;\n  initiatorRootKeyCipher?: string;\n  responderRootKeyCipher?: string;\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  createTp?: boolean;\n  otk?: KeyExchangeOtkNode;\n  isInitiator?: boolean;\n  isExpired?: boolean;\n  responderEmailAddress?: LrEmail;\n}\n\nexport interface SharedItems {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n}\n\nexport interface SharedContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherDataSig?: string;\n  sharedCipherDataSigPxk?: KeyNode;\n  ownerCipherData?: string;\n  ownerCipherDataClearJson?: JSONObject;\n  ownerKey?: KeyNode;\n  ownerPlainData?: string;\n  ownerPlainDataJson?: JSONObject;\n  ownerPlainDataSig?: string;\n  receiverCipherData?: string;\n  receiverCipherDataClearJson?: JSONObject;\n  receiverKey?: KeyNode;\n}\n\nexport interface UserSharedKeyNode extends Node, TimeStamped {\n  keyExchange?: KeyExchangeNode;\n  user?: UserNode;\n  userPrk?: KeyNode;\n  userSigPrk?: KeyNode;\n  other?: UserNode;\n  otherPbk?: KeyNode;\n  otherSigPbk?: KeyNode;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  mkPxk?: KeyNode;\n  mkReshareRequestCipher?: string;\n  mkReshareResponseCipher?: string;\n  mkReshareRequestCipherClearJson?: JSONObject;\n  mkReshareResponseCipherClearJson?: JSONObject;\n  mkReshareRequestSent?: boolean;\n  mkReshareResponseSent?: boolean;\n}\n\nexport interface CurrentUserSharedKeyNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  userSharedKey?: UserSharedKeyNode;\n}\n\nexport interface TpNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  currentUserSharedKey?: CurrentUserSharedKeyNode;\n  isCompleted?: boolean;\n  sharedKey?: KeyNode;\n  sharedContactCard?: SharedContactCardNode;\n  myContactCard?: SharedContactCardNode;\n  myItems?: SharedItems;\n  theirItems?: SharedItems;\n  myScenarios?: Connection<ScenarioNode>;\n  sharedScenarios?: Connection<SharedScenarioNode>;\n}\n\nexport enum TpAssemblyState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport interface TpPasswordResetApproval extends Node, TimeStamped {\n  approverEmail?: string;\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n}\n\nexport interface TpPasswordResetUserApprovalNode extends Node, TimeStamped {\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n  approverEmail?: string;\n}\n\nexport interface TpPasswordResetUserApprover {\n  name?: string;\n  email?: string;\n  state?: TpClaimApproverState;\n}\n\nexport interface TpPasswordResetUserSubAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  approvers?: TpPasswordResetUserApprover[];\n}\n\nexport interface TpPasswordResetUserAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblies?: TpPasswordResetUserSubAssembly[];\n}\n\nexport interface TpPasswordResetUserNode {\n  username?: string;\n  resetUsername?: string;\n  state?: TpClaimState;\n  passKey?: PassKeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sessionEncryptionKey?: string;\n  approvals?: TpPasswordResetUserApprovalNode[];\n  assemblyCipherData?: string;\n  wrappedAssemblyKeyVerifierPrk?: string;\n  assembly?: TpPasswordResetUserAssembly;\n  requestAgainAfter?: DateTime;\n}\n\nexport interface TpPasswordResetNode extends Node, TimeStamped {\n  assembly?: TpAssemblyNode;\n  request?: TpPasswordResetRequestNode;\n  applied?: boolean;\n}\n\nexport interface TpPasswordResetRequestNode extends Node, TimeStamped {\n  state?: TpClaimState;\n}\n\nexport interface TpAssemblyNode extends Node, TimeStamped {\n  id?: ID;\n  singleReject?: boolean;\n  quorum?: number;\n  canMeetQuorum?: boolean;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assemblyKey?: KeyNode;\n  assemblyCipherData?: string;\n  assemblyCipherDataClearJson?: JSONObject;\n  subAssemblies?: Connection<TpSubAssemblyNode>;\n}\n\nexport interface TpSubAssemblyNode extends Node, TimeStamped {\n  singleReject?: boolean;\n  quorum?: number;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: string;\n  approvers?: Connection<TpAssemblyApproverNode>;\n}\n\nexport interface TpAssemblyApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  tp?: TpNode;\n}\n\nexport interface SharedTpPasswordResetNode extends Node, TimeStamped {\n  assembly?: SharedTpAssemblyNode;\n  tp?: TpNode;\n  sharedRequest?: SharedTpPasswordResetRequestNode;\n}\n\nexport interface SharedTpAssemblyNode extends Node, TimeStamped {\n  asApprovers?: Connection<TpAssemblyAsApproverNode>;\n}\n\nexport interface TpAssemblyAsApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n}\n\nexport interface SharedTpPasswordResetRequestNode extends Node, TimeStamped {\n  claim?: SharedTpClaimNode;\n  pxk?: KeyNode;\n}\n\nexport interface SharedTpClaimNode extends Node, TimeStamped {\n  state?: TpClaimState;\n  asClaimApprovers?: Connection<SharedTpClaimApproverNode>;\n}\n\nexport interface SharedTpClaimApproverNode extends Node, TimeStamped {\n  state?: TpClaimApproverState;\n  sharedKey?: KeyNode;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  sharedCipherPartialAssemblyKey?: string;\n  sharedCipherPartialAssemblyKeyClearJson?: JSONObject;\n  receiverApprovals?: Connection<SharedTpClaimReceiverApprovalNode>;\n}\n\nexport interface SharedTpClaimReceiverApprovalNode extends Node, TimeStamped {\n  pxk?: KeyNode;\n}\n\nexport enum LockState {\n  UNLOCKED = 'UNLOCKED',\n  MUTEX_LOCKED = 'MUTEX_LOCKED',\n}\n\nexport enum ScenarioState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n}\n\nexport enum ClaimState {\n  CLAIMED = 'CLAIMED',\n  EXPIRED = 'EXPIRED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum ClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport enum ScenarioLastClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport interface ScenarioLatestClaim {\n  state?: ScenarioLastClaimState;\n  created?: DateTime;\n  claimAgainAfter?: DateTime;\n}\n\nexport interface ScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assembly?: TpAssemblyNode;\n  state?: ScenarioState;\n  claimants?: Connection<ScenarioClaimantNode>;\n  receivers?: Connection<ScenarioReceiverNode>;\n  claims?: Connection<ScenarioClaimNode>;\n  claim?: ScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface ScenarioClaimNode extends Node, TimeStamped {\n  claimant?: ScenarioClaimantNode;\n  state?: ClaimState;\n  scenario?: ScenarioNode;\n}\n\nexport interface ScenarioAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblyStates?: ScenarioSubAssemblyState[];\n}\n\nexport interface ScenarioSubAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  approverStates?: ScenarioAssemblyApproverState[];\n}\n\nexport interface ScenarioAssemblyApproverState {\n  state?: TpClaimApproverState;\n}\n\nexport interface ScenarioReceiverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  pbk?: KeyNode;\n  receiverDirectories?: Connection<ScenarioReceiverDirectoryNode>;\n  receiverFiles?: Connection<ScenarioReceiverFileNode>;\n  tp?: TpNode;\n}\n\nexport interface SharedScenarioReceiverNode extends Node, TimeStamped {\n  pbk?: KeyNode;\n}\n\nexport type ReceiverDirectoryAccessRole = AccessRoleChoice;\n\nexport interface ScenarioReceiverItemNode extends Node, TimeStamped {\n  receiver?: SharedScenarioReceiverNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  accessRole?: ReceiverDirectoryAccessRole;\n  wrappedItemKey?: string;\n  itemKey?: KeyNode;\n}\n\nexport interface ScenarioReceiverDirectoryNode\n  extends ScenarioReceiverItemNode {\n  directory?: DirectoryNode;\n}\n\nexport interface ScenarioReceiverFileNode extends ScenarioReceiverItemNode {\n  file?: FileNode;\n}\n\nexport interface ScenarioClaimantNode extends Node, TimeStamped {\n  tp?: TpNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n}\n\nexport interface SharedScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  state?: ScenarioState;\n  tp?: TpNode;\n  asClaimant?: ScenarioClaimantNode;\n  asReceiver?: ScenarioReceiverNode;\n  assembly?: SharedTpAssemblyNode;\n  sharedClaim?: SharedScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface SharedScenarioClaimNode extends Node, TimeStamped {\n  state?: ClaimState;\n  sharedScenario?: SharedScenarioNode;\n  isClaimant?: boolean;\n  asClaimReceiver?: SharedScenarioClaimReceiverNode;\n  claim?: SharedTpClaimNode;\n}\n\nexport interface SharedScenarioClaimApproverNode extends Node, TimeStamped {\n  receivers?: Connection<SharedScenarioReceiverNode>;\n  state?: ClaimApproverState;\n  approver?: TpAssemblyApproverNode;\n}\n\nexport interface SharedScenarioClaimReceiverNode extends Node, TimeStamped {\n  received?: DateTime;\n  approvals?: Connection<SharedScenarioClaimReceivedApprovalNode>;\n}\n\nexport interface SharedScenarioClaimReceivedApprovalNode\n  extends Node,\n    TimeStamped {\n  receiverCipher?: string;\n  receiverCipherPartialAssemblyKey?: string;\n  pxk?: KeyNode;\n}\n\nexport interface NotificationNode extends Node, TimeStamped {\n  plainData?: JSONString;\n  plainMeta?: JSONString;\n  timeRead?: DateTime;\n}\n\nexport interface NotificationManagementState extends Node, TimeStamped {\n  lastViewed?: DateTime;\n}\n\nexport enum LinkTypeField {\n  HARD = 'HARD',\n  SOFT = 'SOFT',\n}\n\nexport interface MessageNode extends Node, TimeStamped {\n  sender?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  senderSigPbk?: KeyNode;\n  plainMessage?: string;\n  plainMessageJson?: string;\n  signedCipherMessage?: string;\n  signedCipherMessageClearJson?: string;\n}\n\nexport interface LockField {\n  created?: DateTime;\n  modified?: DateTime;\n  expiryTime?: DateTime;\n  version?: string;\n  state?: LockState;\n}\n\nexport interface ServerConfig {\n  relayConnectionMaxLimit?: number;\n}\n\nexport interface AvailablePlanField {\n  issuerUid?: string;\n  planUid?: string;\n  name?: string;\n  description?: string;\n  priceOptions?: PriceOptionField[];\n  trial?: TrialPeriodField;\n}\n\nexport interface PriceOptionField {\n  priceId?: string;\n  name?: string;\n  description?: string;\n  amount?: number;\n  currency?: string;\n  intervalUnit?: string;\n  intervalCount?: number;\n}\n\nexport interface TrialPeriodField {\n  years?: number;\n  months?: number;\n  weeks?: number;\n  days?: number;\n}\n\nexport interface PaymentCaptureField {\n  stripeIntentId?: string;\n  stripeClientSecret?: string;\n}\n\nexport interface PaymentMethodNode extends Node, TimeStamped {\n  card?: PaymentCardField;\n  invoice?: PaymentInvoiceField;\n  isDefault?: boolean;\n}\n\nexport interface PaymentCardField {\n  brand?: string;\n  lastFourDigits?: string;\n  expiryYear?: number;\n  expiryMonth?: number;\n}\n\nexport interface PaymentInvoiceField {\n  email?: string;\n}\n\nexport interface PromotionalCodeField {\n  amountOff?: number;\n  currency?: string;\n  percentOff?: number;\n  name?: string;\n  duration?: string;\n  durationInMonths?: number;\n}\n\nexport interface PeriodField {\n  start?: DateTime;\n  end?: DateTime;\n}\n\nexport interface IssuedPlanNode extends Node, TimeStamped {\n  name?: string;\n  description?: string;\n  currentStates?: IssuedPlanStateNode[];\n  currentPeriod?: PeriodField;\n  currentPriceOption?: PriceOptionField;\n  upcomingInvoice?: BillingField;\n  alternativePriceOptions?: PriceOptionField[];\n}\n\nexport interface IssuedPlanStateNode extends Node, TimeStamped {\n  periodStart?: DateTime;\n  periodEnd?: DateTime;\n  state?: PlanStateField;\n}\n\nexport enum PlanStateField {\n  TRIALLING = 'TRIALLING',\n  ACTIVE = 'ACTIVE',\n  CANCELLED = 'CANCELLED',\n  EXPIRED = 'EXPIRED',\n}\n\nexport interface BillingField {\n  invoiceNumber?: string;\n  total?: number;\n  amountDue?: number;\n  currency?: string;\n  documentUrl?: string;\n  status?: string;\n  periodStart?: DateTime;\n  periodEnd?: DateTime;\n  finalisedAt?: DateTime;\n  paidAt?: DateTime;\n  paid?: boolean;\n  nextPaymentAttempt?: DateTime;\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lr-graphql.types.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/lib/api/types/lr-graphql.types.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Connection,\n  DateTime,\n  GenericScalar,\n  ID,\n  JSONObject,\n  JSONString,\n  LrEmail,\n  Node,\n  TimeStamped,\n} from './graphql.types';\n\nexport function mapEdges<T>(connection: Connection<T>) {\n  return connection.edges.map((edge) => edge.node);\n}\n\nexport interface FeaturesNode {\n  myVault?: string[];\n  tpVault?: string[];\n  shareVault?: string[];\n}\n\nexport enum UserDeleteState {\n  REQUESTED = 'REQUESTED',\n}\n\nexport interface UserDeleteNode extends Node, TimeStamped {\n  state?: UserDeleteState;\n}\n\nexport enum PlanState {\n  ENABLED = 'ENABLED',\n  DISABLED = 'DISABLED',\n}\n\nexport interface PlanNode extends Node {\n  name?: string;\n  data?: JSONString;\n  state?: PlanState;\n}\n\nexport interface UserPlanStripeNode extends Node, TimeStamped {\n  subscriptionId?: string;\n  priceId?: string;\n}\n\nexport interface UserPlanNode extends Node, TimeStamped {\n  user?: UserNode;\n  plan?: PlanNode;\n  periodEnd?: DateTime;\n  stripe?: UserPlanStripeNode;\n  issuer?: UserNode;\n}\n\nexport interface UserStripeNode extends Node, TimeStamped {\n  customer?: GenericScalar;\n}\n\nexport interface PassKeyNode extends Node, TimeStamped {\n  passKeyParams?: GenericScalar;\n  passIdpParams?: GenericScalar;\n  wrappedPassIdpVerifierPrk?: GenericScalar;\n}\n\nexport interface CurrentUserKeyNode extends Node, TimeStamped {\n  passKeys?: PassKeyNode[];\n  passKey?: PassKeyNode;\n  rootKey?: KeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sigPxk?: KeyNode;\n}\n\n// ------------------------------------------------------\n// Node types\n// ------------------------------------------------------\nexport interface UserNode extends Node {\n  username?: string;\n  contactCards?: Connection<ContactCardNode>;\n  currentUserKey?: CurrentUserKeyNode;\n  ownedContactCard?: SharedContactCardNode;\n  receivedContactCard?: SharedContactCardNode;\n  isCurrentUser?: boolean;\n  haveTp?: boolean;\n  stripe?: UserStripeNode;\n  userPlans?: Connection<UserPlanNode>;\n  userDelete?: UserDeleteNode;\n  features?: FeaturesNode;\n  featureState?: UserFeatureState;\n  sessionEncryptionKey?: string;\n  plans?: IssuedPlanNode[];\n  paymentMethods?: PaymentMethodNode[];\n  billingHistory?: BillingField[];\n  availablePlans?: AvailablePlanField[];\n}\n\nexport interface UserFeatureState extends TimeStamped {\n  notificationsLastViewed?: DateTime;\n}\n\nexport interface ServerTime {\n  timestamp?: string;\n}\n\nexport interface KeyNode extends Node, TimeStamped {\n  pbk?: string;\n}\n\nexport interface ContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  publicDataSig?: string;\n  publicSearchableSig?: string;\n  sigPxk?: KeyNode;\n  defaultFrom?: DateTime;\n  publicData?: string;\n  publicSearchable?: string;\n  cipherData?: string;\n  cipherDataClearJson?: JSONObject;\n  key?: KeyNode;\n  plainData?: string;\n  plainDataSig?: string;\n}\n\nexport interface AccessControlledResource {\n  accessRole?: AccessRoleChoice;\n  permissions?: PermissionChoice[];\n  tpAccessRoles?: AccessRole[];\n  confidentiality?: ConfidentialResource;\n}\n\nexport interface DirectoryNode\n  extends Node,\n    TimeStamped,\n    AccessControlledResource {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  archived?: boolean;\n  keyId?: ID;\n  childFileLinks?: Connection<FileLinkNode>;\n  childDirectoryLinks?: Connection<DirectoryLinkNode>;\n  parentDirectoryLinks?: Connection<DirectoryLinkNode>;\n  nParentDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildDirectoryLinks?: DirectoryLinkNodeLrNList;\n  nChildFileLinks?: FileLinkNodeLrNList;\n  descendants?: Descendants;\n  lock?: LockField;\n  lockVersion?: string;\n}\n\nexport interface FileNode extends Node, TimeStamped, AccessControlledResource {\n  currentVersion?: FileVersionNode;\n  archived?: boolean;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n  parentDirectoryLinks?: Connection<FileLinkNode>;\n  nParentDirectoryLinks?: FileLinkNodeLrNList;\n  lock?: LockField;\n  lockVersion?: string;\n}\n\nexport interface DirectoryLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childDirectory?: DirectoryNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface FileLinkNode extends Node, TimeStamped {\n  parentDirectory?: DirectoryNode;\n  childFile?: FileNode;\n  linkType?: LinkTypeField;\n}\n\nexport interface DirectoryLinkNodeLrNList {\n  list?: DirectoryLinkNode[];\n}\n\nexport interface FileLinkNodeLrNList {\n  list?: FileLinkNode[];\n}\n\nexport interface Descendants {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n  directoriesCount?: number;\n  filesCount?: number;\n}\n\nexport enum AccessRoleChoice {\n  READER = 'READER',\n  WRITER = 'WRITER',\n  ADMIN = 'ADMIN',\n  DENY = 'DENY',\n  OWNER = 'OWNER',\n}\n\nexport enum AccessRoleMethodChoice {\n  INHERITED = 'INHERITED',\n  DIRECT = 'DIRECT',\n}\n\nexport enum PermissionChoice {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  DELETE = 'DELETE',\n  SHARE = 'SHARE',\n  ARCHIVE = 'ARCHIVE',\n  ACCESS_ARCHIVED = 'ACCESS_ARCHIVED',\n  UNARCHIVE = 'UNARCHIVE',\n  SET_CONFIDENTIAL = 'SET_CONFIDENTIAL',\n}\n\nexport interface ConfidentialResource {\n  isConfidential?: boolean;\n  method?: AccessRoleMethodChoice;\n}\n\nexport interface AccessRole {\n  issuer?: UserNode;\n  subject?: UserNode;\n  role?: AccessRoleChoice;\n  method?: AccessRoleMethodChoice;\n  inheritedFrom?: DirectoryNode;\n  tp?: TpNode;\n  isIssuer?: boolean;\n}\n\nexport enum FileOperationField {\n  CREATE = 'CREATE',\n  READ = 'READ',\n  UPDATE = 'UPDATE',\n  REVERT = 'REVERT',\n  DELETE = 'DELETE',\n}\n\nexport interface FileVersionNode extends Node, TimeStamped {\n  file?: FileNode;\n  state?: FileStateNode;\n  operation?: FileOperationField;\n  author?: UserNode;\n}\nexport interface FileStateNode extends Node, TimeStamped {\n  plainMeta?: JSONString;\n  plainMetaJson?: JSONObject;\n  cipherMeta?: string;\n  cipherMetaClearJson?: JSONObject;\n  contentResource?: string;\n  versions?: Connection<FileVersionNode>;\n  keyId?: ID;\n}\n\nexport enum KeyExchangeOtkState {\n  OTK_INITIATED = 'OTK_INITIATED',\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\n  OTK_COMPLETED = 'OTK_COMPLETED',\n}\n\n// These fields are not optional because they are not within the user's control to select in a gql query.\nexport interface ContactCardSharedCipherData {\n  // Shared read access between initiator and responder. But only the initiator has write access.\n  sharedCipherDataClearJson: JSONObject;\n}\n\n/**\n * The contents of the one-time key cipher\n * These fields are not optional because they are not within the user's control to select in a gql query.\n */\nexport interface OtKeyCipherClearJson2 {\n  // Used to confirm to the initiator that the responder has access to the one-time key.\n  nonce: string;\n  // Data sent from initiator to the responder\n  initiator: {\n    oneTimePbk: Record<string, JSONObject>; // one-time public encryption key the responder will use to send data back to the initiator\n    pbk: Record<string, JSONObject>; // public encryption key\n    sigPbk: Record<string, JSONObject>; // public signing key\n    message?: JSONObject;\n    contactCard?: ContactCardSharedCipherData;\n  };\n}\n\nexport interface KeyExchangeOtkNode extends Node, TimeStamped {\n  state?: KeyExchangeOtkState;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  initiatorSigPxk?: KeyNode;\n  responderSigPxk?: KeyNode;\n  initiatorOneTimePbkCipher?: string;\n  otKeyParams?: string;\n  otKeyCipher?: string;\n  otKeyCipherClearJson?: OtKeyCipherClearJson2;\n  responderPbkCipher?: string;\n}\n\nexport enum KeyExchangeState {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETED = 'COMPLETED',\n  DECLINED = 'DECLINED',\n  CANCELLED = 'CANCELLED',\n  DELETED = 'DELETED',\n}\n\nexport enum KeyExchangeMode {\n  OTK = 'OTK',\n}\n\nexport interface KeyExchangeNode extends Node, TimeStamped {\n  expiryTime?: DateTime;\n  token?: string;\n  tokenExpiryTime?: DateTime;\n  state?: KeyExchangeState;\n  mode?: KeyExchangeMode;\n  initiator?: UserNode;\n  responder?: UserNode;\n  initiatorRootKeyCipher?: string;\n  responderRootKeyCipher?: string;\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  createTp?: boolean;\n  otk?: KeyExchangeOtkNode;\n  isInitiator?: boolean;\n  isExpired?: boolean;\n  responderEmailAddress?: LrEmail;\n}\n\nexport interface SharedItems {\n  directories?: Connection<DirectoryNode>;\n  files?: Connection<FileNode>;\n}\n\nexport interface SharedContactCardNode extends Node, TimeStamped {\n  owner?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherDataSig?: string;\n  sharedCipherDataSigPxk?: KeyNode;\n  ownerCipherData?: string;\n  ownerCipherDataClearJson?: JSONObject;\n  ownerKey?: KeyNode;\n  ownerPlainData?: string;\n  ownerPlainDataJson?: JSONObject;\n  ownerPlainDataSig?: string;\n  receiverCipherData?: string;\n  receiverCipherDataClearJson?: JSONObject;\n  receiverKey?: KeyNode;\n}\n\nexport interface UserSharedKeyNode extends Node, TimeStamped {\n  keyExchange?: KeyExchangeNode;\n  user?: UserNode;\n  userPrk?: KeyNode;\n  userSigPrk?: KeyNode;\n  other?: UserNode;\n  otherPbk?: KeyNode;\n  otherSigPbk?: KeyNode;\n  sharedKey?: KeyNode;\n  mkSharedKey?: KeyNode;\n  mkPxk?: KeyNode;\n  mkReshareRequestCipher?: string;\n  mkReshareResponseCipher?: string;\n  mkReshareRequestCipherClearJson?: JSONObject;\n  mkReshareResponseCipherClearJson?: JSONObject;\n  mkReshareRequestSent?: boolean;\n  mkReshareResponseSent?: boolean;\n}\n\nexport interface CurrentUserSharedKeyNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  userSharedKey?: UserSharedKeyNode;\n}\n\nexport interface TpNode extends Node, TimeStamped {\n  user?: UserNode;\n  other?: UserNode;\n  currentUserSharedKey?: CurrentUserSharedKeyNode;\n  isCompleted?: boolean;\n  sharedKey?: KeyNode;\n  sharedContactCard?: SharedContactCardNode;\n  myContactCard?: SharedContactCardNode;\n  myItems?: SharedItems;\n  theirItems?: SharedItems;\n  myScenarios?: Connection<ScenarioNode>;\n  sharedScenarios?: Connection<SharedScenarioNode>;\n}\n\nexport enum TpAssemblyState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum TpClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport interface TpPasswordResetApproval extends Node, TimeStamped {\n  approverEmail?: string;\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n}\n\nexport interface TpPasswordResetUserApprovalNode extends Node, TimeStamped {\n  receiverCipher?: string;\n  receiverCipherClearJson?: JSONObject;\n  receiverCipherPartialAssemblyKey?: string;\n  receiverCipherPartialAssemblyKeyClearJson?: JSONObject;\n  approverEmail?: string;\n}\n\nexport interface TpPasswordResetUserApprover {\n  name?: string;\n  email?: string;\n  state?: TpClaimApproverState;\n}\n\nexport interface TpPasswordResetUserSubAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  approvers?: TpPasswordResetUserApprover[];\n}\n\nexport interface TpPasswordResetUserAssembly {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblies?: TpPasswordResetUserSubAssembly[];\n}\n\nexport interface TpPasswordResetUserNode {\n  username?: string;\n  resetUsername?: string;\n  state?: TpClaimState;\n  passKey?: PassKeyNode;\n  masterKey?: KeyNode;\n  pxk?: KeyNode;\n  sessionEncryptionKey?: string;\n  approvals?: TpPasswordResetUserApprovalNode[];\n  assemblyCipherData?: string;\n  wrappedAssemblyKeyVerifierPrk?: string;\n  assembly?: TpPasswordResetUserAssembly;\n  requestAgainAfter?: DateTime;\n}\n\nexport interface TpPasswordResetNode extends Node, TimeStamped {\n  assembly?: TpAssemblyNode;\n  request?: TpPasswordResetRequestNode;\n  applied?: boolean;\n}\n\nexport interface TpPasswordResetRequestNode extends Node, TimeStamped {\n  state?: TpClaimState;\n}\n\nexport interface TpAssemblyNode extends Node, TimeStamped {\n  id?: ID;\n  singleReject?: boolean;\n  quorum?: number;\n  canMeetQuorum?: boolean;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assemblyKey?: KeyNode;\n  assemblyCipherData?: string;\n  assemblyCipherDataClearJson?: JSONObject;\n  subAssemblies?: Connection<TpSubAssemblyNode>;\n}\n\nexport interface TpSubAssemblyNode extends Node, TimeStamped {\n  singleReject?: boolean;\n  quorum?: number;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: string;\n  approvers?: Connection<TpAssemblyApproverNode>;\n}\n\nexport interface TpAssemblyApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  tp?: TpNode;\n}\n\nexport interface SharedTpPasswordResetNode extends Node, TimeStamped {\n  assembly?: SharedTpAssemblyNode;\n  tp?: TpNode;\n  sharedRequest?: SharedTpPasswordResetRequestNode;\n}\n\nexport interface SharedTpAssemblyNode extends Node, TimeStamped {\n  asApprovers?: Connection<TpAssemblyAsApproverNode>;\n}\n\nexport interface TpAssemblyAsApproverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n}\n\nexport interface SharedTpPasswordResetRequestNode extends Node, TimeStamped {\n  claim?: SharedTpClaimNode;\n  pxk?: KeyNode;\n}\n\nexport interface SharedTpClaimNode extends Node, TimeStamped {\n  state?: TpClaimState;\n  asClaimApprovers?: Connection<SharedTpClaimApproverNode>;\n}\n\nexport interface SharedTpClaimApproverNode extends Node, TimeStamped {\n  state?: TpClaimApproverState;\n  sharedKey?: KeyNode;\n  sharedCipherApprovalData?: string;\n  sharedCipherApprovalDataClearJson?: JSONObject;\n  sharedCipherPartialAssemblyKey?: string;\n  sharedCipherPartialAssemblyKeyClearJson?: JSONObject;\n  receiverApprovals?: Connection<SharedTpClaimReceiverApprovalNode>;\n}\n\nexport interface SharedTpClaimReceiverApprovalNode extends Node, TimeStamped {\n  pxk?: KeyNode;\n}\n\nexport enum LockState {\n  UNLOCKED = 'UNLOCKED',\n  MUTEX_LOCKED = 'MUTEX_LOCKED',\n}\n\nexport enum ScenarioState {\n  DISABLED = 'DISABLED',\n  ENABLED = 'ENABLED',\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n}\n\nexport enum ClaimState {\n  CLAIMED = 'CLAIMED',\n  EXPIRED = 'EXPIRED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport enum ClaimApproverState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n}\n\nexport enum ScenarioLastClaimState {\n  CLAIMED = 'CLAIMED',\n  APPROVED = 'APPROVED',\n  REJECTED = 'REJECTED',\n  EXPIRED = 'EXPIRED',\n  CANCELLED = 'CANCELLED',\n  RESET = 'RESET',\n}\n\nexport interface ScenarioLatestClaim {\n  state?: ScenarioLastClaimState;\n  created?: DateTime;\n  claimAgainAfter?: DateTime;\n}\n\nexport interface ScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  subjectKey?: KeyNode;\n  subjectCipherData?: string;\n  subjectCipherDataClearJson?: JSONObject;\n  assembly?: TpAssemblyNode;\n  state?: ScenarioState;\n  claimants?: Connection<ScenarioClaimantNode>;\n  receivers?: Connection<ScenarioReceiverNode>;\n  claims?: Connection<ScenarioClaimNode>;\n  claim?: ScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface ScenarioClaimNode extends Node, TimeStamped {\n  claimant?: ScenarioClaimantNode;\n  state?: ClaimState;\n  scenario?: ScenarioNode;\n}\n\nexport interface ScenarioAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  subAssemblyStates?: ScenarioSubAssemblyState[];\n}\n\nexport interface ScenarioSubAssemblyState {\n  singleReject?: boolean;\n  quorum?: number;\n  approverStates?: ScenarioAssemblyApproverState[];\n}\n\nexport interface ScenarioAssemblyApproverState {\n  state?: TpClaimApproverState;\n}\n\nexport interface ScenarioReceiverNode extends Node, TimeStamped {\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  pbk?: KeyNode;\n  receiverDirectories?: Connection<ScenarioReceiverDirectoryNode>;\n  receiverFiles?: Connection<ScenarioReceiverFileNode>;\n  tp?: TpNode;\n}\n\nexport interface SharedScenarioReceiverNode extends Node, TimeStamped {\n  pbk?: KeyNode;\n}\n\nexport type ReceiverDirectoryAccessRole = AccessRoleChoice;\n\nexport interface ScenarioReceiverItemNode extends Node, TimeStamped {\n  receiver?: SharedScenarioReceiverNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n  accessRole?: ReceiverDirectoryAccessRole;\n  wrappedItemKey?: string;\n  itemKey?: KeyNode;\n}\n\nexport interface ScenarioReceiverDirectoryNode\n  extends ScenarioReceiverItemNode {\n  directory?: DirectoryNode;\n}\n\nexport interface ScenarioReceiverFileNode extends ScenarioReceiverItemNode {\n  file?: FileNode;\n}\n\nexport interface ScenarioClaimantNode extends Node, TimeStamped {\n  tp?: TpNode;\n  sharedKey?: KeyNode;\n  sharedCipherData?: string;\n  sharedCipherDataClearJson?: JSONObject;\n}\n\nexport interface SharedScenarioNode extends Node, TimeStamped {\n  subject?: UserNode;\n  state?: ScenarioState;\n  tp?: TpNode;\n  asClaimant?: ScenarioClaimantNode;\n  asReceiver?: ScenarioReceiverNode;\n  assembly?: SharedTpAssemblyNode;\n  sharedClaim?: SharedScenarioClaimNode;\n  assemblyState?: ScenarioAssemblyState;\n  latestClaim?: ScenarioLatestClaim;\n}\n\nexport interface SharedScenarioClaimNode extends Node, TimeStamped {\n  state?: ClaimState;\n  sharedScenario?: SharedScenarioNode;\n  isClaimant?: boolean;\n  asClaimReceiver?: SharedScenarioClaimReceiverNode;\n  claim?: SharedTpClaimNode;\n}\n\nexport interface SharedScenarioClaimApproverNode extends Node, TimeStamped {\n  receivers?: Connection<SharedScenarioReceiverNode>;\n  state?: ClaimApproverState;\n  approver?: TpAssemblyApproverNode;\n}\n\nexport interface SharedScenarioClaimReceiverNode extends Node, TimeStamped {\n  received?: DateTime;\n  approvals?: Connection<SharedScenarioClaimReceivedApprovalNode>;\n}\n\nexport interface SharedScenarioClaimReceivedApprovalNode\n  extends Node,\n    TimeStamped {\n  receiverCipher?: string;\n  receiverCipherPartialAssemblyKey?: string;\n  pxk?: KeyNode;\n}\n\nexport interface NotificationNode extends Node, TimeStamped {\n  plainData?: JSONString;\n  plainMeta?: JSONString;\n  timeRead?: DateTime;\n}\n\nexport interface NotificationManagementState extends Node, TimeStamped {\n  lastViewed?: DateTime;\n}\n\nexport enum LinkTypeField {\n  HARD = 'HARD',\n  SOFT = 'SOFT',\n}\n\nexport interface MessageNode extends Node, TimeStamped {\n  sender?: UserNode;\n  receiver?: UserNode;\n  sharedKey?: KeyNode;\n  senderSigPbk?: KeyNode;\n  plainMessage?: string;\n  plainMessageJson?: string;\n  signedCipherMessage?: string;\n  signedCipherMessageClearJson?: string;\n}\n\nexport interface LockField {\n  created?: DateTime;\n  modified?: DateTime;\n  expiryTime?: DateTime;\n  version?: string;\n  state?: LockState;\n}\n\nexport interface ServerConfig {\n  relayConnectionMaxLimit?: number;\n}\n\nexport interface AvailablePlanField {\n  issuerUid?: string;\n  planUid?: string;\n  name?: string;\n  description?: string;\n  priceOptions?: PriceOptionField[];\n  trial?: TrialPeriodField;\n}\n\nexport interface PriceOptionField {\n  priceId?: string;\n  name?: string;\n  description?: string;\n  amount?: number;\n  currency?: string;\n  intervalUnit?: string;\n  intervalCount?: number;\n}\n\nexport interface TrialPeriodField {\n  years?: number;\n  months?: number;\n  weeks?: number;\n  days?: number;\n}\n\nexport interface PaymentCaptureField {\n  stripeIntentId?: string;\n  stripeClientSecret?: string;\n}\n\nexport interface PaymentMethodNode extends Node, TimeStamped {\n  card?: PaymentCardField;\n  invoice?: PaymentInvoiceField;\n  isDefault?: boolean;\n}\n\nexport interface PaymentCardField {\n  brand?: string;\n  lastFourDigits?: string;\n  expiryYear?: number;\n  expiryMonth?: number;\n}\n\nexport interface PaymentInvoiceField {\n  email?: string;\n}\n\nexport interface PromotionalCodeField {\n  amountOff?: number;\n  currency?: string;\n  percentOff?: number;\n  name?: string;\n  duration?: string;\n  durationInMonths?: number;\n}\n\nexport interface PeriodField {\n  start?: DateTime;\n  end?: DateTime;\n}\n\nexport interface IssuedPlanNode extends Node, TimeStamped {\n  name?: string;\n  description?: string;\n  currentStates?: IssuedPlanStateNode[];\n  currentPeriod?: PeriodField;\n  currentPriceOption?: PriceOptionField;\n  upcomingInvoice?: BillingField;\n  alternativePriceOptions?: PriceOptionField[];\n  scheduledPriceChanges?: PriceChangeField[];\n}\n\nexport interface IssuedPlanStateNode extends Node, TimeStamped {\n  periodStart?: DateTime;\n  periodEnd?: DateTime;\n  state?: PlanStateField;\n}\n\nexport enum PlanStateField {\n  TRIALLING = 'TRIALLING',\n  ACTIVE = 'ACTIVE',\n  CANCELLED = 'CANCELLED',\n  EXPIRED = 'EXPIRED',\n}\n\nexport interface BillingField {\n  invoiceNumber?: string;\n  total?: number;\n  amountDue?: number;\n  currency?: string;\n  documentUrl?: string;\n  status?: string;\n  periodStart?: DateTime;\n  periodEnd?: DateTime;\n  finalisedAt?: DateTime;\n  paidAt?: DateTime;\n  paid?: boolean;\n  nextPaymentAttempt?: DateTime;\n}\n\nexport interface PriceChangeField {\n  periodStart?: DateTime;\n  priceOption?: PriceOptionField;\n}\n"]}
@@ -17,4 +17,4 @@ export var RecoveryStatus;
17
17
  RecoveryStatus["NEW_PASSWORD"] = "new-password";
18
18
  RecoveryStatus["OLD_PASSWORD"] = "old-password";
19
19
  })(RecoveryStatus || (RecoveryStatus = {}));
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9hdXRoL2F1dGgudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBd0JoRCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsV0FBVztJQUFyRDs7UUFJRSwwQkFBcUIsR0FBRyxLQUFLLENBQUM7SUFDaEMsQ0FBQztDQUFBO0FBRUQsTUFBTSxPQUFPLFdBQVc7Q0FldkI7QUFNRCxNQUFNLE9BQU8sV0FBVztDQUt2QjtBQUVELE1BQU0sT0FBTyxjQUFjO0NBSzFCO0FBRUQsTUFBTSxDQUFOLElBQVksY0FJWDtBQUpELFdBQVksY0FBYztJQUN4QiwrQkFBYSxDQUFBO0lBQ2IsK0NBQTZCLENBQUE7SUFDN0IsK0NBQTZCLENBQUE7QUFDL0IsQ0FBQyxFQUpXLGNBQWMsS0FBZCxjQUFjLFFBSXpCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29nbml0b1VzZXIgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aCc7XG5pbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xuaW1wb3J0IHtcbiAgSlNPTk9iamVjdCxcbiAgVHBQYXNzd29yZFJlc2V0VXNlck5vZGUsXG4gIFVzZXJEZWxldGVOb2RlLFxufSBmcm9tICcuLi9hcGkvdHlwZXMnO1xuaW1wb3J0IHsgUGFzc0lkcFBhcmFtcywgUGFzc0tleVBhcmFtcyB9IGZyb20gJy4uL2tleS9rZXkudHlwZXMnO1xuaW1wb3J0IHsgVXNlclBsYW4gfSBmcm9tICcuLi9wbGFuL3BsYW4udHlwZXMnO1xuaW1wb3J0IHtcbiAgQ3VycmVudFVzZXJLZXksXG4gIEZlYXR1cmVzLFxuICBNYWluQ29udGFjdENhcmQsXG59IGZyb20gJy4uL3Byb2ZpbGUvcHJvZmlsZS50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0tleUJ1bmRsZSB7XG4gIHBhc3NLZXlQYXJhbXM6IFBhc3NLZXlQYXJhbXM7XG4gIHBhc3NLZXk6IEpXSy5LZXk7XG4gIHBhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XG4gIHBhc3NJZHA6IEpXSy5LZXk7XG4gIHBhc3NJZHBWZXJpZmllcjogSldLLktleTtcbiAgd3JhcHBlZFBhc3NJZHBWZXJpZmllclByazogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG59XG5cbmV4cG9ydCBjbGFzcyBDb2duaXRvQ2hhbGxlbmdlVXNlciBleHRlbmRzIENvZ25pdG9Vc2VyIHtcbiAgcmVjb3ZlcnlTdGF0dXM6IFJlY292ZXJ5U3RhdHVzO1xuICBjaGFsbGVuZ2VOYW1lOiAnU01TX01GQScgfCAnU09GVFdBUkVfVE9LRU5fTUZBJztcbiAgY2hhbGxlbmdlUGFyYW06IEpTT05PYmplY3Q7XG4gIGlzVHBQYXNzd29yZFJlc2V0VXNlciA9IGZhbHNlO1xufVxuXG5leHBvcnQgY2xhc3MgQ3VycmVudFVzZXIge1xuICBpZDogc3RyaW5nO1xuICBzdWI6IHN0cmluZztcbiAgdXNlcm5hbWU6IHN0cmluZztcbiAgY3VycmVudFVzZXJLZXk6IEN1cnJlbnRVc2VyS2V5O1xuICBlbWFpbDogc3RyaW5nO1xuICBlbWFpbFZlcmlmaWVkOiBib29sZWFuO1xuICBwaG9uZTogc3RyaW5nO1xuICBwaG9uZVZlcmlmaWVkOiBib29sZWFuO1xuICBjb250YWN0Q2FyZDogTWFpbkNvbnRhY3RDYXJkO1xuICB1c2VyRGVsZXRlPzogVXNlckRlbGV0ZU5vZGU7XG4gIHVzZXJQbGFuczogVXNlclBsYW5bXTtcbiAgZmVhdHVyZXM6IEZlYXR1cmVzO1xuICBoYXNUUFZhdWx0QWNjZXNzOiBib29sZWFuO1xuICBzZXNzaW9uRW5jcnlwdGlvbktleTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRwUGFzc3dvcmRSZXNldFVzZXIgZXh0ZW5kcyBUcFBhc3N3b3JkUmVzZXRVc2VyTm9kZSB7XG4gIHN1Yjogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgTG9naW5SZXN1bHQge1xuICBoYXNDaGFsbGVuZ2U6IGJvb2xlYW47XG4gIGNoYWxsZW5nZT86IENvZ25pdG9DaGFsbGVuZ2VVc2VyO1xuICB1c2VyPzogQ3VycmVudFVzZXI7XG4gIHJlc2V0VXNlcj86IFRwUGFzc3dvcmRSZXNldFVzZXJOb2RlO1xufVxuXG5leHBvcnQgY2xhc3MgUmVnaXN0ZXJSZXN1bHQge1xuICB1c2VybmFtZTogc3RyaW5nO1xuICB1c2VySWQ6IHN0cmluZztcbiAgcHJlU2lnblVwVG9rZW46IHN0cmluZztcbiAgdXNlclN1Yjogc3RyaW5nO1xufVxuXG5leHBvcnQgZW51bSBSZWNvdmVyeVN0YXR1cyB7XG4gIE5PTkUgPSAnbm9uZScsXG4gIE5FV19QQVNTV09SRCA9ICduZXctcGFzc3dvcmQnLFxuICBPTERfUEFTU1dPUkQgPSAnb2xkLXBhc3N3b3JkJyxcbn1cbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9hdXRoL2F1dGgudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBeUJoRCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsV0FBVztJQUFyRDs7UUFJRSwwQkFBcUIsR0FBRyxLQUFLLENBQUM7SUFDaEMsQ0FBQztDQUFBO0FBRUQsTUFBTSxPQUFPLFdBQVc7Q0FnQnZCO0FBTUQsTUFBTSxPQUFPLFdBQVc7Q0FLdkI7QUFFRCxNQUFNLE9BQU8sY0FBYztDQUsxQjtBQUVELE1BQU0sQ0FBTixJQUFZLGNBSVg7QUFKRCxXQUFZLGNBQWM7SUFDeEIsK0JBQWEsQ0FBQTtJQUNiLCtDQUE2QixDQUFBO0lBQzdCLCtDQUE2QixDQUFBO0FBQy9CLENBQUMsRUFKVyxjQUFjLEtBQWQsY0FBYyxRQUl6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZ25pdG9Vc2VyIH0gZnJvbSAnQGF3cy1hbXBsaWZ5L2F1dGgnO1xuaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcbmltcG9ydCB7XG4gIEpTT05PYmplY3QsXG4gIFRwUGFzc3dvcmRSZXNldFVzZXJOb2RlLFxuICBVc2VyRGVsZXRlTm9kZSxcbn0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7IERhdGVUaW1lIH0gZnJvbSAnLi4vYXBpL3R5cGVzL2dyYXBocWwudHlwZXMnO1xuaW1wb3J0IHsgUGFzc0lkcFBhcmFtcywgUGFzc0tleVBhcmFtcyB9IGZyb20gJy4uL2tleS9rZXkudHlwZXMnO1xuaW1wb3J0IHsgVXNlclBsYW4gfSBmcm9tICcuLi9wbGFuL3BsYW4udHlwZXMnO1xuaW1wb3J0IHtcbiAgQ3VycmVudFVzZXJLZXksXG4gIEZlYXR1cmVzLFxuICBNYWluQ29udGFjdENhcmQsXG59IGZyb20gJy4uL3Byb2ZpbGUvcHJvZmlsZS50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFzc0tleUJ1bmRsZSB7XG4gIHBhc3NLZXlQYXJhbXM6IFBhc3NLZXlQYXJhbXM7XG4gIHBhc3NLZXk6IEpXSy5LZXk7XG4gIHBhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XG4gIHBhc3NJZHA6IEpXSy5LZXk7XG4gIHBhc3NJZHBWZXJpZmllcjogSldLLktleTtcbiAgd3JhcHBlZFBhc3NJZHBWZXJpZmllclByazogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD47XG59XG5cbmV4cG9ydCBjbGFzcyBDb2duaXRvQ2hhbGxlbmdlVXNlciBleHRlbmRzIENvZ25pdG9Vc2VyIHtcbiAgcmVjb3ZlcnlTdGF0dXM6IFJlY292ZXJ5U3RhdHVzO1xuICBjaGFsbGVuZ2VOYW1lOiAnU01TX01GQScgfCAnU09GVFdBUkVfVE9LRU5fTUZBJztcbiAgY2hhbGxlbmdlUGFyYW06IEpTT05PYmplY3Q7XG4gIGlzVHBQYXNzd29yZFJlc2V0VXNlciA9IGZhbHNlO1xufVxuXG5leHBvcnQgY2xhc3MgQ3VycmVudFVzZXIge1xuICBpZDogc3RyaW5nO1xuICBzdWI6IHN0cmluZztcbiAgdXNlcm5hbWU6IHN0cmluZztcbiAgY3VycmVudFVzZXJLZXk6IEN1cnJlbnRVc2VyS2V5O1xuICBlbWFpbDogc3RyaW5nO1xuICBlbWFpbFZlcmlmaWVkOiBib29sZWFuO1xuICBwaG9uZTogc3RyaW5nO1xuICBwaG9uZVZlcmlmaWVkOiBib29sZWFuO1xuICBjb250YWN0Q2FyZDogTWFpbkNvbnRhY3RDYXJkO1xuICB1c2VyRGVsZXRlPzogVXNlckRlbGV0ZU5vZGU7XG4gIHVzZXJQbGFuczogVXNlclBsYW5bXTtcbiAgZmVhdHVyZXM6IEZlYXR1cmVzO1xuICBoYXNUUFZhdWx0QWNjZXNzOiBib29sZWFuO1xuICBzZXNzaW9uRW5jcnlwdGlvbktleTogc3RyaW5nO1xuICBkYXRlSm9pbmVkOiBEYXRlVGltZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcFBhc3N3b3JkUmVzZXRVc2VyIGV4dGVuZHMgVHBQYXNzd29yZFJlc2V0VXNlck5vZGUge1xuICBzdWI6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIExvZ2luUmVzdWx0IHtcbiAgaGFzQ2hhbGxlbmdlOiBib29sZWFuO1xuICBjaGFsbGVuZ2U/OiBDb2duaXRvQ2hhbGxlbmdlVXNlcjtcbiAgdXNlcj86IEN1cnJlbnRVc2VyO1xuICByZXNldFVzZXI/OiBUcFBhc3N3b3JkUmVzZXRVc2VyTm9kZTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlZ2lzdGVyUmVzdWx0IHtcbiAgdXNlcm5hbWU6IHN0cmluZztcbiAgdXNlcklkOiBzdHJpbmc7XG4gIHByZVNpZ25VcFRva2VuOiBzdHJpbmc7XG4gIHVzZXJTdWI6IHN0cmluZztcbn1cblxuZXhwb3J0IGVudW0gUmVjb3ZlcnlTdGF0dXMge1xuICBOT05FID0gJ25vbmUnLFxuICBORVdfUEFTU1dPUkQgPSAnbmV3LXBhc3N3b3JkJyxcbiAgT0xEX1BBU1NXT1JEID0gJ29sZC1wYXNzd29yZCcsXG59XG4iXX0=
@@ -127,6 +127,7 @@ export class LifeReadyAuthService {
127
127
  hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),
128
128
  features: currentUser.features,
129
129
  sessionEncryptionKey: currentUser.sessionEncryptionKey,
130
+ dateJoined: currentUser.dateJoined,
130
131
  };
131
132
  });
132
133
  }
@@ -371,6 +372,7 @@ export class LifeReadyAuthService {
371
372
  hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),
372
373
  features: currentUser.features,
373
374
  sessionEncryptionKey: currentUser.sessionEncryptionKey,
375
+ dateJoined: currentUser.dateJoined,
374
376
  };
375
377
  });
376
378
  }
@@ -563,4 +565,4 @@ LifeReadyAuthService.ctorParameters = () => [
563
565
  { type: TpPasswordResetAssemblyController },
564
566
  { type: HttpClient }
565
567
  ];
566
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"life-ready-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/auth/life-ready-auth.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE9D,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAExC,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACjE,OAAO,EAAE,+BAA+B,EAAE,MAAM,4DAA4D,CAAC;AAC7G,OAAO,EAAE,YAAY,EAA2B,MAAM,cAAc,CAAC;AACrE,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,OAAO,EAAY,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAY,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAC1E,OAAO,EACL,qCAAqC,EACrC,iCAAiC,GAClC,MAAM,kDAAkD,CAAC;AAC1D,OAAO,EAAE,iCAAiC,EAAE,MAAM,mDAAmD,CAAC;AACtG,OAAO,EACL,sCAAsC,EACtC,oCAAoC,EACpC,yCAAyC,GAC1C,MAAM,4CAA4C,CAAC;AACpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,oDAAoD,CAAC;AAC9F,OAAO,EACL,qBAAqB,EACrB,mBAAmB,EACnB,2BAA2B,EAC3B,wBAAwB,GACzB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,+BAA+B,EAAE,MAAM,YAAY,CAAC;AAC7D,OAAO,EAIL,cAAc,GAEf,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;;AAEtB,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,WAAiC,EAAE,EAAE;IAClE,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC;AACxC,CAAC,CAAC;AAWF,MAAM,OAAO,oBAAoB;IAS/B,YAC6B,MAAgB,EACnC,IAAe,EACf,UAA6B,EAC7B,UAAsB,EACtB,cAA8B,EAC9B,eAAgC,EAChC,eAAgC,EAChC,WAAwB,EACxB,SAA2B,EAC3B,+BAAgE,EAChE,cAA8B,EAC9B,iBAAoC,EACpC,kBAAqD,EACrD,IAAgB;QAbG,WAAM,GAAN,MAAM,CAAU;QACnC,SAAI,GAAJ,IAAI,CAAW;QACf,eAAU,GAAV,UAAU,CAAmB;QAC7B,eAAU,GAAV,UAAU,CAAY;QACtB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,oBAAe,GAAf,eAAe,CAAiB;QAChC,oBAAe,GAAf,eAAe,CAAiB;QAChC,gBAAW,GAAX,WAAW,CAAa;QACxB,cAAS,GAAT,SAAS,CAAkB;QAC3B,oCAA+B,GAA/B,+BAA+B,CAAiC;QAChE,mBAAc,GAAd,cAAc,CAAgB;QAC9B,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,uBAAkB,GAAlB,kBAAkB,CAAmC;QACrD,SAAI,GAAJ,IAAI,CAAY;QAtB1B,8DAA8D;QACtD,eAAU,GAAuB,IAAI,aAAa,CAAM,CAAC,CAAC,CAAC;QAGnE,sFAAsF;QACtF,qEAAqE;QAC7D,oBAAe,GAAG,IAAI,GAAG,EAAkB,CAAC;QAkBlD,IAAI,CAAC,SAAS,EAAE,EAAE;YAChB,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,EAAE;gBAC7B,MAAM,IAAI,qBAAqB,CAC7B,wDAAwD,CACzD,CAAC;aACH;SACF;IACH,CAAC;IAEK,UAAU;;YACd,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QACnE,CAAC;KAAA;IAEM,UAAU,CAAC,QAAgB,EAAE,QAAmB;QACrD,yEAAyE;QACzE,wBAAwB;QACxB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAEtC,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAED,2EAA2E;IAC3E,2EAA2E;IAC3E,2EAA2E;IAC3E;;OAEG;IACK,sBAAsB,CAAC,QAAgB;QAC7C,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CACF,IAAI,CAAC,MAAM,CAAC,MAAM;YAChB,mCAAmC;YACnC,kBAAkB,CAAC,QAAQ,CAAC,EAC9B;YACE,yEAAyE;YACzE,4EAA4E;YAC5E,gFAAgF;YAChF,8EAA8E;YAC9E,EAAE;YACF,yEAAyE;YACzE,eAAe,EAAE,IAAI;SACtB,CACF;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAEa,aAAa,CAAC,QAAmB;;YAC7C,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,SAAS,EAAE,GAC3C,MAAM,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,CAAC;YAE7C,2DAA2D;YAC3D,6BAA6B;YAE7B,MAAM,OAAO,GAAG,CACd,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,iBACjC,QAAQ,IACL,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,EACnD,CACH,CAAC,GAAG,CAAC;YAEN,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAC5D,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,EACrC,OAAO,EACP,WAAW,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,CACxC,CAAC;YAEF,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;YAEnD,MAAM,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YAEpE,OAAO;gBACL,EAAE,EAAE,WAAW,CAAC,EAAE;gBAClB,GAAG,EAAE,YAAY;gBACjB,QAAQ,EAAE,WAAW,CAAC,QAAQ;gBAC9B,cAAc,EAAE,WAAW,CAAC,cAAc;gBAC1C,KAAK,EAAE,YAAY;gBACnB,aAAa,EAAE,KAAK;gBACpB,KAAK,EAAE,YAAY;gBACnB,aAAa,EAAE,KAAK;gBACpB,WAAW,oBACN,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAC/D;gBACD,UAAU,EAAE,WAAW,CAAC,UAAU;gBAClC,SAAS;gBACT,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,QAAQ,CAAC;gBAC7D,QAAQ,EAAE,WAAW,CAAC,QAAQ;gBAC9B,oBAAoB,EAAE,WAAW,CAAC,oBAAoB;aACvD,CAAC;QACJ,CAAC;KAAA;IAEK,iBAAiB;;YACrB,OAAO,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC;KAAA;IAED,cAAc,CAAC,aAAqB;QAClC,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,iBAAiB,CAAC,QAAwB;QACxC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,oBAAoB,CAAC,QAAwB;QAC3C,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACxC,CAAC;IAEa,YAAY,CACxB,YAAoB,EACpB,QAAmB,EACnB,aAA4B,EAC5B,cAA8B;;YAE9B,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,iBACvD,QAAQ,IACL,aAAa,EAChB,CAAC;YACH,kDAAkD;YAClD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CACjC,YAAY,EACZ,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,aAAa,CAAC,GAAG,CAAC,CACzD,CAAC;YAEF,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;YAErC,OAAO,IAAI,CAAC;QACd,CAAC;KAAA;IAEa,QAAQ,CACpB,YAAoB,EACpB,QAAmB;;YAEnB,iDAAiD;YACjD,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,gBAAgB,CACjE,YAAY,CACb,CAAC;YAEF,IACE,gBAAgB,CAAC,oBAAoB,KAAK,oBAAoB,CAAC,UAAU,EACzE;gBACA,MAAM,IAAI,2BAA2B,CAAC,kCAAkC,CAAC,CAAC;aAC3E;YAED,IACE,gBAAgB,CAAC,oBAAoB,KAAK,oBAAoB,CAAC,QAAQ,EACvE;gBACA,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;gBACjC,mGAAmG;gBACnG,IAAI;oBACF,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAClC,YAAY,EACZ,QAAQ,EACR,gBAAgB,CAAC,gBAAgB,EACjC,cAAc,CAAC,YAAY,CAC5B,CAAC;oBACF,yDAAyD;oBAEzD,gCAAgC;oBAChC,wEAAwE;oBAExE,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;oBAEnC,OAAO,IAAI,CAAC;iBACb;gBAAC,OAAO,KAAK,EAAE;oBACd,0CAA0C;oBAC1C,IAAI,KAAK,CAAC,IAAI,KAAK,wBAAwB,EAAE;wBAC3C,MAAM,KAAK,CAAC;qBACb;oBACD,iDAAiD;iBAClD;gBAED,gFAAgF;gBAChF,IAAI;oBACF,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAClC,YAAY,EACZ,QAAQ,EACR,gBAAgB,CAAC,oBAAoB,EACrC,cAAc,CAAC,YAAY,CAC5B,CAAC;oBACF,uBAAuB;oBACvB,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;oBAEnC,OAAO,IAAI,CAAC;iBACb;gBAAC,OAAO,KAAK,EAAE;oBACd,0CAA0C;oBAC1C,MAAM,KAAK,CAAC,IAAI,KAAK,wBAAwB;wBAC3C,CAAC,CAAC,IAAI,qBAAqB,CACvB,sGAAsG,CACvG;wBACH,CAAC,CAAC,KAAK,CAAC;iBACX;aACF;YAED,+CAA+C;YAC/C,IAAI,gBAAgB,CAAC,eAAe,EAAE;gBACpC,IAAI;oBACF,4EAA4E;oBAC5E,8CAA8C;oBAC9C,MAAM,KAAK,GAAG,gBAAgB,CAAC,eAAe,CAAC;oBAC/C,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,YAAY,CACjC,KAAK,CAAC,aAAa,EACnB,QAAQ,EACR,KAAK,CAAC,aAAa,EACnB,cAAc,CAAC,IAAI,CACpB,CAAC;oBACF,GAAG,CAAC,qBAAqB,GAAG,IAAI,CAAC;oBAEjC,OAAO,GAAG,CAAC;iBACZ;gBAAC,OAAO,GAAG,EAAE;oBACZ,uCAAuC;iBACxC;aACF;YAED,wBAAwB;YACxB,OAAO,MAAM,IAAI,CAAC,YAAY,CAC5B,YAAY,EACZ,QAAQ,EACR,gBAAgB,CAAC,oBAAoB,EACrC,cAAc,CAAC,IAAI,CACpB,CAAC;QACJ,CAAC;KAAA;IAEa,0BAA0B;;YACtC,IAAI,IAAI,CAAC,MAAM,CAAC,2BAA2B,EAAE;gBAC3C,IAAI,CAAC,SAAS,EAAE,EAAE;oBAChB,MAAM,GAAG,GACP,yFAAyF,CAAC;oBAC5F,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBACnB,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC;iBACtB;qBAAM;oBACL,OAAO,CAAC,IAAI,CACV,uFAAuF,CACxF,CAAC;iBACH;aACF;iBAAM;gBACL,+DAA+D;gBAC/D,MAAM,oBAAoB,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;gBAC/D,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAC3B,IAAI,UAAU,CAAC;oBACb,QAAQ,EAAE,+BAA+B;oBACzC,SAAS,EAAE;wBACT,KAAK,EAAE;4BACL,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAClC,oBAAoB,CAAC,MAAM,CAAC,IAAI,CAAC,CAClC;yBACF;qBACF;iBACF,CAAC,EACF;oBACE,eAAe,EAAE,KAAK;iBACvB,CACF,CAAC;gBAEF,IAAI,CAAC,cAAc,CAAC,6BAA6B,CAAC,oBAAoB,CAAC,CAAC;aACzE;QACH,CAAC;KAAA;IAEa,cAAc,CAAC,WAAiC;;YAC5D,MAAM,IAAI,CAAC,sBAAsB,CAAC,WAAW,CAAC,CAAC;YAC/C,MAAM,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAC1C,CAAC;KAAA;IAEY,KAAK,CAChB,YAAoB,EACpB,QAAmB,EACnB,EAAE,2BAA2B,GAAG,IAAI,KAAmB,EAAE;;;YAEzD,IAAI,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YAE/D,IACE,2BAA2B;gBAC3B,OAAA,WAAW,CAAC,SAAS,0CAAE,KAAK,MAAK,YAAY,CAAC,QAAQ,EACtD;gBACA,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBACrC,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;aAC5D;YAED,OAAO,WAAW,CAAC;;KACpB;IAEY,SAAS,CACpB,YAAoB,EACpB,QAAmB;;YAEnB,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;YACpB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YAEhE,6BAA6B;YAC7B,IAAI,CAAC,SAAS,EAAE,oBAAoB,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,aAAa,CAAC,EAAE;gBACzE,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;aACvD;YAED,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;YAEvC,IAAI,WAAW,CAAC,qBAAqB,EAAE;gBACrC,iDAAiD;gBACjD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBACrD,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;aAC3C;iBAAM;gBACL,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;gBACxD,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,8CAA8C;gBAC9E,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;aACtC;QACH,CAAC;KAAA;IAED,0FAA0F;IAC7E,WAAW,CACtB,SAA+B,EAC/B,QAAmB,EACnB,UAAmB,EACnB,IAAY;;YAEZ,MAAM,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,EAAE,SAAS,CAAC,aAAa,CAAC,CAAC;YAExE,kEAAkE;YAElE,MAAM,WAAW,GAAgB,MAAM,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAE5E,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;YAErC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAExD,IAAI,UAAU,EAAE;gBACd,WAAW,CAAC,yBAAyB,CAAC;oBACpC,SAAS,EAAE,GAAG,EAAE;wBACd,OAAO;oBACT,CAAC;oBACD,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;iBACnC,CAAC,CAAC;aACJ;YAED,OAAO,IAAI,CAAC;QACd,CAAC;KAAA;IAEK,sBAAsB,CAAC,IAA0B;;YACrD,IAAI,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,IAAI,EAAE;gBAC/C,MAAM,IAAI,CAAC,eAAe,CAAC,sBAAsB,CAAC;oBAChD,cAAc,EAAE,IAAI,CAAC,cAAc,KAAK,cAAc,CAAC,YAAY;iBACpE,CAAC,CAAC;aACJ;QACH,CAAC;KAAA;IAEK,kBAAkB,CACtB,MAAM,GAAG,KAAK;;YAEd,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAE/D,IAAI,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,iCAAiC,CAAC,EAAE;gBACzE,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;aAClC;iBAAM;gBACL,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;aAC7B;QACH,CAAC;KAAA;IAEK,YAAY,CAAC,MAAM,GAAG,KAAK;;YAC/B,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACpC,OAAO,IAAI,CAAC,gBAAgB,CAAC;aAC9B;YAED,IAAI,CAAC,gBAAgB,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;YAEnD,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,8CAA8C;YAE9E,OAAO,IAAI,CAAC,gBAAgB,CAAC;QAC/B,CAAC;KAAA;IAEK,OAAO,CAAC,MAAM,GAAG,KAAK;;YAC1B,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC/B,OAAO,IAAI,CAAC,WAAW,CAAC;aACzB;YACD,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CACpC,MAAM,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAC3C,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;YACtC,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,8CAA8C;YAC9E,OAAO,IAAI,CAAC,WAAW,CAAC;QAC1B,CAAC;KAAA;IAEO,gBAAgB,CAAC,QAAmB;QAC1C,MAAM,cAAc,GAAG,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO,CAAC;QACzC,OAAO,CACL,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,MAAM,IAAG,CAAC;YAC1B,cAAc,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,CACrE,CAAC;IACJ,CAAC;IAEa,QAAQ,CACpB,WAAwB,EACxB,QAAoB;;YAEpB,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,SAAS,EAAE,GAC3C,MAAM,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,CAAC;YAE7C,IAAI,WAAW,CAAC,oBAAoB,EAAE;gBACpC,IAAI,CAAC,cAAc,CAAC,6BAA6B,CAC/C,MAAM,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAClD,CAAC;aACH;YAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;YAEnE,IAAI,QAAQ,EAAE;gBACZ,MAAM,OAAO,GAAG,CACd,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,iBACjC,QAAQ,IACL,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,EACnD,CACH,CAAC,GAAG,CAAC;gBAEN,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CACrC,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAC1C,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,EACrC,OAAO,EACP,WAAW,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,CACxC,CACF,CAAC;aACH;YACD,MAAM,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;YAEpE,OAAO;gBACL,EAAE,EAAE,WAAW,CAAC,EAAE;gBAClB,GAAG,EAAE,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,cAAc,CAAC;gBACjD,QAAQ,EAAE,WAAW,CAAC,QAAQ;gBAC9B,cAAc,EAAE,WAAW,CAAC,cAAc;gBAC1C,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,cAAc,CAAC;gBACrD,aAAa,EACX,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,cAAc,CAAC,KAAK,MAAM;gBACpE,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,cAAc,CAAC;gBAC5D,aAAa,EACX,IAAI,CAAC,gBAAgB,CAAC,uBAAuB,EAAE,cAAc,CAAC;oBAC9D,MAAM;gBACR,WAAW,oBACN,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,CAC/D;gBACD,UAAU,EAAE,WAAW,CAAC,UAAU;gBAClC,SAAS;gBACT,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,QAAQ,CAAC;gBAC7D,QAAQ,EAAE,WAAW,CAAC,QAAQ;gBAC9B,oBAAoB,EAAE,WAAW,CAAC,oBAAoB;aACvD,CAAC;QACJ,CAAC;KAAA;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAEY,MAAM;;;YACjB,oCAAoC;YACpC,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAE3E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YAC5B,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;YAEjC,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YAExE,UAAI,IAAI,CAAC,MAAM,CAAC,KAAK,0CAAE,QAAQ,EAAE;gBAC/B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC;aACnC;;KACF;IAEO,gBAAgB,CACtB,aAAqB,EACrB,cAAsC;QAEtC,MAAM,aAAa,GAAG,cAAc,CAAC,IAAI,CACvC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,aAAa,CACrC,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IACzD,CAAC;IAEa,aAAa,CACzB,QAAoB;;YAEpB,MAAM,EAAE,mBAAmB,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;gBACpE,KAAK,EAAE,wBAAwB;aAChC,CAAC,CAAC;YAEH,IAAI,SAAS,CAAC,oBAAoB,EAAE;gBAClC,IAAI,CAAC,cAAc,CAAC,6BAA6B,CAC/C,MAAM,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAChD,CAAC;aACH;YAED,kBAAkB;YAClB,IAAI,QAAQ,EAAE;gBACZ,MAAM,OAAO,GAAG,CACd,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,iBACjC,QAAQ,IACL,SAAS,CAAC,OAAO,CAAC,aAAa,EAClC,CACH,CAAC,GAAG,CAAC;gBAEN,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CACrC,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAC1C,SAAS,CAAC,OAAO,CAAC,EAAE,EACpB,OAAO,EACP,SAAS,CAAC,SAAS,CAAC,EAAE,CACvB,CACF,CAAC;aACH;YAED,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;gBAC3B,OAAO,EAAE;oBACP,EAAE,EAAE,SAAS,CAAC,OAAO,CAAC,EAAE;iBACzB;gBACD,SAAS,EAAE;oBACT,EAAE,EAAE,SAAS,CAAC,SAAS,CAAC,EAAE;iBAC3B;aACF,CAAC,CAAC;YAEH,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,cAAc,CACnD,MAAM,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAC3C,CAAC;YACF,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;YAEzD,uCACK,CAAC,MAAM,IAAI,CAAC,+BAA+B,CAAC,8BAA8B,CAC3E,SAAS,CACV,CAAC,KACF,GAAG,IACH;QACJ,CAAC;KAAA;IAEY,kBAAkB;;YAC7B,MAAM,WAAW,GAAgB,MAAM,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAC5E,MAAM,YAAY,GAAG,WAAW,CAAC,oBAAoB,EAAE,CAAC,eAAe,EAAE,CAAC;YAE1E,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBACrC,WAAW,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC,GAAG,EAAE,EAAE;oBAC/C,IAAI,GAAG,EAAE;wBACP,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,GAAG,CAAC,CAAC;wBAC/C,MAAM,CAAC,GAAG,CAAC,CAAC;qBACb;yBAAM;wBACL,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;wBACtC,OAAO,CAAC,CAAC,CAAC,CAAC;qBACZ;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;IAEK,eAAe,CAAC,WAAsB;;YAC1C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YAEhD,IAAI,SAAS,CAAC,KAAK,KAAK,YAAY,CAAC,QAAQ,EAAE;gBAC7C,MAAM,IAAI,mBAAmB,CAC3B,+CAA+C,CAChD,CAAC;aACH;YAED,iEAAiE;YACjE,uDAAuD;YACvD,iEAAiE;YACjE,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;YAE7D,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CACtD,WAAW,EACX,SAAS,CAAC,kBAAkB,CAC7B,CAAC;YAEF,gCAAgC;YAChC,MAAM,UAAU,GAAG,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAE5C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAE5E,MAAM,uBAAuB,GAC3B,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAC1C,SAAS,CAAC,GAAG,EACb,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CACxB,CAAC;YAEJ,mBAAmB;YACnB,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,iBAC1D,QAAQ,EAAE,WAAW,IAClB,SAAS,CAAC,OAAO,CAAC,aAAa,EAClC,CAAC;YAEH,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAC1D,gBAAgB,CAAC,GAAG,CACrB,CAAC;YAEF,iEAAiE;YACjE,6BAA6B;YAC7B,iEAAiE;YACjE,MAAM,SAAS,GAAG,CAChB,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAC3B,IAAI,UAAU,CAAC;gBACb,QAAQ,EAAE,oCAAoC;gBAC9C,SAAS,EAAE;oBACT,KAAK,EAAE,EAAE;iBACV;aACF,CAAC,EACF;gBACE,eAAe,EAAE,KAAK;aACvB,CACF,CACF,CAAC,4BAA4B,CAAC,SAAS,CAAC;YAEzC,qBAAqB;YACrB,kEAAkE;YAClE,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAClD,qCAAqC,CACtC,CAAC;YAEF,MAAM,sBAAsB,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CACjE,WAAW,EACX,SAAS,CAAC,6BAA6B,CACxC,CAAC;YACF,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,IAAI,CACvD,sBAAsB,EACtB,SAAS,CACV,CAAC;YAEF,iEAAiE;YACjE,wCAAwC;YACxC,iEAAiE;YACjE,MAAM,eAAe,GAAG,CACtB,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAC3B,IAAI,UAAU,CAAC;gBACb,QAAQ,EAAE,yCAAyC;gBACnD,SAAS,EAAE;oBACT,KAAK,EAAE;wBACL,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC;qBACjD;iBACF;aACF,CAAC,EACF;gBACE,eAAe,EAAE,KAAK;aACvB,CACF,CACF,CAAC,iCAAiC,CAAC,WAAW,CAAC;YAEhD,iEAAiE;YACjE,0DAA0D;YAC1D,iEAAiE;YACjE,kEAAkE;YAClE,iEAAiE;YACjE,8DAA8D;YAC9D,mEAAmE;YACnE,iDAAiD;YAEjD,8DAA8D;YAC9D,MAAM,UAAU,GAAG,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;gBAC/C,MAAM,QAAQ,GAAG,CAAO,IAAI,EAAE,EAAE;oBAC9B,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,KAAK,QAAQ,EAAE;wBACnC,OAAO;qBACR;oBAED,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;oBAE7B,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;oBAE3D,qCAAqC;oBACrC,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAC3B,IAAI,UAAU,CAAC;wBACb,QAAQ,EAAE,sCAAsC;wBAChD,SAAS,EAAE;4BACT,KAAK,EAAE;gCACL,uBAAuB;gCACvB,WAAW,EAAE,SAAS,CAAC,EAAE;6BAC1B;yBACF;qBACF,CAAC,CACH,CAAC;oBAEF,OAAO,EAAE,CAAC;gBACZ,CAAC,CAAA,CAAC;gBAEF,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YAC/B,CAAC,CAAC,CAAC;YAEH,0FAA0F;YAC1F,6BAA6B;YAC7B,IAAI,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,eAAe,EAAE;gBACrE,OAAO,EAAE,MAAM;aAChB,CAAC,CAAC;YAEH,IAAI,IAAI,CAAC,aAAa,KAAK,uBAAuB,EAAE;gBAClD,MAAM,IAAI,wBAAwB,CAChC,0GAA0G,CAC3G,CAAC;aACH;YAED,0BAA0B;YAC1B,+EAA+E;YAC/E,2BAA2B;YAC3B,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,cAAc,EAAE,EAAE,CAAC,CAAC;YAErE,OAAO,UAAU,CAAC;QACpB,CAAC;KAAA;IAEa,kBAAkB,CAC9B,SAAkC;;YAElC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhE,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,SAAS,CAAC,SAAS;iBAChB,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,gCAAgC,CAAC;iBACjE,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAChB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAC5B,GAAG,EACH,QAAQ,CAAC,gCAAgC,CAC1C,CACF,CACJ,CAAC;YAEF,OAAO,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;QAC9D,CAAC;KAAA;;;;YAhuBF,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;4CAWI,MAAM,SAAC,SAAS;YArEZ,SAAS;YAUT,iBAAiB;YAEjB,UAAU;YAKV,cAAc;YANd,eAAe;YAIf,eAAe;YANf,WAAW;YAJX,gBAAgB;YAChB,+BAA+B;YAU/B,cAAc;YARd,iBAAiB;YAejB,iCAAiC;YA1BjC,UAAU","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, isDevMode } from '@angular/core';\nimport { CognitoUser } from '@aws-amplify/auth';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { Hub } from '@aws-amplify/core';\nimport { CognitoUserAttribute } from 'amazon-cognito-identity-js';\nimport { JWK } from 'node-jose';\nimport { ReplaySubject } from 'rxjs';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { TpPasswordResetProcessorService } from '../api/query-processor/tp-password-reset-processor.service';\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { IdleService } from '../idle/idle.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService } from '../key/key.service';\nimport { PassIdpParams } from '../key/key.types';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { PersistService } from '../persist/persist.service';\nimport { ProfileService } from '../profile/profile.service';\nimport { Features, PasswordChangeStatus } from '../profile/profile.types';\nimport {\n  TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH,\n  TP_PASSWORD_RESET_USERNAME_SUFFIX,\n} from '../tp-password-reset/tp-password-reset.constants';\nimport { TpPasswordResetAssemblyController } from '../tp-password-reset/tp-password-reset.controller';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from '../tp-password-reset/tp-password-reset.gql';\nimport { TpPasswordResetUserQuery } from '../tp-password-reset/tp-password-reset.private.gql';\nimport {\n  KcBadRequestException,\n  KcBadStateException,\n  KcConcurrentAccessException,\n  KcInternalErrorException,\n} from '../_common/exceptions';\nimport { getAccessJwtToken } from '../_common/utils';\nimport { SetSessionEncryptionKeyMutation } from './auth.gql';\nimport {\n  CognitoChallengeUser,\n  CurrentUser,\n  LoginResult,\n  RecoveryStatus,\n  TpPasswordResetUser,\n} from './auth.types';\n\nexport const initialiseAuth = (authService: LifeReadyAuthService) => {\n  return () => authService.initialise();\n};\n\nexport interface LoginOptions {\n  tpPasswordResetAutoComplete?: boolean;\n}\n\nexport type LogoutListener = () => void | Promise<void>;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LifeReadyAuthService {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private hubSubject: ReplaySubject<any> = new ReplaySubject<any>(1);\n  private currentUser: CurrentUser;\n  private currentResetUser: TpPasswordResetUser;\n  // Could use rxjs observables here. But trying to have kc-client use as little angular\n  // features as possible. Rxjs is not used anywhere else in kc-client.\n  private logoutListeners = new Set<LogoutListener>();\n\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private auth: AuthClass,\n    private keyFactory: KeyFactoryService,\n    private keyService: KeyService,\n    private profileService: ProfileService,\n    private keyGraphService: KeyGraphService,\n    private passwordService: PasswordService,\n    private idleService: IdleService,\n    private lrGraphQL: LrGraphQLService,\n    private tpPasswordResetProcessorService: TpPasswordResetProcessorService,\n    private persistService: PersistService,\n    private encryptionService: EncryptionService,\n    private assemblyController: TpPasswordResetAssemblyController,\n    private http: HttpClient\n  ) {\n    if (!isDevMode()) {\n      if (this.config.debug != null) {\n        throw new KcBadRequestException(\n          'In production mode, \"config.debug\" must be set to null'\n        );\n      }\n    }\n  }\n\n  async initialise() {\n    Hub.listen('auth', (data) => this.hubSubject.next(data.payload));\n  }\n\n  public debugLogin(username: string, password: CryptoKey) {\n    // This will fail if debug is null. But when debug is null, this function\n    // should not be called.\n    this.config.debug.username = username;\n\n    return this.debugLoadUser(password);\n  }\n\n  // ------------------------------------------------------------------------\n  // ------------------------------------------------------------------------\n  // ------------------------------------------------------------------------\n  /**\n   * Login using the server side session method.\n   */\n  private debugLoginUsingSession(username: string) {\n    return this.http\n      .get(\n        this.config.apiUrl +\n          'debug_only/users/login/?username=' +\n          encodeURIComponent(username),\n        {\n          // Non-obvious alert: if you want the cookies to be set, you must use the\n          // \"withCredentials\" header. I would have thought the withCredentials header\n          // is only used to send the cookies with the requests. But, if you don't include\n          // the \"withCredentials\" header, the cookies in the response DOES NOT get set!\n          //\n          // ref: https://github.com/github/fetch/issues/386#issuecomment-243229388\n          withCredentials: true,\n        }\n      )\n      .toPromise();\n  }\n\n  private async debugLoadUser(password: CryptoKey): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    // Debug mode can not deal with session encryption key yet.\n    // NO SESSION ENCRYPTION KEY.\n\n    const passKey = (\n      await this.keyFactory.derivePassKey({\n        password,\n        ...currentUser.currentUserKey.passKey.passKeyParams,\n      })\n    ).jwk;\n\n    const masterKey = await this.keyGraphService.unwrapWithPassKey(\n      currentUser.currentUserKey.passKey.id,\n      passKey,\n      currentUser.currentUserKey.masterKey.id\n    );\n\n    await this.idleService.persistMasterKey(masterKey);\n\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: 'DEBUG_MODE',\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      email: 'DEBUG_MODE',\n      emailVerified: false,\n      phone: 'DEBUG_MODE',\n      phoneVerified: false,\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n    };\n  }\n\n  async getAccessJwtToken(): Promise<string> {\n    return getAccessJwtToken(this.auth);\n  }\n\n  importPassword(plainPassword: string): Promise<CryptoKey> {\n    return this.keyFactory.importPassword(plainPassword);\n  }\n\n  addLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.add(callback);\n  }\n\n  removeLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.delete(callback);\n  }\n\n  private async loginIdpImpl(\n    emailOrPhone: string,\n    password: CryptoKey,\n    passIdpParams: PassIdpParams,\n    recoveryStatus: RecoveryStatus\n  ): Promise<CognitoChallengeUser> {\n    const passIdpResult = await this.keyFactory.derivePassIdp({\n      password,\n      ...passIdpParams,\n    });\n    // Use the derived password to signin with cognito\n    const user = await this.auth.signIn(\n      emailOrPhone,\n      this.passwordService.getPassIdpString(passIdpResult.jwk)\n    );\n\n    user.recoveryStatus = recoveryStatus;\n\n    return user;\n  }\n\n  private async loginIdp(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<CognitoChallengeUser> {\n    // Download the salt needed to derive the PassIdp\n    const passIdpApiResult = await this.profileService.getPassIdpParams(\n      emailOrPhone\n    );\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.InProgress\n    ) {\n      throw new KcConcurrentAccessException('A password change is in progress');\n    }\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.Recovery\n    ) {\n      console.log('In recovery mode.');\n      // Let's say we don't know if the password is the new one or the old one. We just have to try both.\n      try {\n        const user = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.newPassIdpParams,\n          RecoveryStatus.NEW_PASSWORD\n        );\n        // New password worked. Let's set to the current password\n\n        // --Potential Failure Point 1--\n        // if changePasswordComplete() doesn't get called, then it should remain\n\n        console.log('New password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        if (error.code !== 'NotAuthorizedException') {\n          throw error;\n        }\n        // pass, try again assuming it's the old password\n      }\n\n      // Now assume it's the previous password. Any exception is allowed to bubble up.\n      try {\n        const user = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.currentPassIdpParams,\n          RecoveryStatus.OLD_PASSWORD\n        );\n        // Old password worked.\n        console.log('Old password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        throw error.code === 'NotAuthorizedException'\n          ? new KcBadRequestException(\n              'The password change request was interrupted, please try to login with both your new and old password'\n            )\n          : error;\n      }\n    }\n\n    // Try against as the TP password reset account\n    if (passIdpApiResult.tpPasswordReset) {\n      try {\n        // TP password reset is in process. We need to try the password against both\n        // original account and the new reset account.\n        const reset = passIdpApiResult.tpPasswordReset;\n        const ret = await this.loginIdpImpl(\n          reset.resetUsername,\n          password,\n          reset.passIdpParams,\n          RecoveryStatus.NONE\n        );\n        ret.isTpPasswordResetUser = true;\n\n        return ret;\n      } catch (err) {\n        // continue, try again as regular user.\n      }\n    }\n\n    // Login as regular user\n    return await this.loginIdpImpl(\n      emailOrPhone,\n      password,\n      passIdpApiResult.currentPassIdpParams,\n      RecoveryStatus.NONE\n    );\n  }\n\n  private async handleSessionEncryptionKey() {\n    if (this.config.disableSessionEncryptionKey) {\n      if (!isDevMode()) {\n        const msg =\n          'You should not set disableSessionEncryptionKey=True in mode prod. It defaults to false.';\n        console.error(msg);\n        throw new Error(msg);\n      } else {\n        console.warn(\n          'You have set disableSessionEncryptionKey=True. Make sure not to do this in prod mode.'\n        );\n      }\n    } else {\n      // Set the session key to a new encryption key for this session\n      const sessionEncryptionKey = await this.keyFactory.createKey();\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: SetSessionEncryptionKeyMutation,\n          variables: {\n            input: {\n              sessionEncryptionKey: JSON.stringify(\n                sessionEncryptionKey.toJSON(true)\n              ),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      );\n\n      this.persistService.setServerSessionEncryptionKey(sessionEncryptionKey);\n    }\n  }\n\n  private async handlePostAuth(cognitoUser: CognitoChallengeUser) {\n    await this.handlePasswordRecovery(cognitoUser);\n    await this.handleSessionEncryptionKey();\n  }\n\n  public async login(\n    emailOrPhone: string,\n    password: CryptoKey,\n    { tpPasswordResetAutoComplete = true }: LoginOptions = {}\n  ) {\n    let loginResult = await this.loginImpl(emailOrPhone, password);\n\n    if (\n      tpPasswordResetAutoComplete &&\n      loginResult.resetUser?.state === TpClaimState.APPROVED\n    ) {\n      await this.completeRequest(password);\n      loginResult = await this.loginImpl(emailOrPhone, password);\n    }\n\n    return loginResult;\n  }\n\n  public async loginImpl(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginResult> {\n    await this.logout();\n    const cognitoUser = await this.loginIdp(emailOrPhone, password);\n\n    // todo: Meet MFA challenges.\n    if (['SMS_MFA', 'SOFTWARE_TOKEN_MFA'].includes(cognitoUser.challengeName)) {\n      return { hasChallenge: true, challenge: cognitoUser };\n    }\n\n    await this.handlePostAuth(cognitoUser);\n\n    if (cognitoUser.isTpPasswordResetUser) {\n      // Assuming there is no MFA on the TP reset user.\n      const resetUser = await this.loadResetUser(password);\n      return { hasChallenge: false, resetUser };\n    } else {\n      const user = await this.loadUser(cognitoUser, password);\n      await this.idleService.start(); // Run idleService whenever user is logged in.\n      return { hasChallenge: false, user };\n    }\n  }\n\n  // TODO <AZ> We need to handle the isTpPasswordResetUser=True case here after MFA as well.\n  public async verifyLogin(\n    challenge: CognitoChallengeUser,\n    password: CryptoKey,\n    rememberMe: boolean,\n    code: string\n  ): Promise<CurrentUser> {\n    await this.auth.confirmSignIn(challenge, code, challenge.challengeName);\n\n    // TODO: this.auth.confirmSignIn() could return another challenge.\n\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n\n    await this.handlePostAuth(challenge);\n\n    const user = await this.loadUser(cognitoUser, password);\n\n    if (rememberMe) {\n      cognitoUser.setDeviceStatusRemembered({\n        onSuccess: () => {\n          return;\n        },\n        onFailure: (e) => console.error(e),\n      });\n    }\n\n    return user;\n  }\n\n  async handlePasswordRecovery(user: CognitoChallengeUser) {\n    if (user.recoveryStatus !== RecoveryStatus.NONE) {\n      await this.passwordService.changePasswordComplete({\n        useNewPassword: user.recoveryStatus === RecoveryStatus.NEW_PASSWORD,\n      });\n    }\n  }\n\n  async getUserOrResetUser(\n    reload = false\n  ): Promise<CurrentUser | TpPasswordResetUser> {\n    const cognitoUser = await this.auth.currentAuthenticatedUser();\n\n    if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {\n      return this.getResetUser(reload);\n    } else {\n      return this.getUser(reload);\n    }\n  }\n\n  async getResetUser(reload = false): Promise<TpPasswordResetUser> {\n    if (!reload && this.currentResetUser) {\n      return this.currentResetUser;\n    }\n\n    this.currentResetUser = await this.loadResetUser();\n\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n\n    return this.currentResetUser;\n  }\n\n  async getUser(reload = false): Promise<CurrentUser> {\n    if (!reload && this.currentUser) {\n      return this.currentUser;\n    }\n    this.currentUser = await this.loadUser(\n      await this.auth.currentAuthenticatedUser()\n    );\n    console.log('Starting idle service.');\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n    return this.currentUser;\n  }\n\n  private mapTPVaultAccess(features?: Features): boolean {\n    const tpVaultFeature = features?.tpVault;\n    return (\n      tpVaultFeature?.length > 0 &&\n      tpVaultFeature.some((feature) => feature.toUpperCase() === 'ACCESS')\n    );\n  }\n\n  private async loadUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    if (currentUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(currentUser.sessionEncryptionKey)\n      );\n    }\n\n    const userAttributes = await this.auth.userAttributes(cognitoUser);\n\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...currentUser.currentUserKey.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          currentUser.currentUserKey.passKey.id,\n          passKey,\n          currentUser.currentUserKey.masterKey.id\n        )\n      );\n    }\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: this.getUserAttribute('sub', userAttributes),\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      email: this.getUserAttribute('email', userAttributes),\n      emailVerified:\n        this.getUserAttribute('email_verified', userAttributes) === 'true',\n      phone: this.getUserAttribute('phone_number', userAttributes),\n      phoneVerified:\n        this.getUserAttribute('phone_number_verified', userAttributes) ===\n        'true',\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n    };\n  }\n\n  public watchAuth() {\n    return this.hubSubject;\n  }\n\n  public async logout(): Promise<void> {\n    // Notify all listeners to clean up.\n    await Promise.all([...this.logoutListeners].map((callback) => callback()));\n\n    this.currentUser = null;\n    this.keyService.purgeKeys();\n    this.keyGraphService.purgeKeys();\n\n    await Promise.all([this.auth.signOut(), this.profileService.signOut()]);\n\n    if (this.config.debug?.username) {\n      this.config.debug.username = null;\n    }\n  }\n\n  private getUserAttribute(\n    attributeName: string,\n    userAttributes: CognitoUserAttribute[]\n  ) {\n    const userAttribute = userAttributes.find(\n      (x) => x.getName() === attributeName\n    );\n\n    return userAttribute ? userAttribute.getValue() : null;\n  }\n\n  private async loadResetUser(\n    password?: CryptoKey\n  ): Promise<TpPasswordResetUser> {\n    const { tpPasswordResetUser: resetUser } = await this.lrGraphQL.query({\n      query: TpPasswordResetUserQuery,\n    });\n\n    if (resetUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(resetUser.sessionEncryptionKey)\n      );\n    }\n\n    // Update the keys\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...resetUser.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          resetUser.passKey.id,\n          passKey,\n          resetUser.masterKey.id\n        )\n      );\n    }\n\n    this.keyService.populateKeys({\n      passKey: {\n        id: resetUser.passKey.id,\n      },\n      masterKey: {\n        id: resetUser.masterKey.id,\n      },\n    });\n\n    const userAttributes = await this.auth.userAttributes(\n      await this.auth.currentAuthenticatedUser()\n    );\n    const sub = this.getUserAttribute('sub', userAttributes);\n\n    return {\n      ...(await this.tpPasswordResetProcessorService.processTpPasswordResetUserNode(\n        resetUser\n      )),\n      sub,\n    };\n  }\n\n  public async refreshAccessToken() {\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n    const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();\n\n    return new Promise((resolve, reject) => {\n      cognitoUser.refreshSession(refreshToken, (err) => {\n        if (err) {\n          console.error('Error refreshing token: ', err);\n          reject(err);\n        } else {\n          console.log('Token refresh complete');\n          resolve(0);\n        }\n      });\n    });\n  }\n\n  async completeRequest(newPassword: CryptoKey): Promise<void> {\n    const resetUser = await this.getResetUser(true);\n\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new KcBadStateException(\n        'Password reset request has not been approved.'\n      );\n    }\n\n    // --------------------------------------------------------------\n    // Prepare all materials to ensure there are no errors.\n    // --------------------------------------------------------------\n    const assemblyKey = await this.recoverAssemblyKey(resetUser);\n\n    const { rootKey } = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.assemblyCipherData\n    );\n\n    // Making sure it's a valid key.\n    const rootKeyJwk = await JWK.asKey(rootKey);\n\n    const masterKey = await this.keyGraphService.getKey(resetUser.masterKey.id);\n\n    const masterKeyWrappedRootKey =\n      await this.encryptionService.encryptToString(\n        masterKey.jwk,\n        rootKeyJwk.toJSON(true)\n      );\n\n    // The new password\n    const newPassIdpResult = await this.keyFactory.derivePassIdp({\n      password: newPassword,\n      ...resetUser.passKey.passIdpParams,\n    });\n\n    const newIdpPassword = this.passwordService.getPassIdpString(\n      newPassIdpResult.jwk\n    );\n\n    // --------------------------------------------------------------\n    // Get assembly key challenge\n    // --------------------------------------------------------------\n    const challenge = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: CreateTpAssemblyKeyChallengeMutation,\n          variables: {\n            input: {},\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).createTpAssemblyKeyChallenge.challenge;\n\n    // Sign the challenge\n    // Generate a client side nonce that's no in the server's control.\n    challenge.clientNonce = this.keyFactory.randomString(\n      TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH\n    );\n\n    const assemblyKeyVerifierPrk = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.wrappedAssemblyKeyVerifierPrk\n    );\n    const signedChallenge = await this.encryptionService.sign(\n      assemblyKeyVerifierPrk,\n      challenge\n    );\n\n    // --------------------------------------------------------------\n    // Change password for the original user\n    // --------------------------------------------------------------\n    const tempIdpPassword = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: PreCompleteTpPasswordResetRequestMutation,\n          variables: {\n            input: {\n              signedChallenge: JSON.stringify(signedChallenge),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).preCompleteTpPasswordResetRequest.idpPassword;\n\n    // --------------------------------------------------------------\n    // Login as the original user using new temporary password\n    // --------------------------------------------------------------\n    // At this point, the original account's password has been changed\n    // to a temporary password. It is no longer possible for the user\n    // to use the original password to login. Any successful login\n    // can only be using the temporary password. So it's safe to assume\n    // that we want to \"complete\" the password reset.\n\n    // The maybe 2FA so we listen for the auth event from Amplify.\n    const retPromise = new Promise<void>((resolve) => {\n      const listener = async (data) => {\n        if (data.payload.event !== 'signIn') {\n          return;\n        }\n\n        Hub.remove('auth', listener);\n\n        await this.auth.signIn(resetUser.username, newIdpPassword);\n\n        // Switch over to the new set of keys\n        await this.lrGraphQL.lrMutate(\n          new LrMutation({\n            mutation: CompleteTpPasswordResetRequestMutation,\n            variables: {\n              input: {\n                masterKeyWrappedRootKey,\n                masterKeyId: masterKey.id,\n              },\n            },\n          })\n        );\n\n        resolve();\n      };\n\n      Hub.listen('auth', listener);\n    });\n\n    // Signin as the original user. Password has been reset to temporary one. It should return\n    // with NEW_PASSWORD_REQUIRED\n    let user = await this.auth.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new KcInternalErrorException(\n        'Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.'\n      );\n    }\n\n    // Set new password on Idp\n    // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without\n    // going through the proxy.\n    user = await this.auth.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: TpPasswordResetUserNode\n  ): Promise<JWK.Key> {\n    const prk = await this.keyGraphService.getKey(resetUser.pxk.id);\n\n    const partials = await Promise.all(\n      resetUser.approvals\n        .filter((approval) => !!approval.receiverCipherPartialAssemblyKey)\n        .map((approval) =>\n          this.encryptionService.decrypt(\n            prk,\n            approval.receiverCipherPartialAssemblyKey\n          )\n        )\n    );\n\n    return this.assemblyController.recoverAssemblyKey(partials);\n  }\n}\n"]}
568
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"life-ready-auth.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/auth/life-ready-auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable, isDevMode } from '@angular/core';\nimport { CognitoUser } from '@aws-amplify/auth';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { Hub } from '@aws-amplify/core';\nimport { CognitoUserAttribute } from 'amazon-cognito-identity-js';\nimport { JWK } from 'node-jose';\nimport { ReplaySubject } from 'rxjs';\nimport { LrGraphQLService, LrMutation } from '../api/lr-graphql';\nimport { TpPasswordResetProcessorService } from '../api/query-processor/tp-password-reset-processor.service';\nimport { TpClaimState, TpPasswordResetUserNode } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { IdleService } from '../idle/idle.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService } from '../key/key.service';\nimport { PassIdpParams } from '../key/key.types';\nimport { KcConfig, KC_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\nimport { PersistService } from '../persist/persist.service';\nimport { ProfileService } from '../profile/profile.service';\nimport { Features, PasswordChangeStatus } from '../profile/profile.types';\nimport {\n  TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH,\n  TP_PASSWORD_RESET_USERNAME_SUFFIX,\n} from '../tp-password-reset/tp-password-reset.constants';\nimport { TpPasswordResetAssemblyController } from '../tp-password-reset/tp-password-reset.controller';\nimport {\n  CompleteTpPasswordResetRequestMutation,\n  CreateTpAssemblyKeyChallengeMutation,\n  PreCompleteTpPasswordResetRequestMutation,\n} from '../tp-password-reset/tp-password-reset.gql';\nimport { TpPasswordResetUserQuery } from '../tp-password-reset/tp-password-reset.private.gql';\nimport {\n  KcBadRequestException,\n  KcBadStateException,\n  KcConcurrentAccessException,\n  KcInternalErrorException,\n} from '../_common/exceptions';\nimport { getAccessJwtToken } from '../_common/utils';\nimport { SetSessionEncryptionKeyMutation } from './auth.gql';\nimport {\n  CognitoChallengeUser,\n  CurrentUser,\n  LoginResult,\n  RecoveryStatus,\n  TpPasswordResetUser,\n} from './auth.types';\n\nexport const initialiseAuth = (authService: LifeReadyAuthService) => {\n  return () => authService.initialise();\n};\n\nexport interface LoginOptions {\n  tpPasswordResetAutoComplete?: boolean;\n}\n\nexport type LogoutListener = () => void | Promise<void>;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LifeReadyAuthService {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private hubSubject: ReplaySubject<any> = new ReplaySubject<any>(1);\n  private currentUser: CurrentUser;\n  private currentResetUser: TpPasswordResetUser;\n  // Could use rxjs observables here. But trying to have kc-client use as little angular\n  // features as possible. Rxjs is not used anywhere else in kc-client.\n  private logoutListeners = new Set<LogoutListener>();\n\n  constructor(\n    @Inject(KC_CONFIG) private config: KcConfig,\n    private auth: AuthClass,\n    private keyFactory: KeyFactoryService,\n    private keyService: KeyService,\n    private profileService: ProfileService,\n    private keyGraphService: KeyGraphService,\n    private passwordService: PasswordService,\n    private idleService: IdleService,\n    private lrGraphQL: LrGraphQLService,\n    private tpPasswordResetProcessorService: TpPasswordResetProcessorService,\n    private persistService: PersistService,\n    private encryptionService: EncryptionService,\n    private assemblyController: TpPasswordResetAssemblyController,\n    private http: HttpClient\n  ) {\n    if (!isDevMode()) {\n      if (this.config.debug != null) {\n        throw new KcBadRequestException(\n          'In production mode, \"config.debug\" must be set to null'\n        );\n      }\n    }\n  }\n\n  async initialise() {\n    Hub.listen('auth', (data) => this.hubSubject.next(data.payload));\n  }\n\n  public debugLogin(username: string, password: CryptoKey) {\n    // This will fail if debug is null. But when debug is null, this function\n    // should not be called.\n    this.config.debug.username = username;\n\n    return this.debugLoadUser(password);\n  }\n\n  // ------------------------------------------------------------------------\n  // ------------------------------------------------------------------------\n  // ------------------------------------------------------------------------\n  /**\n   * Login using the server side session method.\n   */\n  private debugLoginUsingSession(username: string) {\n    return this.http\n      .get(\n        this.config.apiUrl +\n          'debug_only/users/login/?username=' +\n          encodeURIComponent(username),\n        {\n          // Non-obvious alert: if you want the cookies to be set, you must use the\n          // \"withCredentials\" header. I would have thought the withCredentials header\n          // is only used to send the cookies with the requests. But, if you don't include\n          // the \"withCredentials\" header, the cookies in the response DOES NOT get set!\n          //\n          // ref: https://github.com/github/fetch/issues/386#issuecomment-243229388\n          withCredentials: true,\n        }\n      )\n      .toPromise();\n  }\n\n  private async debugLoadUser(password: CryptoKey): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    // Debug mode can not deal with session encryption key yet.\n    // NO SESSION ENCRYPTION KEY.\n\n    const passKey = (\n      await this.keyFactory.derivePassKey({\n        password,\n        ...currentUser.currentUserKey.passKey.passKeyParams,\n      })\n    ).jwk;\n\n    const masterKey = await this.keyGraphService.unwrapWithPassKey(\n      currentUser.currentUserKey.passKey.id,\n      passKey,\n      currentUser.currentUserKey.masterKey.id\n    );\n\n    await this.idleService.persistMasterKey(masterKey);\n\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: 'DEBUG_MODE',\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      email: 'DEBUG_MODE',\n      emailVerified: false,\n      phone: 'DEBUG_MODE',\n      phoneVerified: false,\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n      dateJoined: currentUser.dateJoined,\n    };\n  }\n\n  async getAccessJwtToken(): Promise<string> {\n    return getAccessJwtToken(this.auth);\n  }\n\n  importPassword(plainPassword: string): Promise<CryptoKey> {\n    return this.keyFactory.importPassword(plainPassword);\n  }\n\n  addLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.add(callback);\n  }\n\n  removeLogoutListener(callback: LogoutListener) {\n    this.logoutListeners.delete(callback);\n  }\n\n  private async loginIdpImpl(\n    emailOrPhone: string,\n    password: CryptoKey,\n    passIdpParams: PassIdpParams,\n    recoveryStatus: RecoveryStatus\n  ): Promise<CognitoChallengeUser> {\n    const passIdpResult = await this.keyFactory.derivePassIdp({\n      password,\n      ...passIdpParams,\n    });\n    // Use the derived password to signin with cognito\n    const user = await this.auth.signIn(\n      emailOrPhone,\n      this.passwordService.getPassIdpString(passIdpResult.jwk)\n    );\n\n    user.recoveryStatus = recoveryStatus;\n\n    return user;\n  }\n\n  private async loginIdp(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<CognitoChallengeUser> {\n    // Download the salt needed to derive the PassIdp\n    const passIdpApiResult = await this.profileService.getPassIdpParams(\n      emailOrPhone\n    );\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.InProgress\n    ) {\n      throw new KcConcurrentAccessException('A password change is in progress');\n    }\n\n    if (\n      passIdpApiResult.passwordChangeStatus === PasswordChangeStatus.Recovery\n    ) {\n      console.log('In recovery mode.');\n      // Let's say we don't know if the password is the new one or the old one. We just have to try both.\n      try {\n        const user = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.newPassIdpParams,\n          RecoveryStatus.NEW_PASSWORD\n        );\n        // New password worked. Let's set to the current password\n\n        // --Potential Failure Point 1--\n        // if changePasswordComplete() doesn't get called, then it should remain\n\n        console.log('New password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        if (error.code !== 'NotAuthorizedException') {\n          throw error;\n        }\n        // pass, try again assuming it's the old password\n      }\n\n      // Now assume it's the previous password. Any exception is allowed to bubble up.\n      try {\n        const user = await this.loginIdpImpl(\n          emailOrPhone,\n          password,\n          passIdpApiResult.currentPassIdpParams,\n          RecoveryStatus.OLD_PASSWORD\n        );\n        // Old password worked.\n        console.log('Old password works!');\n\n        return user;\n      } catch (error) {\n        // Just bubble up any other type of error.\n        throw error.code === 'NotAuthorizedException'\n          ? new KcBadRequestException(\n              'The password change request was interrupted, please try to login with both your new and old password'\n            )\n          : error;\n      }\n    }\n\n    // Try against as the TP password reset account\n    if (passIdpApiResult.tpPasswordReset) {\n      try {\n        // TP password reset is in process. We need to try the password against both\n        // original account and the new reset account.\n        const reset = passIdpApiResult.tpPasswordReset;\n        const ret = await this.loginIdpImpl(\n          reset.resetUsername,\n          password,\n          reset.passIdpParams,\n          RecoveryStatus.NONE\n        );\n        ret.isTpPasswordResetUser = true;\n\n        return ret;\n      } catch (err) {\n        // continue, try again as regular user.\n      }\n    }\n\n    // Login as regular user\n    return await this.loginIdpImpl(\n      emailOrPhone,\n      password,\n      passIdpApiResult.currentPassIdpParams,\n      RecoveryStatus.NONE\n    );\n  }\n\n  private async handleSessionEncryptionKey() {\n    if (this.config.disableSessionEncryptionKey) {\n      if (!isDevMode()) {\n        const msg =\n          'You should not set disableSessionEncryptionKey=True in mode prod. It defaults to false.';\n        console.error(msg);\n        throw new Error(msg);\n      } else {\n        console.warn(\n          'You have set disableSessionEncryptionKey=True. Make sure not to do this in prod mode.'\n        );\n      }\n    } else {\n      // Set the session key to a new encryption key for this session\n      const sessionEncryptionKey = await this.keyFactory.createKey();\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: SetSessionEncryptionKeyMutation,\n          variables: {\n            input: {\n              sessionEncryptionKey: JSON.stringify(\n                sessionEncryptionKey.toJSON(true)\n              ),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      );\n\n      this.persistService.setServerSessionEncryptionKey(sessionEncryptionKey);\n    }\n  }\n\n  private async handlePostAuth(cognitoUser: CognitoChallengeUser) {\n    await this.handlePasswordRecovery(cognitoUser);\n    await this.handleSessionEncryptionKey();\n  }\n\n  public async login(\n    emailOrPhone: string,\n    password: CryptoKey,\n    { tpPasswordResetAutoComplete = true }: LoginOptions = {}\n  ) {\n    let loginResult = await this.loginImpl(emailOrPhone, password);\n\n    if (\n      tpPasswordResetAutoComplete &&\n      loginResult.resetUser?.state === TpClaimState.APPROVED\n    ) {\n      await this.completeRequest(password);\n      loginResult = await this.loginImpl(emailOrPhone, password);\n    }\n\n    return loginResult;\n  }\n\n  public async loginImpl(\n    emailOrPhone: string,\n    password: CryptoKey\n  ): Promise<LoginResult> {\n    await this.logout();\n    const cognitoUser = await this.loginIdp(emailOrPhone, password);\n\n    // todo: Meet MFA challenges.\n    if (['SMS_MFA', 'SOFTWARE_TOKEN_MFA'].includes(cognitoUser.challengeName)) {\n      return { hasChallenge: true, challenge: cognitoUser };\n    }\n\n    await this.handlePostAuth(cognitoUser);\n\n    if (cognitoUser.isTpPasswordResetUser) {\n      // Assuming there is no MFA on the TP reset user.\n      const resetUser = await this.loadResetUser(password);\n      return { hasChallenge: false, resetUser };\n    } else {\n      const user = await this.loadUser(cognitoUser, password);\n      await this.idleService.start(); // Run idleService whenever user is logged in.\n      return { hasChallenge: false, user };\n    }\n  }\n\n  // TODO <AZ> We need to handle the isTpPasswordResetUser=True case here after MFA as well.\n  public async verifyLogin(\n    challenge: CognitoChallengeUser,\n    password: CryptoKey,\n    rememberMe: boolean,\n    code: string\n  ): Promise<CurrentUser> {\n    await this.auth.confirmSignIn(challenge, code, challenge.challengeName);\n\n    // TODO: this.auth.confirmSignIn() could return another challenge.\n\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n\n    await this.handlePostAuth(challenge);\n\n    const user = await this.loadUser(cognitoUser, password);\n\n    if (rememberMe) {\n      cognitoUser.setDeviceStatusRemembered({\n        onSuccess: () => {\n          return;\n        },\n        onFailure: (e) => console.error(e),\n      });\n    }\n\n    return user;\n  }\n\n  async handlePasswordRecovery(user: CognitoChallengeUser) {\n    if (user.recoveryStatus !== RecoveryStatus.NONE) {\n      await this.passwordService.changePasswordComplete({\n        useNewPassword: user.recoveryStatus === RecoveryStatus.NEW_PASSWORD,\n      });\n    }\n  }\n\n  async getUserOrResetUser(\n    reload = false\n  ): Promise<CurrentUser | TpPasswordResetUser> {\n    const cognitoUser = await this.auth.currentAuthenticatedUser();\n\n    if (cognitoUser.getUsername().endsWith(TP_PASSWORD_RESET_USERNAME_SUFFIX)) {\n      return this.getResetUser(reload);\n    } else {\n      return this.getUser(reload);\n    }\n  }\n\n  async getResetUser(reload = false): Promise<TpPasswordResetUser> {\n    if (!reload && this.currentResetUser) {\n      return this.currentResetUser;\n    }\n\n    this.currentResetUser = await this.loadResetUser();\n\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n\n    return this.currentResetUser;\n  }\n\n  async getUser(reload = false): Promise<CurrentUser> {\n    if (!reload && this.currentUser) {\n      return this.currentUser;\n    }\n    this.currentUser = await this.loadUser(\n      await this.auth.currentAuthenticatedUser()\n    );\n    console.log('Starting idle service.');\n    await this.idleService.start(); // Run idleService whenever user is logged in.\n    return this.currentUser;\n  }\n\n  private mapTPVaultAccess(features?: Features): boolean {\n    const tpVaultFeature = features?.tpVault;\n    return (\n      tpVaultFeature?.length > 0 &&\n      tpVaultFeature.some((feature) => feature.toUpperCase() === 'ACCESS')\n    );\n  }\n\n  private async loadUser(\n    cognitoUser: CognitoUser,\n    password?: CryptoKey\n  ): Promise<CurrentUser> {\n    const { currentUser, contactCard, userPlans } =\n      await this.profileService.getCurrentUser();\n\n    if (currentUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(currentUser.sessionEncryptionKey)\n      );\n    }\n\n    const userAttributes = await this.auth.userAttributes(cognitoUser);\n\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...currentUser.currentUserKey.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          currentUser.currentUserKey.passKey.id,\n          passKey,\n          currentUser.currentUserKey.masterKey.id\n        )\n      );\n    }\n    await this.keyGraphService.populateKeys(currentUser.currentUserKey);\n\n    return {\n      id: currentUser.id,\n      sub: this.getUserAttribute('sub', userAttributes),\n      username: currentUser.username,\n      currentUserKey: currentUser.currentUserKey,\n      email: this.getUserAttribute('email', userAttributes),\n      emailVerified:\n        this.getUserAttribute('email_verified', userAttributes) === 'true',\n      phone: this.getUserAttribute('phone_number', userAttributes),\n      phoneVerified:\n        this.getUserAttribute('phone_number_verified', userAttributes) ===\n        'true',\n      contactCard: {\n        ...(await this.profileService.decryptContactCard(contactCard)),\n      },\n      userDelete: currentUser.userDelete,\n      userPlans,\n      hasTPVaultAccess: this.mapTPVaultAccess(currentUser.features),\n      features: currentUser.features,\n      sessionEncryptionKey: currentUser.sessionEncryptionKey,\n      dateJoined: currentUser.dateJoined,\n    };\n  }\n\n  public watchAuth() {\n    return this.hubSubject;\n  }\n\n  public async logout(): Promise<void> {\n    // Notify all listeners to clean up.\n    await Promise.all([...this.logoutListeners].map((callback) => callback()));\n\n    this.currentUser = null;\n    this.keyService.purgeKeys();\n    this.keyGraphService.purgeKeys();\n\n    await Promise.all([this.auth.signOut(), this.profileService.signOut()]);\n\n    if (this.config.debug?.username) {\n      this.config.debug.username = null;\n    }\n  }\n\n  private getUserAttribute(\n    attributeName: string,\n    userAttributes: CognitoUserAttribute[]\n  ) {\n    const userAttribute = userAttributes.find(\n      (x) => x.getName() === attributeName\n    );\n\n    return userAttribute ? userAttribute.getValue() : null;\n  }\n\n  private async loadResetUser(\n    password?: CryptoKey\n  ): Promise<TpPasswordResetUser> {\n    const { tpPasswordResetUser: resetUser } = await this.lrGraphQL.query({\n      query: TpPasswordResetUserQuery,\n    });\n\n    if (resetUser.sessionEncryptionKey) {\n      this.persistService.setServerSessionEncryptionKey(\n        await JWK.asKey(resetUser.sessionEncryptionKey)\n      );\n    }\n\n    // Update the keys\n    if (password) {\n      const passKey = (\n        await this.keyFactory.derivePassKey({\n          password,\n          ...resetUser.passKey.passKeyParams,\n        })\n      ).jwk;\n\n      await this.idleService.persistMasterKey(\n        await this.keyGraphService.unwrapWithPassKey(\n          resetUser.passKey.id,\n          passKey,\n          resetUser.masterKey.id\n        )\n      );\n    }\n\n    this.keyService.populateKeys({\n      passKey: {\n        id: resetUser.passKey.id,\n      },\n      masterKey: {\n        id: resetUser.masterKey.id,\n      },\n    });\n\n    const userAttributes = await this.auth.userAttributes(\n      await this.auth.currentAuthenticatedUser()\n    );\n    const sub = this.getUserAttribute('sub', userAttributes);\n\n    return {\n      ...(await this.tpPasswordResetProcessorService.processTpPasswordResetUserNode(\n        resetUser\n      )),\n      sub,\n    };\n  }\n\n  public async refreshAccessToken() {\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n    const refreshToken = cognitoUser.getSignInUserSession().getRefreshToken();\n\n    return new Promise((resolve, reject) => {\n      cognitoUser.refreshSession(refreshToken, (err) => {\n        if (err) {\n          console.error('Error refreshing token: ', err);\n          reject(err);\n        } else {\n          console.log('Token refresh complete');\n          resolve(0);\n        }\n      });\n    });\n  }\n\n  async completeRequest(newPassword: CryptoKey): Promise<void> {\n    const resetUser = await this.getResetUser(true);\n\n    if (resetUser.state !== TpClaimState.APPROVED) {\n      throw new KcBadStateException(\n        'Password reset request has not been approved.'\n      );\n    }\n\n    // --------------------------------------------------------------\n    // Prepare all materials to ensure there are no errors.\n    // --------------------------------------------------------------\n    const assemblyKey = await this.recoverAssemblyKey(resetUser);\n\n    const { rootKey } = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.assemblyCipherData\n    );\n\n    // Making sure it's a valid key.\n    const rootKeyJwk = await JWK.asKey(rootKey);\n\n    const masterKey = await this.keyGraphService.getKey(resetUser.masterKey.id);\n\n    const masterKeyWrappedRootKey =\n      await this.encryptionService.encryptToString(\n        masterKey.jwk,\n        rootKeyJwk.toJSON(true)\n      );\n\n    // The new password\n    const newPassIdpResult = await this.keyFactory.derivePassIdp({\n      password: newPassword,\n      ...resetUser.passKey.passIdpParams,\n    });\n\n    const newIdpPassword = this.passwordService.getPassIdpString(\n      newPassIdpResult.jwk\n    );\n\n    // --------------------------------------------------------------\n    // Get assembly key challenge\n    // --------------------------------------------------------------\n    const challenge = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: CreateTpAssemblyKeyChallengeMutation,\n          variables: {\n            input: {},\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).createTpAssemblyKeyChallenge.challenge;\n\n    // Sign the challenge\n    // Generate a client side nonce that's no in the server's control.\n    challenge.clientNonce = this.keyFactory.randomString(\n      TP_PASSWORD_RESET_CLIENT_NONCE_LENGTH\n    );\n\n    const assemblyKeyVerifierPrk = await this.encryptionService.decrypt(\n      assemblyKey,\n      resetUser.wrappedAssemblyKeyVerifierPrk\n    );\n    const signedChallenge = await this.encryptionService.sign(\n      assemblyKeyVerifierPrk,\n      challenge\n    );\n\n    // --------------------------------------------------------------\n    // Change password for the original user\n    // --------------------------------------------------------------\n    const tempIdpPassword = (\n      await this.lrGraphQL.lrMutate(\n        new LrMutation({\n          mutation: PreCompleteTpPasswordResetRequestMutation,\n          variables: {\n            input: {\n              signedChallenge: JSON.stringify(signedChallenge),\n            },\n          },\n        }),\n        {\n          includeKeyGraph: false,\n        }\n      )\n    ).preCompleteTpPasswordResetRequest.idpPassword;\n\n    // --------------------------------------------------------------\n    // Login as the original user using new temporary password\n    // --------------------------------------------------------------\n    // At this point, the original account's password has been changed\n    // to a temporary password. It is no longer possible for the user\n    // to use the original password to login. Any successful login\n    // can only be using the temporary password. So it's safe to assume\n    // that we want to \"complete\" the password reset.\n\n    // The maybe 2FA so we listen for the auth event from Amplify.\n    const retPromise = new Promise<void>((resolve) => {\n      const listener = async (data) => {\n        if (data.payload.event !== 'signIn') {\n          return;\n        }\n\n        Hub.remove('auth', listener);\n\n        await this.auth.signIn(resetUser.username, newIdpPassword);\n\n        // Switch over to the new set of keys\n        await this.lrGraphQL.lrMutate(\n          new LrMutation({\n            mutation: CompleteTpPasswordResetRequestMutation,\n            variables: {\n              input: {\n                masterKeyWrappedRootKey,\n                masterKeyId: masterKey.id,\n              },\n            },\n          })\n        );\n\n        resolve();\n      };\n\n      Hub.listen('auth', listener);\n    });\n\n    // Signin as the original user. Password has been reset to temporary one. It should return\n    // with NEW_PASSWORD_REQUIRED\n    let user = await this.auth.signIn(resetUser.username, tempIdpPassword, {\n      noProxy: 'true',\n    });\n\n    if (user.challengeName !== 'NEW_PASSWORD_REQUIRED') {\n      throw new KcInternalErrorException(\n        'Expecting Cognito to have done a password reset after call to PreCompleteTpPasswordResetRequestMutation.'\n      );\n    }\n\n    // Set new password on Idp\n    // the awsFetch() function passes NEW_PASSWORD_REQUIRED directly to AWS without\n    // going through the proxy.\n    user = await this.auth.completeNewPassword(user, newIdpPassword, {});\n\n    return retPromise;\n  }\n\n  private async recoverAssemblyKey(\n    resetUser: TpPasswordResetUserNode\n  ): Promise<JWK.Key> {\n    const prk = await this.keyGraphService.getKey(resetUser.pxk.id);\n\n    const partials = await Promise.all(\n      resetUser.approvals\n        .filter((approval) => !!approval.receiverCipherPartialAssemblyKey)\n        .map((approval) =>\n          this.encryptionService.decrypt(\n            prk,\n            approval.receiverCipherPartialAssemblyKey\n          )\n        )\n    );\n\n    return this.assemblyController.recoverAssemblyKey(partials);\n  }\n}\n"]}