@nest-boot/auth 7.9.2 → 7.9.4

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.
Files changed (52) hide show
  1. package/dist/adapters/mikro-orm-adapter.d.ts +6 -1
  2. package/dist/adapters/mikro-orm-adapter.js +17 -1
  3. package/dist/adapters/mikro-orm-adapter.js.map +1 -1
  4. package/dist/adapters/mikro-orm-adapter.spec.d.ts +8 -0
  5. package/dist/adapters/mikro-orm-adapter.spec.js +165 -0
  6. package/dist/adapters/mikro-orm-adapter.spec.js.map +1 -0
  7. package/dist/auth-module-options.interface.d.ts +9 -0
  8. package/dist/auth.constants.d.ts +2 -0
  9. package/dist/auth.constants.js +2 -0
  10. package/dist/auth.constants.js.map +1 -1
  11. package/dist/auth.guard.d.ts +15 -0
  12. package/dist/auth.guard.js +15 -0
  13. package/dist/auth.guard.js.map +1 -1
  14. package/dist/auth.middleware.d.ts +21 -0
  15. package/dist/auth.middleware.js +21 -0
  16. package/dist/auth.middleware.js.map +1 -1
  17. package/dist/auth.module-definition.d.ts +1 -1
  18. package/dist/auth.module-definition.js +2 -2
  19. package/dist/auth.module-definition.js.map +1 -1
  20. package/dist/auth.module.d.ts +28 -1
  21. package/dist/auth.module.js +30 -0
  22. package/dist/auth.module.js.map +1 -1
  23. package/dist/auth.service.d.ts +7 -0
  24. package/dist/auth.service.js +6 -0
  25. package/dist/auth.service.js.map +1 -1
  26. package/dist/auth.transaction-context.d.ts +24 -5
  27. package/dist/auth.transaction-context.js +16 -0
  28. package/dist/auth.transaction-context.js.map +1 -1
  29. package/dist/decorators/current-session.decorator.d.ts +1 -0
  30. package/dist/decorators/current-session.decorator.js +1 -0
  31. package/dist/decorators/current-session.decorator.js.map +1 -1
  32. package/dist/decorators/current-user.decorator.d.ts +1 -0
  33. package/dist/decorators/current-user.decorator.js +1 -0
  34. package/dist/decorators/current-user.decorator.js.map +1 -1
  35. package/dist/decorators/public.decorator.d.ts +1 -0
  36. package/dist/decorators/public.decorator.js +1 -0
  37. package/dist/decorators/public.decorator.js.map +1 -1
  38. package/dist/entities/account.entity.d.ts +20 -0
  39. package/dist/entities/account.entity.js +10 -0
  40. package/dist/entities/account.entity.js.map +1 -1
  41. package/dist/entities/session.entity.d.ts +15 -0
  42. package/dist/entities/session.entity.js +10 -0
  43. package/dist/entities/session.entity.js.map +1 -1
  44. package/dist/entities/user.entity.d.ts +14 -0
  45. package/dist/entities/user.entity.js +10 -0
  46. package/dist/entities/user.entity.js.map +1 -1
  47. package/dist/entities/verification.entity.d.ts +13 -0
  48. package/dist/entities/verification.entity.js +10 -0
  49. package/dist/entities/verification.entity.js.map +1 -1
  50. package/dist/tsconfig.build.tsbuildinfo +1 -1
  51. package/package.json +10 -5
  52. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,11 +1,30 @@
1
- type LowercaseLetter = "a" | "b" | "c" | "d" | "e" | "f" | "g" | "h" | "i" | "j" | "k" | "l" | "m" | "n" | "o" | "p" | "q" | "r" | "s" | "t" | "u" | "v" | "w" | "x" | "y" | "z";
2
- type ValidChar = LowercaseLetter | "_";
3
- type IsValidSnakeCase<S extends string> = S extends `${infer First}${infer Rest}` ? First extends ValidChar ? IsValidSnakeCase<Rest> : false : true;
4
- type SnakeCase<S extends string> = S extends "" ? never : S extends `_${string}` | `${string}_` ? never : S extends `${string}__${string}` ? never : IsValidSnakeCase<S> extends true ? S : never;
1
+ /** Union of all lowercase letter characters (a–z). */
2
+ export type LowercaseLetter = "a" | "b" | "c" | "d" | "e" | "f" | "g" | "h" | "i" | "j" | "k" | "l" | "m" | "n" | "o" | "p" | "q" | "r" | "s" | "t" | "u" | "v" | "w" | "x" | "y" | "z";
3
+ /** Characters allowed in snake_case identifiers (lowercase letters and underscore). */
4
+ export type ValidChar = LowercaseLetter | "_";
5
+ /** Recursively validates that a string contains only valid snake_case characters. */
6
+ export type IsValidSnakeCase<S extends string> = S extends `${infer First}${infer Rest}` ? First extends ValidChar ? IsValidSnakeCase<Rest> : false : true;
7
+ /** Ensures a string literal is a valid snake_case identifier. */
8
+ export type SnakeCase<S extends string> = S extends "" ? never : S extends `_${string}` | `${string}_` ? never : S extends `${string}__${string}` ? never : IsValidSnakeCase<S> extends true ? S : never;
9
+ /**
10
+ * Stores key-value pairs for PostgreSQL transaction-level auth context.
11
+ *
12
+ * @remarks
13
+ * Values set here are emitted as `set_config('auth.<key>', '<value>', true)` SQL
14
+ * statements, enabling row-level security policies to access auth state.
15
+ */
5
16
  export declare class AuthTransactionContext {
17
+ /** Internal storage for transaction context key-value pairs. @internal */
6
18
  private readonly ctx;
19
+ /**
20
+ * Sets a snake_case key-value pair in the transaction context.
21
+ * @param key - Must be a valid snake_case string
22
+ * @param value - The string value to associate with the key
23
+ * @returns This instance for chaining
24
+ */
7
25
  set<S extends string>(key: SnakeCase<S>, value: string): this;
26
+ /** Returns all stored key-value pairs as an array of `[key, value]` tuples. */
8
27
  entries(): [string, string][];
28
+ /** Generates a SQL statement that sets all stored values as PostgreSQL transaction-local config variables. */
9
29
  toSQL(): string;
10
30
  }
11
- export {};
@@ -1,10 +1,24 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AuthTransactionContext = void 0;
4
+ /**
5
+ * Stores key-value pairs for PostgreSQL transaction-level auth context.
6
+ *
7
+ * @remarks
8
+ * Values set here are emitted as `set_config('auth.<key>', '<value>', true)` SQL
9
+ * statements, enabling row-level security policies to access auth state.
10
+ */
4
11
  class AuthTransactionContext {
5
12
  constructor() {
13
+ /** Internal storage for transaction context key-value pairs. @internal */
6
14
  this.ctx = new Map();
7
15
  }
16
+ /**
17
+ * Sets a snake_case key-value pair in the transaction context.
18
+ * @param key - Must be a valid snake_case string
19
+ * @param value - The string value to associate with the key
20
+ * @returns This instance for chaining
21
+ */
8
22
  set(key, value) {
9
23
  if (!/^[a-z]+(_[a-z]+)*$/.test(key)) {
10
24
  throw new Error(`Key must only contain lowercase letters and underscores, cannot start/end with underscore, and cannot have consecutive underscores: ${key}`);
@@ -12,9 +26,11 @@ class AuthTransactionContext {
12
26
  this.ctx.set(key, value);
13
27
  return this;
14
28
  }
29
+ /** Returns all stored key-value pairs as an array of `[key, value]` tuples. */
15
30
  entries() {
16
31
  return Array.from(this.ctx.entries());
17
32
  }
33
+ /** Generates a SQL statement that sets all stored values as PostgreSQL transaction-local config variables. */
18
34
  toSQL() {
19
35
  return /* SQL */ `SELECT ${Array.from(this.ctx.entries())
20
36
  .map(([key, value]) => {
@@ -1 +1 @@
1
- {"version":3,"file":"auth.transaction-context.js","sourceRoot":"","sources":["../src/auth.transaction-context.ts"],"names":[],"mappings":";;;AA+CA,MAAa,sBAAsB;IAAnC;QACmB,QAAG,GAAG,IAAI,GAAG,EAAkB,CAAC;IAwBnD,CAAC;IAtBC,GAAG,CAAmB,GAAiB,EAAE,KAAa;QACpD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CACb,uIAAuI,GAAG,EAAE,CAC7I,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO;QACL,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,KAAK;QACH,OAAO,SAAS,CAAC,UAAU,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;aACtD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACpB,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC/C,OAAO,SAAS,CAAC,oBAAoB,GAAG,OAAO,YAAY,UAAU,CAAC;QACxE,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;IAClB,CAAC;CACF;AAzBD,wDAyBC"}
1
+ {"version":3,"file":"auth.transaction-context.js","sourceRoot":"","sources":["../src/auth.transaction-context.ts"],"names":[],"mappings":";;;AAmDA;;;;;;GAMG;AACH,MAAa,sBAAsB;IAAnC;QACE,0EAA0E;QACzD,QAAG,GAAG,IAAI,GAAG,EAAkB,CAAC;IAgCnD,CAAC;IA9BC;;;;;OAKG;IACH,GAAG,CAAmB,GAAiB,EAAE,KAAa;QACpD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CACb,uIAAuI,GAAG,EAAE,CAC7I,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+EAA+E;IAC/E,OAAO;QACL,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,8GAA8G;IAC9G,KAAK;QACH,OAAO,SAAS,CAAC,UAAU,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;aACtD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACpB,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC/C,OAAO,SAAS,CAAC,oBAAoB,GAAG,OAAO,YAAY,UAAU,CAAC;QACxE,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;IAClB,CAAC;CACF;AAlCD,wDAkCC"}
@@ -1 +1,2 @@
1
+ /** Parameter decorator that injects the current {@link BaseSession} from the request context. */
1
2
  export declare const CurrentSession: (...dataOrPipes: any[]) => ParameterDecorator;
@@ -4,5 +4,6 @@ exports.CurrentSession = void 0;
4
4
  const request_context_1 = require("@nest-boot/request-context");
5
5
  const common_1 = require("@nestjs/common");
6
6
  const session_entity_1 = require("../entities/session.entity");
7
+ /** Parameter decorator that injects the current {@link BaseSession} from the request context. */
7
8
  exports.CurrentSession = (0, common_1.createParamDecorator)(() => request_context_1.RequestContext.get(session_entity_1.BaseSession));
8
9
  //# sourceMappingURL=current-session.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"current-session.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-session.decorator.ts"],"names":[],"mappings":";;;AAAA,gEAA4D;AAC5D,2CAAsD;AAEtD,+DAAyD;AAE5C,QAAA,cAAc,GAAG,IAAA,6BAAoB,EAAC,GAAG,EAAE,CACtD,gCAAc,CAAC,GAAG,CAAC,4BAAW,CAAC,CAChC,CAAC"}
1
+ {"version":3,"file":"current-session.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-session.decorator.ts"],"names":[],"mappings":";;;AAAA,gEAA4D;AAC5D,2CAAsD;AAEtD,+DAAyD;AAEzD,iGAAiG;AACpF,QAAA,cAAc,GAAG,IAAA,6BAAoB,EAAC,GAAG,EAAE,CACtD,gCAAc,CAAC,GAAG,CAAC,4BAAW,CAAC,CAChC,CAAC"}
@@ -1 +1,2 @@
1
+ /** Parameter decorator that injects the current {@link BaseUser} from the request context. */
1
2
  export declare const CurrentUser: (...dataOrPipes: any[]) => ParameterDecorator;
@@ -4,5 +4,6 @@ exports.CurrentUser = void 0;
4
4
  const request_context_1 = require("@nest-boot/request-context");
5
5
  const common_1 = require("@nestjs/common");
6
6
  const user_entity_1 = require("../entities/user.entity");
7
+ /** Parameter decorator that injects the current {@link BaseUser} from the request context. */
7
8
  exports.CurrentUser = (0, common_1.createParamDecorator)(() => request_context_1.RequestContext.get(user_entity_1.BaseUser));
8
9
  //# sourceMappingURL=current-user.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"current-user.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-user.decorator.ts"],"names":[],"mappings":";;;AAAA,gEAA4D;AAC5D,2CAAsD;AAEtD,yDAAmD;AAEtC,QAAA,WAAW,GAAG,IAAA,6BAAoB,EAAC,GAAG,EAAE,CACnD,gCAAc,CAAC,GAAG,CAAC,sBAAQ,CAAC,CAC7B,CAAC"}
1
+ {"version":3,"file":"current-user.decorator.js","sourceRoot":"","sources":["../../src/decorators/current-user.decorator.ts"],"names":[],"mappings":";;;AAAA,gEAA4D;AAC5D,2CAAsD;AAEtD,yDAAmD;AAEnD,8FAA8F;AACjF,QAAA,WAAW,GAAG,IAAA,6BAAoB,EAAC,GAAG,EAAE,CACnD,gCAAc,CAAC,GAAG,CAAC,sBAAQ,CAAC,CAC7B,CAAC"}
@@ -1,2 +1,3 @@
1
1
  import { IS_PUBLIC_KEY } from "../auth.constants";
2
+ /** Decorator that marks a route as public, bypassing the {@link AuthGuard}. */
2
3
  export declare const Public: (value?: boolean) => import("@nestjs/common").CustomDecorator<typeof IS_PUBLIC_KEY>;
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Public = void 0;
4
4
  const common_1 = require("@nestjs/common");
5
5
  const auth_constants_1 = require("../auth.constants");
6
+ /** Decorator that marks a route as public, bypassing the {@link AuthGuard}. */
6
7
  const Public = (value = true) => (0, common_1.SetMetadata)(auth_constants_1.IS_PUBLIC_KEY, value);
7
8
  exports.Public = Public;
8
9
  //# sourceMappingURL=public.decorator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"public.decorator.js","sourceRoot":"","sources":["../../src/decorators/public.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAE7C,sDAAkD;AAE3C,MAAM,MAAM,GAAG,CAAC,KAAK,GAAG,IAAI,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,8BAAa,EAAE,KAAK,CAAC,CAAC;AAA7D,QAAA,MAAM,UAAuD"}
1
+ {"version":3,"file":"public.decorator.js","sourceRoot":"","sources":["../../src/decorators/public.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAE7C,sDAAkD;AAElD,+EAA+E;AACxE,MAAM,MAAM,GAAG,CAAC,KAAK,GAAG,IAAI,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,8BAAa,EAAE,KAAK,CAAC,CAAC;AAA7D,QAAA,MAAM,UAAuD"}
@@ -1,16 +1,36 @@
1
1
  import { BaseEntity, Opt } from "@mikro-orm/core";
2
+ /**
3
+ * Abstract base entity for OAuth/credential account records.
4
+ *
5
+ * @remarks
6
+ * Maps to the better-auth `account` model. Each account links a provider
7
+ * (e.g. Google, GitHub, credentials) to a {@link BaseUser}.
8
+ */
2
9
  export declare abstract class BaseAccount extends BaseEntity {
10
+ /** Primary key (UUID v4, auto-generated). */
3
11
  id: Opt<string>;
12
+ /** Provider-scoped account identifier. */
4
13
  accountId: string;
14
+ /** Authentication provider identifier (e.g. `"google"`, `"credential"`). */
5
15
  providerId: string;
16
+ /** Foreign key referencing the owning {@link BaseUser}. */
6
17
  userId: string;
18
+ /** OAuth access token, if available. */
7
19
  accessToken?: Opt<string>;
20
+ /** OAuth refresh token, if available. */
8
21
  refreshToken?: Opt<string>;
22
+ /** OpenID Connect ID token, if available. */
9
23
  idToken?: Opt<string>;
24
+ /** Expiration timestamp of the access token. */
10
25
  accessTokenExpiresAt?: Opt<Date>;
26
+ /** Expiration timestamp of the refresh token. */
11
27
  refreshTokenExpiresAt?: Opt<Date>;
28
+ /** OAuth scopes granted to this account. */
12
29
  scope?: Opt<string>;
30
+ /** Hashed password for credential-based accounts. */
13
31
  password?: Opt<string>;
32
+ /** Timestamp when the account was created. */
14
33
  createdAt: Opt<Date>;
34
+ /** Timestamp of the last update. */
15
35
  updatedAt: Opt<Date>;
16
36
  }
@@ -12,11 +12,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.BaseAccount = void 0;
13
13
  const core_1 = require("@mikro-orm/core");
14
14
  const crypto_1 = require("crypto");
15
+ /**
16
+ * Abstract base entity for OAuth/credential account records.
17
+ *
18
+ * @remarks
19
+ * Maps to the better-auth `account` model. Each account links a provider
20
+ * (e.g. Google, GitHub, credentials) to a {@link BaseUser}.
21
+ */
15
22
  let BaseAccount = class BaseAccount extends core_1.BaseEntity {
16
23
  constructor() {
17
24
  super(...arguments);
25
+ /** Primary key (UUID v4, auto-generated). */
18
26
  this.id = (0, crypto_1.randomUUID)();
27
+ /** Timestamp when the account was created. */
19
28
  this.createdAt = new Date();
29
+ /** Timestamp of the last update. */
20
30
  this.updatedAt = new Date();
21
31
  }
22
32
  };
@@ -1 +1 @@
1
- {"version":3,"file":"account.entity.js","sourceRoot":"","sources":["../../src/entities/account.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CASyB;AACzB,mCAAoC;AAG7B,IAAe,WAAW,GAA1B,MAAe,WAAY,SAAQ,iBAAU;IAA7C;;QAEL,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAqC/B,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAOlC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AA/CqB,kCAAW;AAE/B;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;uCACE;AAG/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;8CACR;AAGnB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;+CACP;AAOpB;IALC,IAAA,gBAAS,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACvB,SAAS,EAAE,SAAS;QACpB,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,CAAC,cAAO,CAAC,MAAM,CAAC;KAC1B,CAAC;;2CACc;AAGhB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACjB;AAG1B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDAChB;AAG3B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CACrB;AAGtB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;yDACd;AAGjC;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0DACb;AAGlC;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CACvB;AAGpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CACpB;AAGvB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;8CAClB;AAOlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;8CACgC;sBA9Cd,WAAW;IADhC,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACL,WAAW,CA+ChC"}
1
+ {"version":3,"file":"account.entity.js","sourceRoot":"","sources":["../../src/entities/account.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CASyB;AACzB,mCAAoC;AAEpC;;;;;;GAMG;AAEI,IAAe,WAAW,GAA1B,MAAe,WAAY,SAAQ,iBAAU;IAA7C;;QACL,6CAA6C;QAE7C,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QA8C/B,8CAA8C;QAE9C,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAElC,oCAAoC;QAMpC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AA5DqB,kCAAW;AAG/B;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;uCACE;AAI/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;8CACR;AAInB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;+CACP;AAQpB;IALC,IAAA,gBAAS,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACvB,SAAS,EAAE,SAAS;QACpB,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,CAAC,cAAO,CAAC,MAAM,CAAC;KAC1B,CAAC;;2CACc;AAIhB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACjB;AAI1B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDAChB;AAI3B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CACrB;AAItB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;yDACd;AAIjC;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0DACb;AAIlC;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CACvB;AAIpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CACpB;AAIvB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;8CAClB;AAQlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;8CACgC;sBA3Dd,WAAW;IADhC,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACL,WAAW,CA4DhC"}
@@ -1,11 +1,26 @@
1
1
  import { BaseEntity, Opt } from "@mikro-orm/core";
2
+ /**
3
+ * Abstract base entity for user session records.
4
+ *
5
+ * @remarks
6
+ * Maps to the better-auth `session` model. Each session is tied to a
7
+ * {@link BaseUser} and identified by a unique token.
8
+ */
2
9
  export declare class BaseSession extends BaseEntity {
10
+ /** Primary key (UUID v4, auto-generated). */
3
11
  id: Opt<string>;
12
+ /** Unique session token used for authentication. */
4
13
  token: string;
14
+ /** Foreign key referencing the owning {@link BaseUser}. */
5
15
  userId: string;
16
+ /** Timestamp when the session expires. */
6
17
  expiresAt: Date;
18
+ /** IP address of the client that created or last used this session. */
7
19
  ipAddress?: Opt<string>;
20
+ /** User-Agent header from the client that created or last used this session. */
8
21
  userAgent?: Opt<string>;
22
+ /** Timestamp when the session was created. */
9
23
  createdAt: Opt<Date>;
24
+ /** Timestamp of the last update. */
10
25
  updatedAt: Opt<Date>;
11
26
  }
@@ -12,11 +12,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.BaseSession = void 0;
13
13
  const core_1 = require("@mikro-orm/core");
14
14
  const crypto_1 = require("crypto");
15
+ /**
16
+ * Abstract base entity for user session records.
17
+ *
18
+ * @remarks
19
+ * Maps to the better-auth `session` model. Each session is tied to a
20
+ * {@link BaseUser} and identified by a unique token.
21
+ */
15
22
  let BaseSession = class BaseSession extends core_1.BaseEntity {
16
23
  constructor() {
17
24
  super(...arguments);
25
+ /** Primary key (UUID v4, auto-generated). */
18
26
  this.id = (0, crypto_1.randomUUID)();
27
+ /** Timestamp when the session was created. */
19
28
  this.createdAt = new Date();
29
+ /** Timestamp of the last update. */
20
30
  this.updatedAt = new Date();
21
31
  }
22
32
  };
@@ -1 +1 @@
1
- {"version":3,"file":"session.entity.js","sourceRoot":"","sources":["../../src/entities/session.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAUyB;AACzB,mCAAoC;AAG7B,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,iBAAU;IAApC;;QAEL,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAuB/B,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAOlC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AAjCY,kCAAW;AAEtB;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;uCACE;AAI/B;IAFC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;IAC1B,IAAA,aAAM,GAAE;;0CACM;AAOf;IALC,IAAA,gBAAS,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACvB,SAAS,EAAE,SAAS;QACpB,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,CAAC,cAAO,CAAC,MAAM,CAAC;KAC1B,CAAC;;2CACc;AAGhB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,CAAC;8BACnB,IAAI;8CAAC;AAGjB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACnB;AAGxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACnB;AAGxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;8CAClB;AAOlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;8CACgC;sBAhCvB,WAAW;IADvB,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACd,WAAW,CAiCvB"}
1
+ {"version":3,"file":"session.entity.js","sourceRoot":"","sources":["../../src/entities/session.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAUyB;AACzB,mCAAoC;AAEpC;;;;;;GAMG;AAEI,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,iBAAU;IAApC;;QACL,6CAA6C;QAE7C,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QA2B/B,8CAA8C;QAE9C,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAElC,oCAAoC;QAMpC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AAzCY,kCAAW;AAGtB;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;uCACE;AAK/B;IAFC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;IAC1B,IAAA,aAAM,GAAE;;0CACM;AAQf;IALC,IAAA,gBAAS,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE;QACvB,SAAS,EAAE,SAAS;QACpB,OAAO,EAAE,IAAI;QACb,OAAO,EAAE,CAAC,cAAO,CAAC,MAAM,CAAC;KAC1B,CAAC;;2CACc;AAIhB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,CAAC;8BACnB,IAAI;8CAAC;AAIjB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACnB;AAIxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACnB;AAIxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;8CAClB;AAQlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;8CACgC;sBAxCvB,WAAW;IADvB,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACd,WAAW,CAyCvB"}
@@ -1,10 +1,24 @@
1
1
  import { BaseEntity, Opt } from "@mikro-orm/core";
2
+ /**
3
+ * Abstract base entity for user records.
4
+ *
5
+ * @remarks
6
+ * Maps to the better-auth `user` model. Provides core identity fields
7
+ * such as name, email, and avatar, intended to be extended by the application.
8
+ */
2
9
  export declare class BaseUser extends BaseEntity {
10
+ /** Primary key (UUID v4, auto-generated). */
3
11
  id: Opt<string>;
12
+ /** Display name of the user. */
4
13
  name: string;
14
+ /** Unique email address of the user. */
5
15
  email: string;
16
+ /** Whether the email address has been verified. */
6
17
  emailVerified: boolean;
18
+ /** URL of the user's avatar image. */
7
19
  image?: Opt<string>;
20
+ /** Timestamp when the user was created. */
8
21
  createdAt: Opt<Date>;
22
+ /** Timestamp of the last update. */
9
23
  updatedAt: Opt<Date>;
10
24
  }
@@ -12,11 +12,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.BaseUser = void 0;
13
13
  const core_1 = require("@mikro-orm/core");
14
14
  const crypto_1 = require("crypto");
15
+ /**
16
+ * Abstract base entity for user records.
17
+ *
18
+ * @remarks
19
+ * Maps to the better-auth `user` model. Provides core identity fields
20
+ * such as name, email, and avatar, intended to be extended by the application.
21
+ */
15
22
  let BaseUser = class BaseUser extends core_1.BaseEntity {
16
23
  constructor() {
17
24
  super(...arguments);
25
+ /** Primary key (UUID v4, auto-generated). */
18
26
  this.id = (0, crypto_1.randomUUID)();
27
+ /** Timestamp when the user was created. */
19
28
  this.createdAt = new Date();
29
+ /** Timestamp of the last update. */
20
30
  this.updatedAt = new Date();
21
31
  }
22
32
  };
@@ -1 +1 @@
1
- {"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAQyB;AACzB,mCAAoC;AAG7B,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,iBAAU;IAAjC;;QAEL,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAgB/B,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAOlC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AA1BY,4BAAQ;AAEnB;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;oCACE;AAG/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;sCACb;AAId;IAFC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;IAC1B,IAAA,aAAM,GAAE;;uCACM;AAGf;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;;+CACtB;AAGxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACvB;AAGpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;2CAClB;AAOlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;2CACgC;mBAzBvB,QAAQ;IADpB,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACd,QAAQ,CA0BpB"}
1
+ {"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAQyB;AACzB,mCAAoC;AAEpC;;;;;;GAMG;AAEI,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,iBAAU;IAAjC;;QACL,6CAA6C;QAE7C,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAmB/B,2CAA2C;QAE3C,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAElC,oCAAoC;QAMpC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AAjCY,4BAAQ;AAGnB;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;oCACE;AAI/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;sCACb;AAKd;IAFC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;IAC1B,IAAA,aAAM,GAAE;;uCACM;AAIf;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;;+CACtB;AAIxB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACvB;AAIpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;2CAClB;AAQlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;2CACgC;mBAhCvB,QAAQ;IADpB,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACd,QAAQ,CAiCpB"}
@@ -1,9 +1,22 @@
1
1
  import { BaseEntity, Opt } from "@mikro-orm/core";
2
+ /**
3
+ * Abstract base entity for verification records.
4
+ *
5
+ * @remarks
6
+ * Used for email verification tokens, password reset tokens, and similar
7
+ * time-limited verification flows managed by better-auth.
8
+ */
2
9
  export declare abstract class BaseVerification extends BaseEntity {
10
+ /** Primary key (UUID v4, auto-generated). */
3
11
  id: Opt<string>;
12
+ /** Identifier associated with this verification (e.g. email address). */
4
13
  identifier: string;
14
+ /** Verification token value. */
5
15
  value: string;
16
+ /** Timestamp when this verification expires. */
6
17
  expiresAt: Date;
18
+ /** Timestamp when the verification was created. */
7
19
  createdAt: Opt<Date>;
20
+ /** Timestamp of the last update. */
8
21
  updatedAt: Opt<Date>;
9
22
  }
@@ -12,11 +12,21 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.BaseVerification = void 0;
13
13
  const core_1 = require("@mikro-orm/core");
14
14
  const crypto_1 = require("crypto");
15
+ /**
16
+ * Abstract base entity for verification records.
17
+ *
18
+ * @remarks
19
+ * Used for email verification tokens, password reset tokens, and similar
20
+ * time-limited verification flows managed by better-auth.
21
+ */
15
22
  let BaseVerification = class BaseVerification extends core_1.BaseEntity {
16
23
  constructor() {
17
24
  super(...arguments);
25
+ /** Primary key (UUID v4, auto-generated). */
18
26
  this.id = (0, crypto_1.randomUUID)();
27
+ /** Timestamp when the verification was created. */
19
28
  this.createdAt = new Date();
29
+ /** Timestamp of the last update. */
20
30
  this.updatedAt = new Date();
21
31
  }
22
32
  };
@@ -1 +1 @@
1
- {"version":3,"file":"verification.entity.js","sourceRoot":"","sources":["../../src/entities/verification.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAOyB;AACzB,mCAAoC;AAG7B,IAAe,gBAAgB,GAA/B,MAAe,gBAAiB,SAAQ,iBAAU;IAAlD;;QAEL,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAY/B,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAOlC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AAtBqB,4CAAgB;AAEpC;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;4CACE;AAG/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;oDACP;AAGpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;+CACZ;AAGf;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,CAAC;8BACnB,IAAI;mDAAC;AAGjB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;mDAClB;AAOlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;mDACgC;2BArBd,gBAAgB;IADrC,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACL,gBAAgB,CAsBrC"}
1
+ {"version":3,"file":"verification.entity.js","sourceRoot":"","sources":["../../src/entities/verification.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAOyB;AACzB,mCAAoC;AAEpC;;;;;;GAMG;AAEI,IAAe,gBAAgB,GAA/B,MAAe,gBAAiB,SAAQ,iBAAU;IAAlD;;QACL,6CAA6C;QAE7C,OAAE,GAAgB,IAAA,mBAAU,GAAE,CAAC;QAc/B,mDAAmD;QAEnD,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;QAElC,oCAAoC;QAMpC,cAAS,GAAc,IAAI,IAAI,EAAE,CAAC;IACpC,CAAC;CAAA,CAAA;AA5BqB,4CAAgB;AAGpC;IADC,IAAA,iBAAU,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;4CACE;AAI/B;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;oDACP;AAIpB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,IAAI,EAAE,CAAC;;+CACZ;AAIf;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,CAAC;8BACnB,IAAI;mDAAC;AAIjB;IADC,IAAA,eAAQ,EAAC,EAAE,IAAI,EAAE,QAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;;mDAClB;AAQlC;IALC,IAAA,eAAQ,EAAC;QACR,IAAI,EAAE,QAAC,CAAC,QAAQ;QAChB,UAAU,EAAE,OAAO;QACnB,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,IAAI,EAAE;KAC3B,CAAC;;mDACgC;2BA3Bd,gBAAgB;IADrC,IAAA,aAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;GACL,gBAAgB,CA4BrC"}