@rpcbase/db 0.64.0 → 0.65.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/acl/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { b, d, f, e, g, c, a, r } from "../can-D558uqd-.js";
1
+ import { b, d, f, e, g, c, h, a, r } from "../can--Y-1LK22.js";
2
2
  export {
3
3
  b as buildAbility,
4
4
  d as buildAbilityFromSession,
@@ -6,6 +6,7 @@ export {
6
6
  e as getAccessibleByQuery,
7
7
  g as getRegisteredPolicies,
8
8
  c as getTenantRolesFromSessionUser,
9
+ h as hasRegisteredPolicy,
9
10
  a as registerPoliciesFromModules,
10
11
  r as registerPolicy
11
12
  };
@@ -29,6 +29,7 @@ declare module "mongoose" {
29
29
  }
30
30
  export declare const mongooseAclPlugin: (schema: mongoose.Schema) => void;
31
31
  export declare const _private: {
32
+ createModelAclProxy: <TModel extends mongoose.Model<unknown>>(model: TModel, ability: AppAbility) => TModel;
32
33
  injectAggregateMatch: (pipeline: PipelineStageLike[], match: Record<string, unknown>) => void;
33
34
  mergeMongoQuery: (left: unknown, right: Record<string, unknown>) => Record<string, unknown>;
34
35
  };
@@ -1 +1 @@
1
- {"version":3,"file":"mongooseAclPlugin.d.ts","sourceRoot":"","sources":["../../src/acl/mongooseAclPlugin.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,UAAU,CAAA;AAG/B,OAAO,KAAK,EAAE,SAAS,EAAkB,UAAU,EAAE,MAAM,SAAS,CAAA;AAGpE,KAAK,SAAS,GAAG;IACf,OAAO,EAAE,UAAU,CAAA;IACnB,MAAM,CAAC,EAAE,SAAS,CAAA;CACnB,CAAA;AAID,KAAK,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AA6HhD,OAAO,CAAC,MAAM,sBAAsB,EAAE,OAAO,MAAM,CAAA;AAEnD,OAAO,QAAQ,UAAU,CAAC;IACxB,UAAU,YAAY,CAAC,OAAO,GAAG,OAAO;QACtC,KAAK,CAAC,EAAE,SAAS,CAAC;QAClB,CAAC,sBAAsB,CAAC,CAAC,EAAE,OAAO,CAAC;KACpC;IAED,UAAU,gBAAgB;QACxB,KAAK,CAAC,EAAE,SAAS,CAAC;KACnB;IAED,UAAU,KAAK,CACb,UAAU,EACV,OAAO,EACP,QAAQ,GAAG,EAAE,EACb,UAAU,GAAG,OAAO,EACpB,OAAO,GAAG,MAAM,EAChB,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC;QAErC,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC;QAC/F,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;KACxD;IAED,UAAU,SAAS,CAAC,UAAU;QAC5B,CAAC,sBAAsB,CAAC,CAAC,EAAE,UAAU,CAAC;QACtC,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;KACxD;IAED,UAAU,KAAK,CACb,WAAW,EACX,aAAa,EACb,gBAAgB,EAChB,SAAS,EACT,qBAAqB,EACrB,OAAO,EACP,eAAe;QAEf,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,SAAS,EAAE,qBAAqB,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;QACtI,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,KAAK,IAAI,CAAC;KACpC;CACF;AAED,eAAO,MAAM,iBAAiB,GAAI,QAAQ,QAAQ,CAAC,MAAM,KAAG,IAsE3D,CAAA;AAED,eAAO,MAAM,QAAQ;qCAjMmB,iBAAiB,EAAE,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,IAAI;4BA3CnE,OAAO,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CA+O/F,CAAA"}
1
+ {"version":3,"file":"mongooseAclPlugin.d.ts","sourceRoot":"","sources":["../../src/acl/mongooseAclPlugin.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,UAAU,CAAA;AAG/B,OAAO,KAAK,EAAE,SAAS,EAAkB,UAAU,EAAE,MAAM,SAAS,CAAA;AAGpE,KAAK,SAAS,GAAG;IACf,OAAO,EAAE,UAAU,CAAA;IACnB,MAAM,CAAC,EAAE,SAAS,CAAA;CACnB,CAAA;AAID,KAAK,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAqIhD,OAAO,CAAC,MAAM,sBAAsB,EAAE,OAAO,MAAM,CAAA;AAEnD,OAAO,QAAQ,UAAU,CAAC;IACxB,UAAU,YAAY,CAAC,OAAO,GAAG,OAAO;QACtC,KAAK,CAAC,EAAE,SAAS,CAAC;QAClB,CAAC,sBAAsB,CAAC,CAAC,EAAE,OAAO,CAAC;KACpC;IAED,UAAU,gBAAgB;QACxB,KAAK,CAAC,EAAE,SAAS,CAAC;KACnB;IAED,UAAU,KAAK,CACb,UAAU,EACV,OAAO,EACP,QAAQ,GAAG,EAAE,EACb,UAAU,GAAG,OAAO,EACpB,OAAO,GAAG,MAAM,EAChB,aAAa,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC;QAErC,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC;QAC/F,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;KACxD;IAED,UAAU,SAAS,CAAC,UAAU;QAC5B,CAAC,sBAAsB,CAAC,CAAC,EAAE,UAAU,CAAC;QACtC,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;KACxD;IAED,UAAU,KAAK,CACb,WAAW,EACX,aAAa,EACb,gBAAgB,EAChB,SAAS,EACT,qBAAqB,EACrB,OAAO,EACP,eAAe;QAEf,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,SAAS,EAAE,qBAAqB,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;QACtI,GAAG,EAAE,CAAC,OAAO,EAAE,UAAU,KAAK,IAAI,CAAC;KACpC;CACF;AAED,eAAO,MAAM,iBAAiB,GAAI,QAAQ,QAAQ,CAAC,MAAM,KAAG,IAsE3D,CAAA;AAED,eAAO,MAAM,QAAQ;0BA9IQ,MAAM,SAAS,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,SAC1D,MAAM,WACJ,UAAU,KAClB,MAAM;qCA9D+B,iBAAiB,EAAE,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,IAAI;4BA3CnE,OAAO,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAwP/F,CAAA"}
@@ -7,4 +7,5 @@ export type AclPolicy = {
7
7
  export declare const registerPolicy: (policy: AclPolicy) => void;
8
8
  export declare const registerPoliciesFromModules: (modules: Record<string, unknown>) => void;
9
9
  export declare const getRegisteredPolicies: () => Array<AclPolicy["define"]>;
10
+ export declare const hasRegisteredPolicy: (subject: string) => boolean;
10
11
  //# sourceMappingURL=registry.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/acl/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAEnD,OAAO,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAGrE,MAAM,MAAM,SAAS,GAAG;IACtB,OAAO,EAAE,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,CAAA;IACvC,MAAM,EAAE,CAAC,OAAO,EAAE,cAAc,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,UAAU,KAAK,IAAI,CAAA;CACvE,CAAA;AAuBD,eAAO,MAAM,cAAc,GAAI,QAAQ,SAAS,KAAG,IAIlD,CAAA;AAED,eAAO,MAAM,2BAA2B,GAAI,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,IAmB9E,CAAA;AAED,eAAO,MAAM,qBAAqB,QAAO,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAMjE,CAAA"}
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/acl/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAEnD,OAAO,KAAK,EAAE,UAAU,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAGrE,MAAM,MAAM,SAAS,GAAG;IACtB,OAAO,EAAE,OAAO,CAAC,cAAc,EAAE,KAAK,CAAC,CAAA;IACvC,MAAM,EAAE,CAAC,OAAO,EAAE,cAAc,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,UAAU,KAAK,IAAI,CAAA;CACvE,CAAA;AAuBD,eAAO,MAAM,cAAc,GAAI,QAAQ,SAAS,KAAG,IAIlD,CAAA;AAED,eAAO,MAAM,2BAA2B,GAAI,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAG,IAmB9E,CAAA;AAED,eAAO,MAAM,qBAAqB,QAAO,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAMjE,CAAA;AAED,eAAO,MAAM,mBAAmB,GAAI,SAAS,MAAM,KAAG,OAErD,CAAA"}
@@ -42,6 +42,9 @@ const getRegisteredPolicies = () => {
42
42
  }
43
43
  return out;
44
44
  };
45
+ const hasRegisteredPolicy = (subject2) => {
46
+ return policiesBySubject.has(subject2);
47
+ };
45
48
  const buildAbility = (ctx) => {
46
49
  const builder = new AbilityBuilder(createMongoAbility);
47
50
  const {
@@ -123,6 +126,7 @@ export {
123
126
  getAccessibleByQuery as e,
124
127
  can as f,
125
128
  getRegisteredPolicies as g,
129
+ hasRegisteredPolicy as h,
126
130
  registerPolicy as r
127
131
  };
128
- //# sourceMappingURL=can-D558uqd-.js.map
132
+ //# sourceMappingURL=can--Y-1LK22.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can--Y-1LK22.js","sources":["../src/acl/registry.ts","../src/acl/buildAbility.ts","../src/acl/session.ts","../src/acl/accessible.ts","../src/acl/can.ts"],"sourcesContent":["import type { AbilityBuilder } from \"@casl/ability\"\n\nimport type { AclContext, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport type AclPolicy = {\n subject: Exclude<AclSubjectType, \"all\">\n define: (builder: AbilityBuilder<AppAbility>, ctx: AclContext) => void\n}\n\nconst POLICIES_GLOBAL_KEY = Symbol.for(\"@rpcbase/db/acl/policiesBySubject\")\n\nconst getGlobalPoliciesMap = (): Map<string, Set<AclPolicy[\"define\"]>> => {\n const store = globalThis as unknown as Record<symbol, unknown>\n const existing = store[POLICIES_GLOBAL_KEY]\n if (existing instanceof Map) {\n return existing as Map<string, Set<AclPolicy[\"define\"]>>\n }\n const created = new Map<string, Set<AclPolicy[\"define\"]>>()\n store[POLICIES_GLOBAL_KEY] = created\n return created\n}\n\nconst policiesBySubject = getGlobalPoliciesMap()\n\nconst isPolicy = (value: unknown): value is AclPolicy => {\n if (!value || typeof value !== \"object\") return false\n const maybe = value as Partial<AclPolicy>\n return typeof maybe.subject === \"string\" && typeof maybe.define === \"function\"\n}\n\nexport const registerPolicy = (policy: AclPolicy): void => {\n const set = policiesBySubject.get(policy.subject) ?? new Set<AclPolicy[\"define\"]>()\n set.add(policy.define)\n policiesBySubject.set(policy.subject, set)\n}\n\nexport const registerPoliciesFromModules = (modules: Record<string, unknown>): void => {\n for (const [exportName, value] of Object.entries(modules)) {\n if (!isPolicy(value)) continue\n\n if (!exportName.endsWith(\"Policy\")) {\n throw new Error(\n `Invalid policy export name \"${exportName}\". Policies must be exported as \"<ModelName>Policy\".`,\n )\n }\n\n const expectedSubject = exportName.slice(0, -(\"Policy\".length))\n if (value.subject !== expectedSubject) {\n throw new Error(\n `Invalid policy \"${exportName}\": expected subject \"${expectedSubject}\", got \"${value.subject}\".`,\n )\n }\n\n registerPolicy(value)\n }\n}\n\nexport const getRegisteredPolicies = (): Array<AclPolicy[\"define\"]> => {\n const out: Array<AclPolicy[\"define\"]> = []\n for (const set of policiesBySubject.values()) {\n for (const fn of set) out.push(fn)\n }\n return out\n}\n\nexport const hasRegisteredPolicy = (subject: string): boolean => {\n return policiesBySubject.has(subject)\n}\n","import { AbilityBuilder, createMongoAbility } from \"@casl/ability\"\n\nimport { getRegisteredPolicies } from \"./registry\"\nimport type { AclContext, AppAbility } from \"./types\"\n\n\nexport const buildAbility = (ctx: AclContext): AppAbility => {\n const builder = new AbilityBuilder<AppAbility>(createMongoAbility)\n\n const { can } = builder\n\n if (ctx.roles.includes(\"owner\") || ctx.roles.includes(\"admin\")) {\n can(\"manage\", \"all\")\n }\n\n for (const define of getRegisteredPolicies()) {\n define(builder, ctx)\n }\n\n return builder.build()\n}\n\n","import { buildAbility } from \"./buildAbility\"\nimport type { AppAbility, TenantRolesByTenantId } from \"./types\"\n\n\ntype SessionUserLike = {\n id?: unknown\n signedInTenants?: unknown\n tenantRoles?: unknown\n}\n\ntype SessionLike = {\n user?: SessionUserLike\n}\n\nconst normalizeRole = (raw: unknown): string | null => {\n if (typeof raw !== \"string\") return null\n const normalized = raw.trim()\n return normalized ? normalized : null\n}\n\nconst normalizeRoles = (raw: unknown): string[] => {\n if (Array.isArray(raw)) {\n return raw.map(normalizeRole).filter((r): r is string => Boolean(r))\n }\n const role = normalizeRole(raw)\n return role ? [role] : []\n}\n\nconst normalizeRolesByTenantId = (raw: unknown): TenantRolesByTenantId | null => {\n if (!raw || typeof raw !== \"object\") return null\n if (raw instanceof Map) {\n return Object.fromEntries(Array.from(raw.entries()).map(([key, value]) => [String(key), normalizeRoles(value)]))\n }\n const obj = raw as Record<string, unknown>\n const out: TenantRolesByTenantId = {}\n for (const [key, value] of Object.entries(obj)) {\n const tenantId = String(key).trim()\n if (!tenantId) continue\n out[tenantId] = normalizeRoles(value)\n }\n return out\n}\n\nexport const getTenantRolesFromSessionUser = (user: unknown, tenantId: string): string[] => {\n if (!user || typeof user !== \"object\") return []\n const rolesByTenantId = normalizeRolesByTenantId((user as SessionUserLike).tenantRoles)\n if (!rolesByTenantId) return []\n return rolesByTenantId[tenantId]?.filter(Boolean) ?? []\n}\n\nexport const buildAbilityFromSession = ({\n tenantId,\n session,\n claims,\n}: {\n tenantId: string\n session: SessionLike | null | undefined\n claims?: Record<string, unknown>\n}): AppAbility => {\n const user = session?.user\n const userId = typeof user?.id === \"string\" ? user.id.trim() : \"\"\n const rolesByTenantId = normalizeRolesByTenantId(user?.tenantRoles)\n const hasExplicitTenantEntry = Boolean(\n rolesByTenantId && Object.prototype.hasOwnProperty.call(rolesByTenantId, tenantId),\n )\n\n const signedInTenantsRaw = user?.signedInTenants\n const signedInTenants = Array.isArray(signedInTenantsRaw) ? signedInTenantsRaw.map(String) : []\n\n const roles = hasExplicitTenantEntry\n ? rolesByTenantId![tenantId] ?? []\n : userId && signedInTenants.includes(tenantId)\n ? [\"owner\"]\n : getTenantRolesFromSessionUser(user, tenantId)\n\n return buildAbility({\n tenantId,\n userId: userId || null,\n roles,\n claims,\n })\n}\n","import { accessibleBy } from \"@casl/mongoose\"\n\nimport type { AclAction, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport const getAccessibleByQuery = (\n ability: AppAbility,\n action: AclAction,\n subject: Exclude<AclSubjectType, \"all\">,\n): Record<string, unknown> => {\n return accessibleBy(ability, action).ofType(subject)\n}\n","import { subject } from \"@casl/ability\"\n\nimport type { AclAction, AclSubject, AclSubjectMap, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport const can = <TSubject extends Exclude<AclSubjectType, \"all\">>(\n ability: AppAbility,\n action: AclAction,\n subjectType: TSubject,\n object?: Partial<AclSubjectMap[TSubject]> | null,\n): boolean => {\n if (object && typeof object === \"object\") {\n return ability.can(action, subject(subjectType, object) as unknown as AclSubject)\n }\n return ability.can(action, subjectType)\n}\n"],"names":["POLICIES_GLOBAL_KEY","Symbol","for","getGlobalPoliciesMap","store","globalThis","existing","Map","created","policiesBySubject","isPolicy","value","maybe","subject","define","registerPolicy","policy","set","get","Set","add","registerPoliciesFromModules","modules","exportName","Object","entries","endsWith","Error","expectedSubject","slice","length","getRegisteredPolicies","out","values","fn","push","hasRegisteredPolicy","has","buildAbility","ctx","builder","AbilityBuilder","createMongoAbility","can","roles","includes","build","normalizeRole","raw","normalized","trim","normalizeRoles","Array","isArray","map","filter","r","Boolean","role","normalizeRolesByTenantId","fromEntries","from","key","String","obj","tenantId","getTenantRolesFromSessionUser","user","rolesByTenantId","tenantRoles","buildAbilityFromSession","session","claims","userId","id","hasExplicitTenantEntry","prototype","hasOwnProperty","call","signedInTenantsRaw","signedInTenants","getAccessibleByQuery","ability","action","accessibleBy","ofType","subjectType","object"],"mappings":"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"}
@@ -16,6 +16,12 @@ type ModelsGetFn<TTenantModules extends ModelModules> = {
16
16
  [K in keyof TNames]: LoadedTenantModel;
17
17
  }>;
18
18
  };
19
+ type ModelsGetUnsafeFn<TTenantModules extends ModelModules> = {
20
+ (modelName: TenantModelName<TTenantModules>, ctx: LoadModelCtx): ReturnType<(typeof models)["getUnsafe"]>;
21
+ <const TNames extends readonly TenantModelName<TTenantModules>[]>(modelNames: TNames, ctx: LoadModelCtx): Promise<{
22
+ [K in keyof TNames]: LoadedTenantModel;
23
+ }>;
24
+ };
19
25
  type ModelsGetGlobalFn<TGlobalModules extends ModelModules> = {
20
26
  (modelName: GlobalModelName<TGlobalModules>, ctx: LoadModelCtx): ReturnType<(typeof models)["getGlobal"]>;
21
27
  <const TNames extends readonly GlobalModelName<TGlobalModules>[]>(modelNames: TNames, ctx: LoadModelCtx): Promise<{
@@ -29,6 +35,7 @@ export type ModelsConfig<TTenantModules extends ModelModules, TGlobalModules ext
29
35
  export type ModelsClient<TTenantModules extends ModelModules, TGlobalModules extends ModelModules> = {
30
36
  register: (modules: ModelsConfig<TTenantModules, TGlobalModules>) => void;
31
37
  get: ModelsGetFn<TTenantModules>;
38
+ getUnsafe: ModelsGetUnsafeFn<TTenantModules>;
32
39
  getGlobal: ModelsGetGlobalFn<TGlobalModules>;
33
40
  };
34
41
  export declare const createModels: <TTenantModules extends ModelModules, TGlobalModules extends ModelModules = Record<string, never>>(modules: ModelsConfig<TTenantModules, TGlobalModules>) => ModelsClient<TTenantModules, TGlobalModules>;
@@ -1 +1 @@
1
- {"version":3,"file":"createModels.d.ts","sourceRoot":"","sources":["../src/createModels.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"createModels.d.ts","sourceRoot":"","sources":["../src/createModels.ts"],"names":[],"mappings":"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"}
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
- import { a as registerPoliciesFromModules } from "./can-D558uqd-.js";
2
- import { b, d, f, e, g, c, r } from "./can-D558uqd-.js";
1
+ import { a as registerPoliciesFromModules, h as hasRegisteredPolicy } from "./can--Y-1LK22.js";
2
+ import { b, d, f, e, g, c, r } from "./can--Y-1LK22.js";
3
3
  import mongoose, { Schema as Schema$1, Types } from "mongoose";
4
4
  import { default as default2 } from "mongoose";
5
5
  import { z } from "zod";
@@ -1436,7 +1436,7 @@ const allocateSeqRange = async (db, count, session) => {
1436
1436
  }
1437
1437
  }, {
1438
1438
  upsert: true,
1439
- new: true,
1439
+ returnDocument: "after",
1440
1440
  setDefaultsOnInsert: true,
1441
1441
  projection: {
1442
1442
  seq: 1
@@ -1683,6 +1683,11 @@ const patchAggregateAcl = () => {
1683
1683
  const createModelAclProxy = (model2, ability) => {
1684
1684
  return new Proxy(model2, {
1685
1685
  get(target, prop, receiver) {
1686
+ if (prop === "acl") {
1687
+ return () => {
1688
+ throw new Error(`Model "${target.modelName}" is already ACL-scoped. Do not call .acl(...) again.`);
1689
+ };
1690
+ }
1686
1691
  const value = Reflect.get(target, prop, receiver);
1687
1692
  if (typeof value !== "function") return value;
1688
1693
  return (...args) => {
@@ -1873,11 +1878,24 @@ const getTenantIdFromCtx = (ctx) => {
1873
1878
  };
1874
1879
  const models = {
1875
1880
  register: registerModels,
1876
- get: async (modelName, ctx) => {
1881
+ getUnsafe: async (modelName, ctx) => {
1877
1882
  const tenantId = getTenantIdFromCtx(ctx);
1878
1883
  const dbName = getTenantDbName(tenantId);
1879
1884
  return loadModelFromDb(modelName, dbName, "tenant");
1880
1885
  },
1886
+ get: async (modelName, ctx) => {
1887
+ const model2 = await models.getUnsafe(modelName, ctx);
1888
+ const resolvedAbility = ctx.ability;
1889
+ const isProtected = hasRegisteredPolicy(modelName);
1890
+ if (!isProtected) {
1891
+ return model2;
1892
+ }
1893
+ if (!resolvedAbility) {
1894
+ throw new Error(`Model "${modelName}" is ACL-protected. Set ctx.ability or use models.getUnsafe(...) explicitly.`);
1895
+ }
1896
+ if (typeof model2.acl !== "function") return model2;
1897
+ return model2.acl(resolvedAbility);
1898
+ },
1881
1899
  getGlobal: async (modelName, ctx) => {
1882
1900
  const dbName = getGlobalDbName();
1883
1901
  return loadModelFromDb(modelName, dbName, "global");
@@ -1891,6 +1909,12 @@ const createModels = (modules) => {
1891
1909
  }
1892
1910
  return models.get(modelNameOrNames, ctx);
1893
1911
  });
1912
+ const getUnsafe = (async (modelNameOrNames, ctx) => {
1913
+ if (Array.isArray(modelNameOrNames)) {
1914
+ return Promise.all(modelNameOrNames.map((modelName) => models.getUnsafe(modelName, ctx)));
1915
+ }
1916
+ return models.getUnsafe(modelNameOrNames, ctx);
1917
+ });
1894
1918
  const getGlobal = (async (modelNameOrNames, ctx) => {
1895
1919
  if (Array.isArray(modelNameOrNames)) {
1896
1920
  return Promise.all(modelNameOrNames.map((modelName) => models.getGlobal(modelName, ctx)));
@@ -1900,6 +1924,7 @@ const createModels = (modules) => {
1900
1924
  return {
1901
1925
  register: registerModels,
1902
1926
  get,
1927
+ getUnsafe,
1903
1928
  getGlobal
1904
1929
  };
1905
1930
  };
@@ -2034,6 +2059,7 @@ export {
2034
2059
  getTenantFilesystemDbFromCtx,
2035
2060
  getTenantFilesystemDbName,
2036
2061
  c as getTenantRolesFromSessionUser,
2062
+ hasRegisteredPolicy,
2037
2063
  isPaginationValidationError,
2038
2064
  localizedStringField,
2039
2065
  m as makeZE164Phone,
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/models/RBUser.ts","../src/models/RBTenant.ts","../src/models/RBTenantSubscription.ts","../src/models/RBTenantSubscriptionEvent.ts","../src/models/RBRtsCounter.ts","../src/models/RBRtsChange.ts","../src/models/RBUploadSession.ts","../src/models/RBUploadChunk.ts","../src/models/RBNotification.ts","../src/models/RBNotificationSettings.ts","../src/models/RBOAuthRequest.ts","../src/mongoose/extendMongooseSchema.ts","../src/mongoose/localizedStringField.ts","../src/mongoose/index.ts","../src/pagination/errors.ts","../src/pagination/normalizeSpec.ts","../src/pagination/cursor.ts","../src/pagination/compileMongoPagination.ts","../src/pagination/materializePagination.ts","../src/pagination/mongoAdapter.ts","../src/pagination/paginateMongoQuery.ts","../src/pagination/mongoPaginationPlugin.ts","../src/search/index.ts","../src/dbNames.ts","../src/getMongoUrl.ts","../src/ensureMongooseConnection.ts","../src/rtsChangeLogPlugin.ts","../src/acl/mongooseAclPlugin.ts","../src/registerModels.ts","../src/modelsApi.ts","../src/createModels.ts","../src/tenantFilesystemDb.ts","../src/transactions.ts"],"sourcesContent":["import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBUser = z.object({\n email: z.string().email().optional(),\n password: z.string(),\n name: z.string().optional(),\n phone: z.string().optional(),\n tenants: z.array(z.string()),\n tenantRoles: z.record(z.string(), z.array(z.string())).optional(),\n oauthProviders: z.record(z.string(), z.object({\n subject: z.string(),\n email: z.string().email().optional(),\n name: z.string().optional(),\n accessToken: z.string().optional(),\n refreshToken: z.string().optional(),\n idToken: z.string().optional(),\n scope: z.string().optional(),\n tokenType: z.string().optional(),\n expiresAt: z.date().optional(),\n rawUserInfo: z.unknown().optional(),\n createdAt: z.date().optional(),\n updatedAt: z.date().optional(),\n })).optional(),\n emailVerificationCode: z.string().length(6).optional(),\n emailVerificationExpiresAt: z.date().optional(),\n})\n\nexport type IRBUser = z.infer<typeof ZRBUser>;\n\nexport const RBUserSchema: Schema = new Schema({\n email: { type: String, unique: true, sparse: true },\n phone: { type: String, unique: true, sparse: true },\n password: { type: String, required: true },\n name: String,\n tenants: { type: [String], index: true, required: true },\n tenantRoles: { type: Map, of: [String], required: false, default: {} },\n oauthProviders: {\n type: Map,\n of: new Schema({\n subject: { type: String, required: true },\n email: { type: String, required: false },\n name: { type: String, required: false },\n accessToken: { type: String, required: false },\n refreshToken: { type: String, required: false },\n idToken: { type: String, required: false },\n scope: { type: String, required: false },\n tokenType: { type: String, required: false },\n expiresAt: { type: Date, required: false },\n rawUserInfo: { type: Schema.Types.Mixed, required: false },\n createdAt: { type: Date, required: false },\n updatedAt: { type: Date, required: false },\n }, { _id: false }),\n default: {},\n required: false,\n },\n emailVerificationCode: { type: String, required: false },\n emailVerificationExpiresAt: { type: Date, required: false }\n})\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBTenant = z.object({\n tenantId: z.string(),\n parentTenantId: z.string().optional(),\n name: z.string().optional(),\n})\n\nexport type IRBTenant = z.infer<typeof ZRBTenant>;\n\nexport const RBTenantSchema: Schema = new Schema({\n tenantId: { type: String, required: true, unique: true, index: true },\n parentTenantId: { type: String },\n name: { type: String },\n})\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBTenantSubscriptionStatus = z.enum([\n \"trialing\",\n \"active\",\n \"past_due\",\n \"paused\",\n \"canceled\",\n \"expired\",\n])\n\nexport const ZRBTenantSubscriptionIntervalUnit = z.enum([\"month\", \"year\"])\n\nexport const ZRBTenantSubscriptionType = z.enum([\"primary\", \"addon\"])\n\nexport const ZRBTenantSubscriptionScope = z.enum([\"tenant\", \"shop\", \"custom\"])\n\nexport const ZRBTenantSubscription = z.object({\n tenantId: z.string(),\n subscriptionId: z.string(),\n type: ZRBTenantSubscriptionType.optional(),\n parentSubscriptionId: z.string().optional(),\n scope: ZRBTenantSubscriptionScope.optional(),\n scopeId: z.string().optional(),\n planKey: z.string(),\n status: ZRBTenantSubscriptionStatus,\n intervalUnit: ZRBTenantSubscriptionIntervalUnit,\n intervalCount: z.number().int().min(1).optional(),\n modules: z.array(z.string()).optional(),\n currentPeriodStart: z.date().optional(),\n currentPeriodEnd: z.date().optional(),\n trialEndsAt: z.date().optional(),\n cancelAt: z.date().optional(),\n cancelAtPeriodEnd: z.boolean().optional(),\n canceledAt: z.date().optional(),\n provider: z.string().optional(),\n providerCustomerId: z.string().optional(),\n providerSubscriptionId: z.string().optional(),\n latestEventId: z.string().optional(),\n latestEventAt: z.date().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBTenantSubscription = z.infer<typeof ZRBTenantSubscription>\n\nexport const RBTenantSubscriptionSchema: Schema = new Schema(\n {\n tenantId: { type: String, required: true, index: true },\n subscriptionId: { type: String, required: true },\n type: { type: String, required: true, enum: ZRBTenantSubscriptionType.options, default: \"primary\" },\n parentSubscriptionId: { type: String },\n scope: { type: String, enum: ZRBTenantSubscriptionScope.options, default: \"tenant\" },\n scopeId: { type: String },\n planKey: { type: String, required: true },\n status: { type: String, required: true, enum: ZRBTenantSubscriptionStatus.options },\n intervalUnit: { type: String, required: true, enum: ZRBTenantSubscriptionIntervalUnit.options },\n intervalCount: { type: Number, min: 1, default: 1 },\n modules: { type: [String], default: [] },\n currentPeriodStart: { type: Date },\n currentPeriodEnd: { type: Date },\n trialEndsAt: { type: Date },\n cancelAt: { type: Date },\n cancelAtPeriodEnd: { type: Boolean, default: false },\n canceledAt: { type: Date },\n provider: { type: String },\n providerCustomerId: { type: String },\n providerSubscriptionId: { type: String },\n latestEventId: { type: String },\n latestEventAt: { type: Date },\n metadata: { type: Schema.Types.Mixed },\n },\n)\n\nRBTenantSubscriptionSchema.index({ tenantId: 1, subscriptionId: 1 }, { unique: true })\nRBTenantSubscriptionSchema.index({ tenantId: 1, scope: 1, scopeId: 1 })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport {\n ZRBTenantSubscriptionIntervalUnit,\n ZRBTenantSubscriptionStatus,\n} from \"./RBTenantSubscription\"\n\n\nexport const ZRBTenantSubscriptionEventSource = z.enum([\n \"admin\",\n \"system\",\n \"webhook\",\n \"user\",\n])\n\nexport const ZRBTenantSubscriptionChangeDirection = z.enum([\n \"upgrade\",\n \"downgrade\",\n \"lateral\",\n])\n\nexport const ZRBTenantSubscriptionEvent = z.object({\n tenantId: z.string(),\n subscriptionId: z.string(),\n type: z.string(),\n occurredAt: z.date(),\n effectiveAt: z.date().optional(),\n fromPlanKey: z.string().optional(),\n toPlanKey: z.string().optional(),\n fromStatus: ZRBTenantSubscriptionStatus.optional(),\n toStatus: ZRBTenantSubscriptionStatus.optional(),\n fromModules: z.array(z.string()).optional(),\n toModules: z.array(z.string()).optional(),\n fromIntervalUnit: ZRBTenantSubscriptionIntervalUnit.optional(),\n toIntervalUnit: ZRBTenantSubscriptionIntervalUnit.optional(),\n fromIntervalCount: z.number().int().min(1).optional(),\n toIntervalCount: z.number().int().min(1).optional(),\n direction: ZRBTenantSubscriptionChangeDirection.optional(),\n actorUserId: z.string().optional(),\n source: ZRBTenantSubscriptionEventSource.optional(),\n reason: z.string().optional(),\n provider: z.string().optional(),\n providerEventId: z.string().optional(),\n providerPayload: z.unknown().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBTenantSubscriptionEvent = z.infer<typeof ZRBTenantSubscriptionEvent>\n\nexport const RBTenantSubscriptionEventSchema: Schema = new Schema(\n {\n tenantId: { type: String, required: true, index: true },\n subscriptionId: { type: String, required: true, index: true },\n type: { type: String, required: true },\n occurredAt: { type: Date, required: true, default: Date.now },\n effectiveAt: { type: Date },\n fromPlanKey: { type: String },\n toPlanKey: { type: String },\n fromStatus: { type: String, enum: ZRBTenantSubscriptionStatus.options },\n toStatus: { type: String, enum: ZRBTenantSubscriptionStatus.options },\n fromModules: { type: [String], default: undefined },\n toModules: { type: [String], default: undefined },\n fromIntervalUnit: { type: String, enum: ZRBTenantSubscriptionIntervalUnit.options },\n toIntervalUnit: { type: String, enum: ZRBTenantSubscriptionIntervalUnit.options },\n fromIntervalCount: { type: Number, min: 1 },\n toIntervalCount: { type: Number, min: 1 },\n direction: { type: String, enum: ZRBTenantSubscriptionChangeDirection.options },\n actorUserId: { type: String },\n source: { type: String, enum: ZRBTenantSubscriptionEventSource.options },\n reason: { type: String },\n provider: { type: String },\n providerEventId: { type: String },\n providerPayload: { type: Schema.Types.Mixed },\n metadata: { type: Schema.Types.Mixed },\n },\n)\n\nRBTenantSubscriptionEventSchema.index({ tenantId: 1, subscriptionId: 1, occurredAt: 1 })\nRBTenantSubscriptionEventSchema.index({ provider: 1, providerEventId: 1 }, { unique: true, sparse: true })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBRtsCounter = z.object({\n _id: z.string(),\n seq: z.number().int().min(0),\n})\n\nexport type IRBRtsCounter = z.infer<typeof ZRBRtsCounter>\n\nexport const RBRtsCounterSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n seq: { type: Number, required: true, default: 0 },\n },\n {\n versionKey: false,\n },\n)\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nconst ttlSecondsRaw = process.env.RB_RTS_CHANGES_TTL_S ?? \"\"\nconst ttlSeconds = Number.isFinite(Number(ttlSecondsRaw)) ? Math.max(60, Math.floor(Number(ttlSecondsRaw))) : 60 * 60 * 24 * 30\n\nexport const ZRBRtsChangeOp = z.enum([\"delete\", \"reset_model\"])\n\nexport const ZRBRtsChange = z.object({\n seq: z.number().int().min(0),\n modelName: z.string(),\n op: ZRBRtsChangeOp,\n docId: z.string().optional(),\n ts: z.date(),\n})\n\nexport type IRBRtsChange = z.infer<typeof ZRBRtsChange>\n\nexport const RBRtsChangeSchema: Schema = new Schema(\n {\n seq: { type: Number, required: true },\n modelName: { type: String, required: true, index: true },\n op: { type: String, required: true, enum: ZRBRtsChangeOp.options },\n docId: { type: String, required: false },\n ts: { type: Date, required: true, default: Date.now },\n },\n {\n versionKey: false,\n },\n)\n\nRBRtsChangeSchema.index({ seq: 1 }, { unique: true })\nRBRtsChangeSchema.index({ ts: 1 }, { expireAfterSeconds: ttlSeconds })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBUploadSessionStatus = z.enum([\"uploading\", \"assembling\", \"done\", \"error\"])\n\nexport const ZRBUploadSession = z.object({\n _id: z.string(),\n userId: z.string().optional(),\n ownerKeyHash: z.string().optional(),\n filename: z.string(),\n mimeType: z.string(),\n totalSize: z.number().int().min(0),\n chunkSize: z.number().int().min(1),\n chunksTotal: z.number().int().min(1),\n status: ZRBUploadSessionStatus,\n createdAt: z.date(),\n expiresAt: z.date(),\n fileId: z.string().optional(),\n isPublic: z.boolean().optional(),\n error: z.string().optional(),\n})\n\nexport type IRBUploadSession = z.infer<typeof ZRBUploadSession>\n\nexport const RBUploadSessionSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n userId: { type: String, required: false, index: true },\n ownerKeyHash: { type: String, required: false },\n filename: { type: String, required: true },\n mimeType: { type: String, required: true },\n totalSize: { type: Number, required: true },\n chunkSize: { type: Number, required: true },\n chunksTotal: { type: Number, required: true },\n status: { type: String, required: true, enum: ZRBUploadSessionStatus.options },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n fileId: { type: String, required: false },\n isPublic: { type: Boolean, required: false },\n error: { type: String, required: false },\n },\n {\n versionKey: false,\n },\n)\n\nRBUploadSessionSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n\nexport const RBUploadSessionPolicy: AclPolicy = {\n subject: \"RBUploadSession\",\n define: (builder, ctx) => {\n builder.can(\"create\", \"RBUploadSession\")\n\n if (ctx.userId) {\n builder.can(\"read\", \"RBUploadSession\", { userId: ctx.userId })\n builder.can(\"update\", \"RBUploadSession\", { userId: ctx.userId })\n builder.can(\"delete\", \"RBUploadSession\", { userId: ctx.userId })\n }\n\n const uploadKeyHash = typeof ctx.claims?.uploadKeyHash === \"string\" ? ctx.claims.uploadKeyHash.trim() : \"\"\n if (uploadKeyHash) {\n builder.can(\"read\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n builder.can(\"update\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n builder.can(\"delete\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n }\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBUploadChunk = z.object({\n uploadId: z.string(),\n index: z.number().int().min(0),\n data: z.unknown(),\n size: z.number().int().min(0),\n sha256: z.string().optional(),\n createdAt: z.date(),\n expiresAt: z.date(),\n})\n\nexport type IRBUploadChunk = z.infer<typeof ZRBUploadChunk>\n\nexport const RBUploadChunkSchema: Schema = new Schema(\n {\n uploadId: { type: String, required: true, index: true },\n index: { type: Number, required: true },\n data: { type: Buffer, required: true },\n size: { type: Number, required: true },\n sha256: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n },\n {\n versionKey: false,\n },\n)\n\nRBUploadChunkSchema.index({ uploadId: 1, index: 1 }, { unique: true })\nRBUploadChunkSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBNotification = z.object({\n userId: z.string(),\n topic: z.string().optional(),\n title: z.string(),\n body: z.string().optional(),\n url: z.string().optional(),\n createdAt: z.date(),\n seenAt: z.date().optional(),\n readAt: z.date().optional(),\n archivedAt: z.date().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBNotification = z.infer<typeof ZRBNotification>\n\nconst TTL_90_DAYS_S = 60 * 60 * 24 * 90\n\nexport const RBNotificationSchema: Schema = new Schema(\n {\n userId: { type: String, required: true, index: true },\n topic: { type: String, required: false, index: true },\n title: { type: String, required: true },\n body: { type: String, required: false },\n url: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now, index: true },\n seenAt: { type: Date, required: false, index: true },\n readAt: { type: Date, required: false, index: true },\n archivedAt: { type: Date, required: false },\n metadata: { type: Schema.Types.Mixed, required: false },\n },\n {\n versionKey: false,\n },\n)\n\nRBNotificationSchema.index({ userId: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ userId: 1, seenAt: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ userId: 1, readAt: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ archivedAt: 1 }, { expireAfterSeconds: TTL_90_DAYS_S })\n\nexport const RBNotificationPolicy: AclPolicy = {\n subject: \"RBNotification\",\n define: (builder, ctx) => {\n if (!ctx.userId) return\n builder.can(\"create\", \"RBNotification\")\n builder.can(\"read\", \"RBNotification\", { userId: ctx.userId })\n builder.can(\"update\", \"RBNotification\", { userId: ctx.userId })\n builder.can(\"delete\", \"RBNotification\", { userId: ctx.userId })\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBNotificationDigestFrequency = z.enum([\"off\", \"daily\", \"weekly\"])\n\nexport const ZRBNotificationTopicPreference = z.object({\n topic: z.string(),\n inApp: z.boolean(),\n emailDigest: z.boolean(),\n push: z.boolean(),\n})\n\nexport const ZRBNotificationSettings = z.object({\n userId: z.string(),\n digestFrequency: ZRBNotificationDigestFrequency,\n topicPreferences: z.array(ZRBNotificationTopicPreference).optional(),\n lastDigestSentAt: z.date().optional(),\n})\n\nexport type IRBNotificationSettings = z.infer<typeof ZRBNotificationSettings>\n\nconst TopicPreferenceSchema = new Schema(\n {\n topic: { type: String, required: true },\n inApp: { type: Boolean, required: true, default: true },\n emailDigest: { type: Boolean, required: true, default: true },\n push: { type: Boolean, required: true, default: false },\n },\n { _id: false },\n)\n\nexport const RBNotificationSettingsSchema: Schema = new Schema(\n {\n userId: { type: String, required: true },\n digestFrequency: {\n type: String,\n required: true,\n enum: ZRBNotificationDigestFrequency.options,\n default: \"weekly\",\n },\n topicPreferences: {\n type: [TopicPreferenceSchema],\n default: [],\n },\n lastDigestSentAt: { type: Date, required: false },\n },\n {\n versionKey: false,\n timestamps: true,\n },\n)\n\nRBNotificationSettingsSchema.index({ userId: 1 }, { unique: true })\nRBNotificationSettingsSchema.index({ userId: 1, \"topicPreferences.topic\": 1 })\n\nexport const RBNotificationSettingsPolicy: AclPolicy = {\n subject: \"RBNotificationSettings\",\n define: (builder, ctx) => {\n if (!ctx.userId) return\n builder.can(\"create\", \"RBNotificationSettings\")\n builder.can(\"read\", \"RBNotificationSettings\", { userId: ctx.userId })\n builder.can(\"update\", \"RBNotificationSettings\", { userId: ctx.userId })\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBOAuthRequest = z.object({\n _id: z.string(),\n providerId: z.string(),\n codeVerifier: z.string(),\n returnTo: z.string().optional(),\n createdAt: z.date(),\n expiresAt: z.date(),\n})\n\nexport type IRBOAuthRequest = z.infer<typeof ZRBOAuthRequest>\n\nexport const RBOAuthRequestSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n providerId: { type: String, required: true, index: true },\n codeVerifier: { type: String, required: true },\n returnTo: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n },\n { versionKey: false },\n)\n\nRBOAuthRequestSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n","import { Schema } from \"mongoose\"\n\n\ntype MongooseSchemaExtension = Parameters<Schema[\"add\"]>[0]\n\nexport function extendMongooseSchema<TSchema extends Schema>(\n baseSchema: TSchema,\n ...extensions: MongooseSchemaExtension[]\n): TSchema {\n const schema = baseSchema.clone() as TSchema\n\n extensions.forEach((extension) => schema.add(extension))\n\n return schema\n}\n\nexport function omitMongooseSchemaPaths<TSchema extends Schema>(\n schema: TSchema,\n paths: string[],\n): TSchema {\n const clone = schema.clone() as TSchema\n paths.forEach((path) => clone.remove(path))\n return clone\n}\n","import { Schema } from \"mongoose\"\nimport type { SchemaTypeOptions } from \"mongoose\"\n\nimport type { LocalizedString } from \"../zod/localizedString\"\nimport { withLocalizedStringFallback } from \"../zod/localizedString\"\n\n\nexport function localizedStringField(\n options?: Omit<SchemaTypeOptions<LocalizedString>, \"type\">\n): SchemaTypeOptions<LocalizedString> {\n const userGet = options?.get\n\n return {\n ...options,\n type: Schema.Types.Mixed,\n get: (value: unknown) => withLocalizedStringFallback(userGet ? userGet(value) : value),\n }\n}\n","import mongoose from \"mongoose\"\nimport type { InferSchemaType } from \"mongoose\"\n\n\nconst { Schema, model } = mongoose\n\nexport { Schema, model, mongoose, type InferSchemaType }\nexport * from \"./extendMongooseSchema\"\nexport * from \"./localizedStringField\"\n","export type PaginationErrorCode = \"invalid_pagination\"\n\nexport class PaginationValidationError extends Error {\n readonly code: PaginationErrorCode = \"invalid_pagination\"\n readonly statusCode = 400\n\n constructor(message: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"PaginationValidationError\"\n }\n}\n\nexport const isPaginationValidationError = (error: unknown): error is PaginationValidationError => {\n if (!error || typeof error !== \"object\") return false\n const anyError = error as Partial<PaginationValidationError>\n return (\n anyError.name === \"PaginationValidationError\" &&\n anyError.code === \"invalid_pagination\" &&\n anyError.statusCode === 400\n )\n}\n","import type { PaginationDirection, PaginationOrder, PaginationSpec } from \"@rpcbase/api\"\n\nimport { PaginationValidationError } from \"./errors\"\n\n\nconst DISALLOWED_MONGO_FIELD_SEGMENTS = new Set([\"__proto__\", \"constructor\", \"prototype\"])\nconst PAGINATION_LIMIT_MAX = 128\n\nexport type NormalizedPaginationSpec = Omit<PaginationSpec, \"direction\" | \"sort\" | \"limit\"> & {\n direction: PaginationDirection;\n limit: number;\n sort: Array<{\n field: string;\n order: PaginationOrder;\n }>;\n}\n\nexport const normalizePaginationSpec = (spec: PaginationSpec): NormalizedPaginationSpec => {\n if (!spec || typeof spec !== \"object\") throw new PaginationValidationError(\"Invalid PaginationSpec\")\n\n const limit = normalizeLimit(spec.limit)\n const direction = spec.direction ?? \"next\"\n if (direction !== \"next\" && direction !== \"prev\") throw new PaginationValidationError(\"Invalid pagination direction\")\n\n if (!Array.isArray(spec.sort) || spec.sort.length === 0) throw new PaginationValidationError(\"Invalid pagination sort\")\n\n const sort: NormalizedPaginationSpec[\"sort\"] = spec.sort.map(({ field, order }) => ({\n field: assertSafeMongoFieldPath(field),\n order: normalizeOrder(order),\n }))\n\n const seenFields = new Set<string>()\n for (const { field } of sort) {\n if (seenFields.has(field)) throw new PaginationValidationError(`Duplicate pagination sort field: ${field}`)\n seenFields.add(field)\n }\n\n const primaryOrder = sort[0]?.order\n\n if (!seenFields.has(\"_id\")) {\n sort.push({ field: \"_id\", order: primaryOrder })\n }\n\n return {\n ...spec,\n limit,\n direction,\n sort,\n }\n}\n\nconst normalizeLimit = (limit: unknown): number => {\n if (typeof limit !== \"number\" || !Number.isFinite(limit) || !Number.isInteger(limit) || limit <= 0) {\n throw new PaginationValidationError(\"Invalid pagination limit\")\n }\n if (limit > PAGINATION_LIMIT_MAX) {\n throw new PaginationValidationError(\"Invalid pagination limit\")\n }\n return limit\n}\n\nconst normalizeOrder = (order: unknown): PaginationOrder => {\n if (order !== \"asc\" && order !== \"desc\") throw new PaginationValidationError(\"Invalid pagination order\")\n return order\n}\n\nconst assertSafeMongoFieldPath = (field: unknown): string => {\n if (typeof field !== \"string\" || field.length === 0) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (field.startsWith(\"$\")) throw new PaginationValidationError(\"Invalid pagination sort field\")\n\n const parts = field.split(\".\")\n for (const part of parts) {\n if (part.length === 0) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (DISALLOWED_MONGO_FIELD_SEGMENTS.has(part)) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (!/^[a-zA-Z0-9_]+$/.test(part)) throw new PaginationValidationError(\"Invalid pagination sort field\")\n }\n\n return field\n}\n","import { createHmac, timingSafeEqual } from \"node:crypto\"\n\nimport { Types } from \"mongoose\"\nimport type { PaginationSpec } from \"@rpcbase/api\"\n\nimport { PaginationValidationError } from \"./errors\"\nimport { normalizePaginationSpec } from \"./normalizeSpec\"\n\n\ntype CursorValue =\n | null\n | string\n | number\n | boolean\n | { $date: string }\n | { $oid: string }\n\ntype CursorPayloadV1 = {\n v: 1;\n values: Record<string, CursorValue>;\n}\n\nexport type PaginationCursorCodecOptions = {\n signingSecret: string | Buffer;\n}\n\nexport const encodePaginationCursor = (\n spec: PaginationSpec,\n node: unknown,\n options: PaginationCursorCodecOptions,\n): string => {\n const normalized = normalizePaginationSpec(spec)\n\n const values = Object.create(null) as Record<string, CursorValue>\n for (const { field } of normalized.sort) {\n const value = readFieldValue(node, field)\n if (typeof value === \"undefined\") {\n throw new Error(`Pagination cursor encode failed (missing field: ${field})`)\n }\n values[field] = encodeCursorValue(field, value)\n }\n\n const payload: CursorPayloadV1 = { v: 1, values }\n const payloadB64 = Buffer.from(JSON.stringify(payload), \"utf8\").toString(\"base64url\")\n\n const sigB64 = signCursorPayloadB64(payloadB64, options.signingSecret)\n return `${payloadB64}.${sigB64}`\n}\n\nexport const decodePaginationCursor = (\n spec: PaginationSpec,\n cursor: string,\n options: PaginationCursorCodecOptions,\n): Record<string, unknown> => {\n const normalized = normalizePaginationSpec(spec)\n\n const [payloadB64, sigB64, ...rest] = cursor.split(\".\")\n if (rest.length > 0) throw new PaginationValidationError(\"Invalid pagination cursor format\")\n if (!sigB64) throw new PaginationValidationError(\"Invalid pagination cursor format\")\n verifyCursorSignature(payloadB64, sigB64, options.signingSecret)\n\n const payloadRaw = Buffer.from(payloadB64, \"base64url\").toString(\"utf8\")\n\n let payloadUnknown: unknown\n try {\n payloadUnknown = JSON.parse(payloadRaw)\n } catch {\n throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n }\n\n if (!payloadUnknown || typeof payloadUnknown !== \"object\") throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n const payload = payloadUnknown as Partial<CursorPayloadV1>\n\n if (payload.v !== 1) throw new PaginationValidationError(\"Unsupported pagination cursor version\")\n if (!payload.values || typeof payload.values !== \"object\") throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n\n const decoded = Object.create(null) as Record<string, unknown>\n for (const { field } of normalized.sort) {\n if (!Object.prototype.hasOwnProperty.call(payload.values, field)) {\n throw new PaginationValidationError(`Pagination cursor missing field: ${field}`)\n }\n const encodedValue = (payload.values as Record<string, CursorValue>)[field]\n decoded[field] = decodeCursorValue(field, encodedValue)\n }\n\n return decoded\n}\n\nconst signCursorPayloadB64 = (payloadB64: string, secret: string | Buffer): string => {\n return createHmac(\"sha256\", secret).update(payloadB64, \"utf8\").digest(\"base64url\")\n}\n\nconst verifyCursorSignature = (payloadB64: string, sigB64: string, secret: string | Buffer): void => {\n const expectedSigB64 = signCursorPayloadB64(payloadB64, secret)\n const a = Buffer.from(sigB64, \"utf8\")\n const b = Buffer.from(expectedSigB64, \"utf8\")\n if (a.length !== b.length || !timingSafeEqual(a, b)) {\n throw new PaginationValidationError(\"Invalid pagination cursor signature\")\n }\n}\n\nconst encodeCursorValue = (field: string, value: unknown): CursorValue => {\n if (value === null) return null\n\n if (field === \"_id\") {\n if (value instanceof Types.ObjectId) return { $oid: value.toHexString() }\n if (typeof value === \"string\") return value\n throw new Error(\"Pagination cursor encode failed (_id must be an ObjectId or string)\")\n }\n\n if (value instanceof Date) return { $date: value.toISOString() }\n\n if (typeof value === \"string\" || typeof value === \"number\" || typeof value === \"boolean\") return value\n\n if (value instanceof Types.ObjectId) return { $oid: value.toHexString() }\n\n throw new Error(`Unsupported pagination cursor value type for field: ${field}`)\n}\n\nconst decodeCursorValue = (field: string, value: CursorValue): unknown => {\n if (value === null) return null\n\n if (typeof value === \"string\") {\n return value\n }\n\n if (typeof value === \"number\" || typeof value === \"boolean\") return value\n\n if (!value || typeof value !== \"object\") throw new PaginationValidationError(`Invalid pagination cursor value for field: ${field}`)\n\n if (\"$date\" in value) {\n if (typeof value.$date !== \"string\") throw new PaginationValidationError(`Invalid pagination cursor date for field: ${field}`)\n const d = new Date(value.$date)\n if (Number.isNaN(d.getTime())) throw new PaginationValidationError(`Invalid pagination cursor date for field: ${field}`)\n return d\n }\n\n if (\"$oid\" in value) {\n if (typeof value.$oid !== \"string\" || !Types.ObjectId.isValid(value.$oid)) {\n throw new PaginationValidationError(`Invalid pagination cursor ObjectId for field: ${field}`)\n }\n return new Types.ObjectId(value.$oid)\n }\n\n throw new PaginationValidationError(`Invalid pagination cursor value for field: ${field}`)\n}\n\nconst readFieldValue = (node: unknown, field: string): unknown => {\n if (!node || typeof node !== \"object\") return undefined\n\n if (\"get\" in node && typeof (node as { get?: unknown }).get === \"function\") {\n return (node as { get: (path: string) => unknown }).get(field)\n }\n\n return field.split(\".\").reduce((acc, key) => {\n if (!acc || typeof acc !== \"object\") return undefined\n return (acc as Record<string, unknown>)[key]\n }, node as unknown)\n}\n","import type { PaginationOrder, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { decodePaginationCursor } from \"./cursor\"\nimport { PaginationValidationError } from \"./errors\"\nimport type { NormalizedPaginationSpec } from \"./normalizeSpec\"\nimport { normalizePaginationSpec } from \"./normalizeSpec\"\n\n\nexport type CompiledMongoPagination = {\n spec: NormalizedPaginationSpec;\n mongoFilterDelta: Record<string, unknown>;\n mongoSort: Record<string, 1 | -1>;\n mongoLimit: number;\n}\n\nexport type CompileMongoPaginationOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const compileMongoPagination = (\n spec: PaginationSpec,\n options: CompileMongoPaginationOptions,\n): CompiledMongoPagination => {\n const normalized = normalizePaginationSpec(spec)\n\n const mongoLimit = normalized.limit + 1\n const mongoSort = toMongoSort(normalized)\n\n if (normalized.cursor == null) {\n return {\n spec: normalized,\n mongoFilterDelta: {},\n mongoSort,\n mongoLimit,\n }\n }\n\n if (typeof normalized.cursor !== \"string\" || normalized.cursor.length === 0) {\n throw new PaginationValidationError(\"Invalid pagination cursor\")\n }\n\n const cursorValues = decodePaginationCursor(normalized, normalized.cursor, options.cursor)\n const mongoFilterDelta = buildKeysetFilterDelta(normalized, cursorValues)\n\n return {\n spec: normalized,\n mongoFilterDelta,\n mongoSort,\n mongoLimit,\n }\n}\n\nconst toMongoSort = (spec: NormalizedPaginationSpec): Record<string, 1 | -1> => {\n const mongoSort = Object.create(null) as Record<string, 1 | -1>\n for (const { field, order } of spec.sort) {\n const forQueryOrder = spec.direction === \"prev\" ? invertOrder(order) : order\n mongoSort[field] = forQueryOrder === \"asc\" ? 1 : -1\n }\n return mongoSort\n}\n\nconst buildKeysetFilterDelta = (\n spec: NormalizedPaginationSpec,\n cursorValues: Record<string, unknown>,\n): Record<string, unknown> => {\n const branches: Record<string, unknown>[] = []\n\n for (let i = 0; i < spec.sort.length; i++) {\n const current = spec.sort[i]\n if (!current) continue\n\n const and: Record<string, unknown>[] = []\n\n for (let j = 0; j < i; j++) {\n const prev = spec.sort[j]\n if (!prev) continue\n const eq = Object.create(null) as Record<string, unknown>\n eq[prev.field] = cursorValues[prev.field]\n and.push(eq)\n }\n\n const op = getKeysetOp(current.order, spec.direction)\n const cmpOp = Object.create(null) as Record<string, unknown>\n cmpOp[op] = cursorValues[current.field]\n const cmp = Object.create(null) as Record<string, unknown>\n cmp[current.field] = cmpOp\n and.push(cmp)\n\n branches.push(and.length === 1 ? and[0]! : { $and: and })\n }\n\n return { $or: branches }\n}\n\nconst getKeysetOp = (order: PaginationOrder, direction: NormalizedPaginationSpec[\"direction\"]): \"$gt\" | \"$lt\" => {\n if (direction === \"next\") return order === \"asc\" ? \"$gt\" : \"$lt\"\n return order === \"asc\" ? \"$lt\" : \"$gt\"\n}\n\nconst invertOrder = (order: PaginationOrder): PaginationOrder => {\n return order === \"asc\" ? \"desc\" : \"asc\"\n}\n","import type { PaginationResponse } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { encodePaginationCursor } from \"./cursor\"\nimport type { CompiledMongoPagination } from \"./compileMongoPagination\"\n\n\nexport type MaterializePaginationOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const materializeMongoPagination = <TNode>(\n compiled: CompiledMongoPagination,\n fetchedNodes: TNode[],\n options: MaterializePaginationOptions,\n): PaginationResponse<TNode> => {\n const limit = compiled.spec.limit\n const hasMore = fetchedNodes.length > limit\n\n const trimmed = fetchedNodes.slice(0, limit)\n const nodes = compiled.spec.direction === \"prev\" ? trimmed.reverse() : trimmed\n\n const hasPrevPage = compiled.spec.direction === \"next\" ? Boolean(compiled.spec.cursor) : hasMore\n const hasNextPage = compiled.spec.direction === \"next\" ? hasMore : Boolean(compiled.spec.cursor)\n\n const pageInfo: PaginationResponse<TNode>[\"pageInfo\"] = {\n hasNextPage,\n hasPrevPage,\n }\n\n if (nodes.length === 0) {\n return { nodes, pageInfo }\n }\n\n if (hasPrevPage) {\n pageInfo.prevCursor = encodePaginationCursor(compiled.spec, nodes[0], options.cursor)\n }\n\n if (hasNextPage) {\n pageInfo.nextCursor = encodePaginationCursor(compiled.spec, nodes[nodes.length - 1], options.cursor)\n }\n\n return { nodes, pageInfo }\n}\n","import type { CompiledMongoPagination } from \"./compileMongoPagination\"\n\n\ntype MongoQueryLike = {\n where: (delta: Record<string, unknown>) => unknown;\n sort: (sort: Record<string, 1 | -1>) => unknown;\n limit: (limit: number) => unknown;\n}\n\nexport const MongoAdapter = {\n applyPagination: <TQuery extends MongoQueryLike>(query: TQuery, compiled: CompiledMongoPagination): TQuery => {\n query.where(compiled.mongoFilterDelta)\n query.sort(compiled.mongoSort)\n query.limit(compiled.mongoLimit)\n return query\n },\n}\n\n","import type { PaginationResponse, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { compileMongoPagination } from \"./compileMongoPagination\"\nimport { materializeMongoPagination } from \"./materializePagination\"\nimport { MongoAdapter } from \"./mongoAdapter\"\n\n\ntype MongoPaginateQueryLike<TNode> = {\n where: (delta: Record<string, unknown>) => unknown;\n sort: (sort: Record<string, 1 | -1>) => unknown;\n limit: (limit: number) => unknown;\n exec: () => Promise<TNode[]>;\n}\n\nexport type PaginateMongoQueryOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const paginateMongoQuery = async <TNode>(\n query: MongoPaginateQueryLike<TNode>,\n pagination: PaginationSpec,\n options: PaginateMongoQueryOptions,\n): Promise<PaginationResponse<TNode>> => {\n const compiled = compileMongoPagination(pagination, { cursor: options.cursor })\n\n MongoAdapter.applyPagination(query, compiled)\n\n const fetchedNodes = await query.exec()\n if (!Array.isArray(fetchedNodes)) {\n throw new Error(\"paginateMongoQuery expects query.exec() to return an array\")\n }\n\n return materializeMongoPagination(compiled, fetchedNodes, { cursor: options.cursor })\n}\n","import mongoose from \"mongoose\"\nimport type { PaginationResponse, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { paginateMongoQuery } from \"./paginateMongoQuery\"\n\n\ndeclare const mongoPaginationPluginBrand: unique symbol\n\n\ntype QueryOptionsLike = Record<string, unknown>\n\nconst getQueryOptions = (query: unknown): QueryOptionsLike | undefined => {\n if (!query || typeof query !== \"object\") return undefined\n if (!(\"getOptions\" in query) || typeof (query as { getOptions?: unknown }).getOptions !== \"function\") return undefined\n return (query as { getOptions: () => QueryOptionsLike }).getOptions()\n}\n\nconst getPaginationFromOptions = (query: unknown): PaginationSpec | undefined => {\n const options = getQueryOptions(query)\n return options?.pagination as PaginationSpec | undefined\n}\n\nconst getCursorFromOptions = (query: unknown): PaginationCursorCodecOptions | undefined => {\n const options = getQueryOptions(query)\n return options?.paginationCursor as PaginationCursorCodecOptions | undefined\n}\n\nexport type MongoPaginationPluginOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\ntype QueryResultNode<TResult> = TResult extends Array<infer TNode> ? TNode : unknown\n\ndeclare module \"mongoose\" {\n interface Query<\n ResultType,\n DocType,\n THelpers = {},\n RawDocType = unknown,\n QueryOp = \"find\",\n TDocOverrides = Record<string, never>,\n > {\n [mongoPaginationPluginBrand]?: [DocType, THelpers, RawDocType, QueryOp, TDocOverrides];\n paginate: (\n pagination?: PaginationSpec,\n options?: MongoPaginationPluginOptions,\n ) => Promise<PaginationResponse<QueryResultNode<ResultType>>>;\n }\n}\n\nexport const mongoPaginationPlugin = (schema: mongoose.Schema, pluginOptions?: MongoPaginationPluginOptions): void => {\n ;(schema.query as Record<string, unknown>).paginate = async function(\n this: mongoose.Query<unknown[], unknown>,\n pagination?: PaginationSpec,\n options?: MongoPaginationPluginOptions,\n ): Promise<PaginationResponse<unknown>> {\n const spec = pagination ?? getPaginationFromOptions(this)\n if (!spec) throw new Error(\"Missing pagination spec\")\n\n const cursor = options?.cursor ?? getCursorFromOptions(this) ?? pluginOptions?.cursor\n if (!cursor?.signingSecret) throw new Error(\"Missing pagination cursor signingSecret\")\n\n return await paginateMongoQuery(this, spec, { cursor })\n }\n}\n","type MongoDbLike = {\n databaseName?: string\n command: (command: Record<string, unknown>) => Promise<unknown>\n}\n\nexport type SearchTextStageOptions = {\n index: string\n query: string\n path: string | string[]\n highlightPath?: string | string[]\n}\n\nexport type SearchTextStage = {\n $search: {\n index: string\n text: {\n query: string\n path: string | string[]\n }\n highlight?: {\n path: string | string[]\n }\n }\n}\n\nexport const buildSearchTextStage = (options: SearchTextStageOptions): SearchTextStage => {\n const index = options.index.trim()\n if (!index) throw new Error(\"Missing search index name\")\n\n const query = options.query.trim()\n if (!query) throw new Error(\"Missing search query\")\n\n const stage: SearchTextStage = {\n $search: {\n index,\n text: {\n query,\n path: options.path,\n },\n },\n }\n\n if (options.highlightPath) {\n stage.$search.highlight = { path: options.highlightPath }\n }\n\n return stage\n}\n\nexport const searchMetaProjection = () => {\n return {\n score: { $meta: \"searchScore\" },\n highlights: { $meta: \"searchHighlights\" },\n } as const\n}\n\nexport type EnsureSearchIndexParams = {\n db: MongoDbLike\n collection: string\n name: string\n definition: Record<string, unknown>\n}\n\nconst listResultHasIndex = (listResult: unknown, name: string): boolean => {\n if (!listResult || typeof listResult !== \"object\") return false\n if (!(\"cursor\" in listResult)) return false\n const cursor = (listResult as { cursor?: unknown }).cursor\n if (!cursor || typeof cursor !== \"object\") return false\n const firstBatch = (cursor as { firstBatch?: unknown }).firstBatch\n if (!Array.isArray(firstBatch)) return false\n return firstBatch.some((idx) => idx && typeof idx === \"object\" && \"name\" in idx && (idx as { name?: unknown }).name === name)\n}\n\nconst isIndexAlreadyExistsError = (error: unknown): boolean => {\n if (!error || typeof error !== \"object\") return false\n const codeName = \"codeName\" in error ? (error as { codeName?: unknown }).codeName : undefined\n if (codeName === \"IndexAlreadyExists\") return true\n const message = \"message\" in error ? String((error as { message?: unknown }).message ?? \"\") : \"\"\n return /already exists/i.test(message)\n}\n\nexport const ensureSearchIndex = async (params: EnsureSearchIndexParams): Promise<{ created: boolean }> => {\n const collection = params.collection.trim()\n if (!collection) throw new Error(\"Missing collection name\")\n\n const name = params.name.trim()\n if (!name) throw new Error(\"Missing search index name\")\n\n let listResult: unknown\n try {\n listResult = await params.db.command({ listSearchIndexes: collection })\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n throw new Error(`listSearchIndexes failed for \"${collection}\": ${message}`)\n }\n\n if (listResultHasIndex(listResult, name)) {\n return { created: false }\n }\n\n try {\n await params.db.command({\n createSearchIndexes: collection,\n indexes: [{ name, definition: params.definition }],\n })\n } catch (error) {\n if (isIndexAlreadyExistsError(error)) {\n return { created: false }\n }\n const message = error instanceof Error ? error.message : String(error)\n throw new Error(`createSearchIndexes failed for \"${collection}\" (index \"${name}\"): ${message}`)\n }\n\n return { created: true }\n}\n","const getAppName = (env: NodeJS.ProcessEnv = process.env): string => {\n const appName = env.APP_NAME?.trim()\n if (!appName) {\n throw new Error(\"Missing APP_NAME\")\n }\n return appName\n}\n\nexport const GLOBAL_DB_SUFFIX = \"-global-db\"\n\nexport const getGlobalDbName = (env: NodeJS.ProcessEnv = process.env): string => {\n return `${getAppName(env)}${GLOBAL_DB_SUFFIX}`\n}\n\nexport const getTenantDbName = (tenantId: string, env: NodeJS.ProcessEnv = process.env): string => {\n return `${getAppName(env)}-${tenantId.trim()}-db`\n}\n","type EnvRecord = { [key: string]: string | undefined }\n\nexport const getMongoUrl = (env: EnvRecord = process.env): string => {\n const explicitUrl =\n env.MONGODB_URL\n ?? env.MONGO_URL\n ?? env.MONGODB_URI\n ?? env.DB_URL\n\n if (explicitUrl && explicitUrl.trim()) {\n return explicitUrl.trim()\n }\n\n const port = env.DB_PORT?.trim()\n if (!port) throw new Error(\"Missing Mongo connection details (MONGODB_URL/MONGO_URL/MONGODB_URI/DB_URL/DB_PORT)\")\n\n const host = env.DB_HOST?.trim() || \"localhost\"\n return `mongodb://${host}:${port}`\n}\n\n","import mongoose from \"mongoose\"\n\nimport { getMongoUrl } from \"./getMongoUrl\"\n\n\nconst connections = new Map<string, mongoose.Connection>()\nlet rootConnection: mongoose.Connection | null = null\n\nconst waitForOpen = async (connection: mongoose.Connection): Promise<void> => {\n if (connection.readyState === 1) return\n\n await new Promise<void>((resolve, reject) => {\n connection.once(\"open\", resolve)\n connection.once(\"error\", reject)\n })\n}\n\nexport const ensureMongooseConnection = async (dbName: string): Promise<mongoose.Connection> => {\n const normalizedDbName = dbName.trim()\n if (!normalizedDbName) {\n throw new Error(\"Missing dbName\")\n }\n\n const existing = connections.get(normalizedDbName)\n if (existing) {\n await waitForOpen(existing)\n return existing\n }\n\n if (!rootConnection) {\n const mongoUrl = getMongoUrl()\n rootConnection = mongoose.createConnection(mongoUrl, {\n sanitizeFilter: true,\n dbName: normalizedDbName,\n })\n }\n\n await waitForOpen(rootConnection)\n\n const connection = rootConnection.name === normalizedDbName\n ? rootConnection\n : rootConnection.useDb(normalizedDbName, { useCache: true })\n\n await waitForOpen(connection)\n\n connections.set(normalizedDbName, connection)\n return connection\n}\n","import type mongoose from \"mongoose\"\n\nimport { GLOBAL_DB_SUFFIX } from \"./dbNames\"\nimport { RBRtsChangeSchema, type IRBRtsChange } from \"./models/RBRtsChange\"\nimport { RBRtsCounterSchema, type IRBRtsCounter } from \"./models/RBRtsCounter\"\n\n\ntype RtsChangeOp = IRBRtsChange[\"op\"]\n\nconst RTS_COUNTER_ID = \"rts\"\nconst EXCLUDED_MODEL_NAMES = new Set([\"RBRtsChange\", \"RBRtsCounter\"])\n\nconst maxDeleteIdsRaw = process.env.RB_RTS_DELETE_LOG_MAX_IDS ?? \"\"\nconst maxDeleteIds = Number.isFinite(Number(maxDeleteIdsRaw)) ? Math.max(1, Math.floor(Number(maxDeleteIdsRaw))) : 5000\n\ntype DeleteMeta = {\n modelName: string\n ids: string[]\n reset: boolean\n session?: mongoose.ClientSession\n}\n\nconst deleteMetaByQuery = new WeakMap<object, DeleteMeta>()\n\nconst hasToString = (value: unknown): value is { toString: () => string } => {\n if (typeof value !== \"object\" || value === null) return false\n const maybe = value as { toString?: unknown }\n return typeof maybe.toString === \"function\"\n}\n\nconst normalizeId = (id: unknown): string | null => {\n if (!id) return null\n if (typeof id === \"string\") return id\n if (hasToString(id)) return id.toString()\n return null\n}\n\nconst getDbName = (db: unknown): string => {\n if (!db || typeof db !== \"object\") return \"\"\n const maybe = db as { name?: unknown; db?: { databaseName?: unknown } }\n const raw = maybe.name ?? maybe.db?.databaseName\n return typeof raw === \"string\" ? raw : \"\"\n}\n\nconst isGlobalDb = (db: unknown): boolean => getDbName(db).endsWith(GLOBAL_DB_SUFFIX)\n\ntype RtsCounterDoc = IRBRtsCounter\ntype RtsChangeDoc = IRBRtsChange\n\nconst getQuerySession = (query: MongooseQuery): mongoose.ClientSession | undefined => {\n const opts = typeof query.getOptions === \"function\" ? query.getOptions() : undefined\n if (!opts || typeof opts !== \"object\") return undefined\n const session = (opts as { session?: unknown }).session\n if (!session || typeof session !== \"object\") return undefined\n return session as mongoose.ClientSession\n}\n\nconst getRtsModels = (db: mongoose.Connection) => {\n const RtsCounter = (db.models.RBRtsCounter as mongoose.Model<RtsCounterDoc>)\n ?? db.model<RtsCounterDoc>(\"RBRtsCounter\", RBRtsCounterSchema)\n const RtsChange = (db.models.RBRtsChange as mongoose.Model<RtsChangeDoc>)\n ?? db.model<RtsChangeDoc>(\"RBRtsChange\", RBRtsChangeSchema)\n return { RtsCounter, RtsChange }\n}\n\nconst allocateSeqRange = async (\n db: mongoose.Connection,\n count: number,\n session?: mongoose.ClientSession,\n): Promise<{ start: number; end: number }> => {\n const { RtsCounter } = getRtsModels(db)\n const updated = await RtsCounter.findOneAndUpdate(\n { _id: RTS_COUNTER_ID },\n { $inc: { seq: count } },\n { upsert: true, new: true, setDefaultsOnInsert: true, projection: { seq: 1 }, session },\n ).lean()\n\n const end = Number(updated?.seq ?? 0)\n const start = end - count + 1\n return { start, end }\n}\n\nconst insertChanges = async (\n db: mongoose.Connection,\n changes: Array<{ seq: number; modelName: string; op: RtsChangeOp; docId?: string | null }>,\n session?: mongoose.ClientSession,\n): Promise<void> => {\n if (!changes.length) return\n const { RtsChange } = getRtsModels(db)\n const ts = new Date()\n const docs = changes.map((c) => ({\n seq: c.seq,\n modelName: c.modelName,\n op: c.op,\n docId: c.docId ?? undefined,\n ts,\n }))\n\n if (session) {\n await RtsChange.insertMany(docs, { session })\n return\n }\n\n await RtsChange.insertMany(docs)\n}\n\nconst recordDeleteChanges = async (\n db: mongoose.Connection,\n modelName: string,\n ids: string[],\n session?: mongoose.ClientSession,\n): Promise<void> => {\n const uniqueIds = Array.from(new Set(ids)).filter(Boolean)\n if (!uniqueIds.length) return\n const { start } = await allocateSeqRange(db, uniqueIds.length, session)\n await insertChanges(db, uniqueIds.map((docId, idx) => ({\n seq: start + idx,\n modelName,\n op: \"delete\",\n docId,\n })), session)\n}\n\nconst recordResetModel = async (db: mongoose.Connection, modelName: string, session?: mongoose.ClientSession): Promise<void> => {\n const { start } = await allocateSeqRange(db, 1, session)\n await insertChanges(db, [{ seq: start, modelName, op: \"reset_model\" }], session)\n}\n\ntype MongooseQuery = mongoose.Query<unknown, unknown> & {\n model?: {\n modelName?: string\n db?: unknown\n find: (filter: unknown, projection: unknown) => unknown\n }\n getFilter?: () => unknown\n getQuery?: () => unknown\n getOptions?: () => unknown\n}\n\nconst captureDeleteMeta = async (query: MongooseQuery, mode: \"one\" | \"many\") => {\n const modelName = String(query?.model?.modelName ?? \"\")\n if (!modelName || modelName.startsWith(\"RB\") || EXCLUDED_MODEL_NAMES.has(modelName)) return\n if (isGlobalDb(query?.model?.db)) return\n\n const filter = typeof query.getFilter === \"function\" ? query.getFilter() : query.getQuery?.() ?? {}\n const session = getQuerySession(query)\n const findQuery = query.model.find(filter, { _id: 1 }) as unknown as {\n session?: (s: mongoose.ClientSession) => unknown\n limit: (n: number) => unknown\n lean: () => unknown\n }\n if (session && typeof findQuery.session === \"function\") {\n findQuery.session(session)\n }\n\n findQuery.lean()\n\n if (mode === \"one\") {\n findQuery.limit(1)\n } else {\n findQuery.limit(maxDeleteIds + 1)\n }\n\n const docs = await findQuery\n const ids = Array.isArray(docs)\n ? docs\n .map((d) => normalizeId((d as { _id?: unknown })?._id))\n .filter((id): id is string => Boolean(id))\n : []\n const reset = mode === \"many\" && ids.length > maxDeleteIds\n const trimmedIds = reset ? [] : ids\n\n const meta: DeleteMeta = {\n modelName,\n ids: trimmedIds,\n reset,\n session,\n }\n\n deleteMetaByQuery.set(query, meta)\n}\n\nconst flushDeleteMeta = async (query: MongooseQuery) => {\n const meta = deleteMetaByQuery.get(query)\n deleteMetaByQuery.delete(query)\n if (!meta) return\n\n const db = query?.model?.db as mongoose.Connection | undefined\n if (!db) return\n\n try {\n if (meta.reset) {\n await recordResetModel(db, meta.modelName, meta.session)\n } else {\n await recordDeleteChanges(db, meta.modelName, meta.ids, meta.session)\n }\n } catch {\n return\n }\n}\n\nexport const rtsChangeLogPlugin = (schema: mongoose.Schema): void => {\n schema.pre(\"deleteOne\", { query: true, document: false }, async function(this: MongooseQuery) {\n await captureDeleteMeta(this, \"one\")\n })\n\n schema.pre(\"deleteMany\", { query: true, document: false }, async function(this: MongooseQuery) {\n await captureDeleteMeta(this, \"many\")\n })\n\n schema.post(\"deleteOne\", { query: true, document: false }, async function(this: MongooseQuery) {\n await flushDeleteMeta(this)\n })\n\n schema.post(\"deleteMany\", { query: true, document: false }, async function(this: MongooseQuery) {\n await flushDeleteMeta(this)\n })\n\n schema.post(\"findOneAndDelete\", { query: true, document: false }, async function(this: MongooseQuery, doc: unknown) {\n const modelName = String(this?.model?.modelName ?? \"\")\n if (!modelName || modelName.startsWith(\"RB\") || EXCLUDED_MODEL_NAMES.has(modelName)) return\n\n const db = this?.model?.db as mongoose.Connection | undefined\n if (!db) return\n if (isGlobalDb(db)) return\n\n const docId = normalizeId((doc as { _id?: unknown } | null | undefined)?._id)\n if (!docId) return\n\n try {\n const session = getQuerySession(this)\n await recordDeleteChanges(db, modelName, [docId], session)\n } catch {\n return\n }\n })\n}\n","import mongoose from \"mongoose\"\nimport { accessibleBy } from \"@casl/mongoose\"\n\nimport type { AclAction, AclSubjectType, AppAbility } from \"./types\"\n\n\ntype StoredAcl = {\n ability: AppAbility\n action?: AclAction\n}\n\ntype QueryOptionsLike = Record<string, unknown>\n\ntype PipelineStageLike = Record<string, unknown>\n\nconst isRecord = (value: unknown): value is Record<string, unknown> => Boolean(value) && typeof value === \"object\" && !Array.isArray(value)\n\nconst mergeMongoQuery = (left: unknown, right: Record<string, unknown>): Record<string, unknown> => {\n const leftQuery = isRecord(left) ? left : {}\n if (Object.keys(leftQuery).length === 0) return right\n if (Object.keys(right).length === 0) return leftQuery\n return { $and: [leftQuery, right] }\n}\n\nconst getQueryOptions = (query: unknown): QueryOptionsLike | undefined => {\n if (!query || typeof query !== \"object\") return undefined\n if (!(\"getOptions\" in query) || typeof (query as { getOptions?: unknown }).getOptions !== \"function\") return undefined\n return (query as { getOptions: () => QueryOptionsLike }).getOptions()\n}\n\nconst getStoredAclFromQuery = (query: unknown): StoredAcl | null => {\n const options = getQueryOptions(query)\n const raw = options?.rbAcl\n if (!isRecord(raw)) return null\n if (!(\"ability\" in raw)) return null\n return raw as unknown as StoredAcl\n}\n\nconst getStoredAclFromAggregate = (aggregate: unknown): StoredAcl | null => {\n if (!aggregate || typeof aggregate !== \"object\") return null\n const raw = (aggregate as { options?: unknown }).options\n if (!isRecord(raw)) return null\n const acl = raw.rbAcl\n if (!isRecord(acl)) return null\n if (!(\"ability\" in acl)) return null\n return acl as unknown as StoredAcl\n}\n\nconst addQueryAclFilter = (query: mongoose.Query<unknown, unknown>, action: AclAction): void => {\n const storedAcl = getStoredAclFromQuery(query)\n if (!storedAcl) return\n\n const ability = storedAcl.ability\n const resolvedAction = storedAcl.action ?? action\n const modelName = query.model.modelName\n\n const accessQuery = accessibleBy(ability, resolvedAction).ofType(modelName as AclSubjectType)\n query.and([accessQuery])\n}\n\nconst injectAggregateMatch = (pipeline: PipelineStageLike[], match: Record<string, unknown>): void => {\n if (pipeline.length === 0) {\n pipeline.unshift({ $match: match })\n return\n }\n\n const first = pipeline[0]\n if (!isRecord(first)) {\n pipeline.unshift({ $match: match })\n return\n }\n\n if (\"$geoNear\" in first) {\n const geoNear = first.$geoNear\n if (isRecord(geoNear)) {\n geoNear.query = mergeMongoQuery(geoNear.query, match)\n return\n }\n }\n\n if (\"$search\" in first || \"$vectorSearch\" in first || \"$searchMeta\" in first) {\n pipeline.splice(1, 0, { $match: match })\n return\n }\n\n pipeline.unshift({ $match: match })\n}\n\nconst addAggregateAclFilter = (aggregate: mongoose.Aggregate<unknown>, action: AclAction): void => {\n const storedAcl = getStoredAclFromAggregate(aggregate)\n if (!storedAcl) return\n\n const ability = storedAcl.ability\n const resolvedAction = storedAcl.action ?? action\n const modelName = aggregate.model().modelName\n\n const accessQuery = accessibleBy(ability, resolvedAction).ofType(modelName as AclSubjectType)\n injectAggregateMatch(aggregate.pipeline() as unknown as PipelineStageLike[], accessQuery)\n}\n\nconst patchAggregateAcl = (): void => {\n const globalKey = Symbol.for(\"@rpcbase/db/acl/mongooseAggregateAclPatched\")\n const globalState = globalThis as unknown as Record<string | symbol, unknown>\n if (globalState[globalKey]) return\n globalState[globalKey] = true\n\n const AggregatePrototype = (mongoose.Aggregate as unknown as { prototype: Record<string, unknown> }).prototype\n if (typeof AggregatePrototype.acl === \"function\") return\n\n AggregatePrototype.acl = function(\n this: mongoose.Aggregate<unknown>,\n ability: AppAbility,\n action: AclAction = \"read\",\n ) {\n this.option({ rbAcl: { ability, action } })\n return this\n }\n}\n\nconst createModelAclProxy = <TModel extends mongoose.Model<unknown>>(\n model: TModel,\n ability: AppAbility,\n): TModel => {\n return new Proxy(model, {\n get(target, prop, receiver) {\n const value = Reflect.get(target, prop, receiver) as unknown\n if (typeof value !== \"function\") return value\n return (...args: unknown[]) => {\n const result = Reflect.apply(value, target, args) as unknown\n if (result && typeof result === \"object\" && \"acl\" in result && typeof (result as { acl?: unknown }).acl === \"function\") {\n return (result as { acl: (ability: AppAbility) => unknown }).acl(ability)\n }\n return result\n }\n },\n }) as unknown as TModel\n}\n\ndeclare const mongooseAclPluginBrand: unique symbol\n\ndeclare module \"mongoose\" {\n interface QueryOptions<DocType = unknown> {\n rbAcl?: StoredAcl;\n [mongooseAclPluginBrand]?: DocType;\n }\n\n interface AggregateOptions {\n rbAcl?: StoredAcl;\n }\n\n interface Query<\n ResultType,\n DocType,\n THelpers = {},\n RawDocType = unknown,\n QueryOp = \"find\",\n TDocOverrides = Record<string, never>,\n > {\n [mongooseAclPluginBrand]?: [ResultType, DocType, THelpers, RawDocType, QueryOp, TDocOverrides];\n acl: (ability: AppAbility, action?: AclAction) => this;\n }\n\n interface Aggregate<ResultType> {\n [mongooseAclPluginBrand]?: ResultType;\n acl: (ability: AppAbility, action?: AclAction) => this;\n }\n\n interface Model<\n TRawDocType,\n TQueryHelpers,\n TInstanceMethods,\n TVirtuals,\n THydratedDocumentType,\n TSchema,\n TLeanResultType,\n > {\n [mongooseAclPluginBrand]?: [TRawDocType, TQueryHelpers, TInstanceMethods, TVirtuals, THydratedDocumentType, TSchema, TLeanResultType];\n acl: (ability: AppAbility) => this;\n }\n}\n\nexport const mongooseAclPlugin = (schema: mongoose.Schema): void => {\n patchAggregateAcl()\n\n ;(schema.query as Record<string, unknown>).acl = function(\n this: mongoose.Query<unknown, unknown>,\n ability: AppAbility,\n action?: AclAction,\n ) {\n this.setOptions({ rbAcl: { ability, action } })\n return this\n }\n\n ;(schema.statics as Record<string, unknown>).acl = function(\n this: mongoose.Model<unknown>,\n ability: AppAbility,\n ) {\n return createModelAclProxy(this, ability)\n }\n\n schema.pre(\"aggregate\", function() {\n addAggregateAclFilter(this, \"read\")\n })\n\n schema.pre(\"countDocuments\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"deleteMany\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"deleteOne\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"distinct\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"find\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"findOne\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"findOneAndDelete\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"findOneAndReplace\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"findOneAndUpdate\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"replaceOne\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"updateMany\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"updateOne\", function() {\n addQueryAclFilter(this, \"update\")\n })\n}\n\nexport const _private = {\n injectAggregateMatch,\n mergeMongoQuery,\n}\n","import mongoose from \"mongoose\"\nimport { accessibleRecordsPlugin } from \"@casl/mongoose\"\n\nimport * as frameworkSchemas from \"./models\"\nimport { rtsChangeLogPlugin } from \"./rtsChangeLogPlugin\"\nimport { registerPoliciesFromModules } from \"./acl\"\nimport { mongooseAclPlugin } from \"./acl/mongooseAclPlugin\"\nimport { mongoPaginationPlugin } from \"./pagination/mongoPaginationPlugin\"\n\n\ntype ModelModules = Record<string, unknown>\ntype ModelsScope = \"tenant\" | \"global\"\n\ntype RegisteredSchemas = Record<string, mongoose.Schema>\n\ntype RegisteredModels = {\n tenant: RegisteredSchemas\n global: RegisteredSchemas\n}\n\nlet cachedModels: RegisteredModels | null = null\n\nconst DEFAULT_GLOBAL_RB_MODEL_NAMES_SET = new Set<string>([\n \"RBUser\",\n \"RBTenant\",\n \"RBOAuthRequest\",\n])\n\nconst assertSchema = (exportName: string, value: unknown): mongoose.Schema => {\n if (value instanceof mongoose.Schema) return value\n\n throw new Error(\n [\n `Expected ${exportName} to be an instance of mongoose.Schema, but it was not.`,\n \"rpcbase supports mongoose 9+ only.\",\n \"Fix: ensure the project is using mongoose 9.x and that all packages resolve the same mongoose instance (try `npm ls mongoose`).\",\n ].join(\" \"),\n )\n}\n\nconst getFrameworkSchemaForModelName = (modelName: string): mongoose.Schema | null => {\n const exportName = `${modelName}Schema`\n const value = (frameworkSchemas as unknown as Record<string, unknown>)[exportName]\n if (!(value instanceof mongoose.Schema)) return null\n return value\n}\n\nconst applyTenantPlugins = (schema: mongoose.Schema): void => {\n schema.plugin(accessibleRecordsPlugin)\n schema.plugin(mongooseAclPlugin)\n schema.plugin(mongoPaginationPlugin)\n schema.plugin(rtsChangeLogPlugin)\n}\n\nconst registerSchema = (\n target: RegisteredSchemas,\n other: RegisteredSchemas,\n modelName: string,\n schema: mongoose.Schema,\n scope: ModelsScope,\n): void => {\n if (target[modelName] || other[modelName]) {\n throw new Error(`Duplicate model name \"${modelName}\" across tenant/global scopes`)\n }\n target[modelName] = schema\n}\n\nconst buildSchemasFromModules = (modules: ModelModules): Array<{ modelName: string; schema: mongoose.Schema }> =>\n Object.entries(modules)\n .filter(([key]) => key.endsWith(\"Schema\"))\n .map(([key, schemaValue]) => {\n const schema = assertSchema(key, schemaValue)\n const modelName = key.replace(/Schema$/, \"\")\n return { modelName, schema }\n })\n\nexport const registerModels = ({ tenant, global }: { tenant: ModelModules; global?: ModelModules }) => {\n registerPoliciesFromModules(frameworkSchemas as unknown as Record<string, unknown>)\n registerPoliciesFromModules(tenant)\n\n const tenantSchemas: RegisteredSchemas = {}\n const globalSchemas: RegisteredSchemas = {}\n\n for (const { modelName, schema } of buildSchemasFromModules(frameworkSchemas as unknown as ModelModules)) {\n if (DEFAULT_GLOBAL_RB_MODEL_NAMES_SET.has(modelName)) {\n const cloned = schema.clone()\n registerSchema(globalSchemas, tenantSchemas, modelName, cloned, \"global\")\n } else {\n const cloned = schema.clone()\n applyTenantPlugins(cloned)\n registerSchema(tenantSchemas, globalSchemas, modelName, cloned, \"tenant\")\n }\n }\n\n for (const { modelName, schema } of buildSchemasFromModules(tenant)) {\n if (modelName === \"RBUser\" || modelName === \"RBTenant\") {\n throw new Error(`Invalid tenant model name \"${modelName}\". RBUser/RBTenant are global models.`)\n }\n if (modelName.startsWith(\"RB\")) {\n const frameworkSchema = getFrameworkSchemaForModelName(modelName)\n if (frameworkSchema && schema === frameworkSchema) continue\n throw new Error(`Invalid tenant model name \"${modelName}\". RB* models are reserved for rpcbase.`)\n }\n const cloned = schema.clone()\n applyTenantPlugins(cloned)\n registerSchema(tenantSchemas, globalSchemas, modelName, cloned, \"tenant\")\n }\n\n for (const { modelName, schema } of buildSchemasFromModules(global ?? {})) {\n if (modelName.startsWith(\"RB\")) {\n const frameworkSchema = getFrameworkSchemaForModelName(modelName)\n if (frameworkSchema && schema === frameworkSchema) continue\n throw new Error(`Invalid global model name \"${modelName}\". RB* models are reserved for rpcbase.`)\n }\n const cloned = schema.clone()\n registerSchema(globalSchemas, tenantSchemas, modelName, cloned, \"global\")\n }\n\n const allSchemas = { ...globalSchemas, ...tenantSchemas }\n\n for (const [modelName, schema] of Object.entries(allSchemas)) {\n if (!mongoose.models[modelName]) {\n mongoose.model(modelName, schema)\n }\n }\n\n cachedModels = {\n tenant: { ...(cachedModels?.tenant ?? {}), ...tenantSchemas },\n global: { ...(cachedModels?.global ?? {}), ...globalSchemas },\n }\n}\n\nexport const getRegisteredModels = (scope: ModelsScope) => {\n if (!cachedModels) {\n throw new Error(\"Models not registered. Call createModels(...) once at startup (or import your models module) before using models.get.\")\n }\n return cachedModels[scope]\n}\n\nexport type { ModelModules, ModelsScope }\n","import assert from \"assert\"\n\nimport { getGlobalDbName, getTenantDbName } from \"./dbNames\"\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport { getRegisteredModels, registerModels, type ModelsScope } from \"./registerModels\"\n\n\nexport type LoadModelCtx = {\n req: {\n session?: {\n user?: {\n currentTenantId?: string;\n }\n } | null;\n };\n};\n\nconst loadModelFromDb = async (\n modelName: string,\n dbName: string,\n scope: ModelsScope,\n) => {\n const schemas = getRegisteredModels(scope)\n const schema = schemas[modelName]\n assert(schema, `Model ${modelName} not registered. Available models: ${Object.keys(schemas).join(\", \")}`)\n\n const modelConnection = await ensureMongooseConnection(dbName)\n\n if (!modelConnection.models[modelName]) {\n modelConnection.model(modelName, schema)\n }\n\n return modelConnection.models[modelName]\n}\n\nconst getTenantIdFromCtx = (ctx: LoadModelCtx): string => {\n const tenantId = ctx.req.session?.user?.currentTenantId\n assert(typeof tenantId === \"string\" && tenantId.trim(), \"Tenant ID is missing from session\")\n return tenantId\n}\n\nexport const models = {\n register: registerModels,\n\n get: async (modelName: string, ctx: LoadModelCtx) => {\n const tenantId = getTenantIdFromCtx(ctx)\n const dbName = getTenantDbName(tenantId)\n return loadModelFromDb(modelName, dbName, \"tenant\")\n },\n\n getGlobal: async (modelName: string, ctx: LoadModelCtx) => {\n const dbName = getGlobalDbName()\n return loadModelFromDb(modelName, dbName, \"global\")\n },\n} as const\n","import type { LoadModelCtx } from \"./modelsApi\"\nimport type { ModelModules } from \"./registerModels\"\nimport type * as frameworkSchemas from \"./models\"\nimport { models } from \"./modelsApi\"\nimport { registerModels } from \"./registerModels\"\n\n\ntype ExtractModelNamesFromSchemas<TModules> = {\n [K in keyof TModules]-?: K extends `${infer Name}Schema` ? Name : never\n}[keyof TModules] & string\n\ntype FrameworkModelName = ExtractModelNamesFromSchemas<typeof frameworkSchemas>\n\ntype RpcbaseGlobalModelName = Extract<FrameworkModelName, \"RBUser\" | \"RBTenant\" | \"RBOAuthRequest\">\n\nexport type TenantModelName<TTenantModules extends ModelModules> =\n ExtractModelNamesFromSchemas<TTenantModules>\n\nexport type GlobalModelName<TGlobalModules extends ModelModules> =\n | RpcbaseGlobalModelName\n | ExtractModelNamesFromSchemas<TGlobalModules>\n\ntype LoadedTenantModel = Awaited<ReturnType<(typeof models)[\"get\"]>>\ntype LoadedGlobalModel = Awaited<ReturnType<(typeof models)[\"getGlobal\"]>>\n\ntype ModelsGetFn<TTenantModules extends ModelModules> = {\n (modelName: TenantModelName<TTenantModules>, ctx: LoadModelCtx): ReturnType<(typeof models)[\"get\"]>\n <const TNames extends readonly TenantModelName<TTenantModules>[]>(\n modelNames: TNames,\n ctx: LoadModelCtx,\n ): Promise<{ [K in keyof TNames]: LoadedTenantModel }>\n}\n\ntype ModelsGetGlobalFn<TGlobalModules extends ModelModules> = {\n (modelName: GlobalModelName<TGlobalModules>, ctx: LoadModelCtx): ReturnType<(typeof models)[\"getGlobal\"]>\n <const TNames extends readonly GlobalModelName<TGlobalModules>[]>(\n modelNames: TNames,\n ctx: LoadModelCtx,\n ): Promise<{ [K in keyof TNames]: LoadedGlobalModel }>\n}\n\nexport type ModelsConfig<TTenantModules extends ModelModules, TGlobalModules extends ModelModules> = {\n tenant: TTenantModules\n global?: TGlobalModules\n}\n\nexport type ModelsClient<TTenantModules extends ModelModules, TGlobalModules extends ModelModules> = {\n register: (modules: ModelsConfig<TTenantModules, TGlobalModules>) => void\n get: ModelsGetFn<TTenantModules>\n getGlobal: ModelsGetGlobalFn<TGlobalModules>\n}\n\nexport const createModels = <\n TTenantModules extends ModelModules,\n TGlobalModules extends ModelModules = Record<string, never>,\n>(modules: ModelsConfig<TTenantModules, TGlobalModules>): ModelsClient<TTenantModules, TGlobalModules> => {\n registerModels(modules)\n\n const get = (async (\n modelNameOrNames: TenantModelName<TTenantModules> | readonly TenantModelName<TTenantModules>[],\n ctx: LoadModelCtx,\n ) => {\n if (Array.isArray(modelNameOrNames)) {\n return Promise.all(modelNameOrNames.map((modelName) => models.get(modelName as string, ctx)))\n }\n return models.get(modelNameOrNames as string, ctx)\n }) as ModelsClient<TTenantModules, TGlobalModules>[\"get\"]\n\n const getGlobal = (async (\n modelNameOrNames: GlobalModelName<TGlobalModules> | readonly GlobalModelName<TGlobalModules>[],\n ctx: LoadModelCtx,\n ) => {\n if (Array.isArray(modelNameOrNames)) {\n return Promise.all(modelNameOrNames.map((modelName) => models.getGlobal(modelName as string, ctx)))\n }\n return models.getGlobal(modelNameOrNames as string, ctx)\n }) as ModelsClient<TTenantModules, TGlobalModules>[\"getGlobal\"]\n\n return {\n register: registerModels,\n get,\n getGlobal,\n }\n}\n","import assert from \"assert\"\n\nimport type mongoose from \"mongoose\"\n\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport type { LoadModelCtx } from \"./modelsApi\"\n\n\nconst getAppName = (): string => {\n const appName = process.env.APP_NAME?.trim()\n assert(appName, \"Missing APP_NAME\")\n return appName\n}\n\nconst normalizeTenantId = (tenantId: string): string => {\n const normalized = tenantId.trim()\n assert(normalized, \"Tenant ID is missing\")\n return normalized\n}\n\nexport const getTenantFilesystemDbName = (tenantId: string): string =>\n `${getAppName()}-${normalizeTenantId(tenantId)}-filesystem-db`\n\nexport const getTenantFilesystemDb = async (tenantId: string): Promise<mongoose.Connection> =>\n ensureMongooseConnection(getTenantFilesystemDbName(tenantId))\n\nexport const getTenantFilesystemDbFromCtx = async (ctx: LoadModelCtx): Promise<mongoose.Connection> => {\n const tenantId = ctx.req.session?.user?.currentTenantId\n assert(typeof tenantId === \"string\" && tenantId.trim(), \"Tenant ID is missing from session\")\n return getTenantFilesystemDb(tenantId)\n}\n","import type mongoose from \"mongoose\"\nimport type { ClientSession } from \"mongoose\"\n\nimport { getGlobalDbName, getTenantDbName } from \"./dbNames\"\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport type { LoadModelCtx } from \"./modelsApi\"\nimport { getTenantFilesystemDbName } from \"./tenantFilesystemDb\"\n\n\ntype MongooseTransactionOptions = Parameters<ClientSession[\"withTransaction\"]>[1]\n\nexport type TenantGlobalFilesystemTransactionCtx = {\n tenantId: string\n session: ClientSession\n ctx: {\n tenant: LoadModelCtx\n global: LoadModelCtx\n }\n db: {\n tenant: mongoose.Connection\n global: mongoose.Connection\n filesystem: mongoose.Connection\n }\n}\n\ntype WithTransactionScope =\n | string\n | { tenantId: string }\n | { ctx: LoadModelCtx }\n\nconst getTenantIdFromLoadModelCtx = (ctx: LoadModelCtx): string => {\n const raw = ctx.req.session?.user?.currentTenantId\n if (typeof raw !== \"string\") {\n throw new Error(\"Tenant ID is missing from ctx\")\n }\n const tenantId = raw.trim()\n if (!tenantId) {\n throw new Error(\"Tenant ID is missing from ctx\")\n }\n return tenantId\n}\n\nconst buildTenantLoadModelCtx = (tenantId: string): LoadModelCtx => ({\n req: {\n session: {\n user: {\n currentTenantId: tenantId,\n },\n },\n },\n})\n\nexport function withTransaction<T>(\n tenantId: string,\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T>\nexport function withTransaction<T>(\n scope: { tenantId: string } | { ctx: LoadModelCtx },\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T>\nexport async function withTransaction<T>(\n scope: WithTransactionScope,\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T> {\n const normalizedTenantId = (() => {\n if (typeof scope === \"string\") return scope.trim()\n if (\"tenantId\" in scope) return scope.tenantId.trim()\n return getTenantIdFromLoadModelCtx(scope.ctx)\n })()\n\n if (!normalizedTenantId) throw new Error(\"Tenant ID is missing\")\n\n const tenantDbName = getTenantDbName(normalizedTenantId)\n const globalDbName = getGlobalDbName()\n const filesystemDbName = getTenantFilesystemDbName(normalizedTenantId)\n\n const tenantDb = await ensureMongooseConnection(tenantDbName)\n const globalDb = await ensureMongooseConnection(globalDbName)\n const filesystemDb = await ensureMongooseConnection(filesystemDbName)\n\n const session = await tenantDb.startSession()\n\n const tenantCtx: LoadModelCtx = typeof scope === \"object\" && \"ctx\" in scope\n ? scope.ctx\n : buildTenantLoadModelCtx(normalizedTenantId)\n\n const globalCtx: LoadModelCtx = { req: { session: null } }\n\n try {\n return await session.withTransaction(async () => fn({\n tenantId: normalizedTenantId,\n session,\n ctx: {\n tenant: tenantCtx,\n global: globalCtx,\n },\n db: {\n tenant: tenantDb,\n global: globalDb,\n filesystem: filesystemDb,\n },\n }), options)\n } finally {\n await session.endSession()\n }\n}\n"],"names":["ZRBUser","z","object","email","string","optional","password","name","phone","tenants","array","tenantRoles","record","oauthProviders","subject","accessToken","refreshToken","idToken","scope","tokenType","expiresAt","date","rawUserInfo","unknown","createdAt","updatedAt","emailVerificationCode","length","emailVerificationExpiresAt","RBUserSchema","Schema","type","String","unique","sparse","required","index","Map","of","default","Date","Types","Mixed","_id","ZRBTenant","tenantId","parentTenantId","RBTenantSchema","ZRBTenantSubscriptionStatus","enum","ZRBTenantSubscriptionIntervalUnit","ZRBTenantSubscriptionType","ZRBTenantSubscriptionScope","ZRBTenantSubscription","subscriptionId","parentSubscriptionId","scopeId","planKey","status","intervalUnit","intervalCount","number","int","min","modules","currentPeriodStart","currentPeriodEnd","trialEndsAt","cancelAt","cancelAtPeriodEnd","boolean","canceledAt","provider","providerCustomerId","providerSubscriptionId","latestEventId","latestEventAt","metadata","RBTenantSubscriptionSchema","options","Number","Boolean","ZRBTenantSubscriptionEventSource","ZRBTenantSubscriptionChangeDirection","ZRBTenantSubscriptionEvent","occurredAt","effectiveAt","fromPlanKey","toPlanKey","fromStatus","toStatus","fromModules","toModules","fromIntervalUnit","toIntervalUnit","fromIntervalCount","toIntervalCount","direction","actorUserId","source","reason","providerEventId","providerPayload","RBTenantSubscriptionEventSchema","now","undefined","ZRBRtsCounter","seq","RBRtsCounterSchema","versionKey","ttlSecondsRaw","process","env","RB_RTS_CHANGES_TTL_S","ttlSeconds","isFinite","Math","max","floor","ZRBRtsChangeOp","ZRBRtsChange","modelName","op","docId","ts","RBRtsChangeSchema","expireAfterSeconds","ZRBUploadSessionStatus","ZRBUploadSession","userId","ownerKeyHash","filename","mimeType","totalSize","chunkSize","chunksTotal","fileId","isPublic","error","RBUploadSessionSchema","RBUploadSessionPolicy","define","builder","ctx","can","uploadKeyHash","claims","trim","ZRBUploadChunk","uploadId","data","size","sha256","RBUploadChunkSchema","Buffer","ZRBNotification","topic","title","body","url","seenAt","readAt","archivedAt","TTL_90_DAYS_S","RBNotificationSchema","RBNotificationPolicy","ZRBNotificationDigestFrequency","ZRBNotificationTopicPreference","inApp","emailDigest","push","ZRBNotificationSettings","digestFrequency","topicPreferences","lastDigestSentAt","TopicPreferenceSchema","RBNotificationSettingsSchema","timestamps","RBNotificationSettingsPolicy","ZRBOAuthRequest","providerId","codeVerifier","returnTo","RBOAuthRequestSchema","extendMongooseSchema","baseSchema","extensions","schema","clone","forEach","extension","add","omitMongooseSchemaPaths","paths","path","remove","localizedStringField","userGet","get","value","withLocalizedStringFallback","model","mongoose","PaginationValidationError","Error","code","statusCode","constructor","message","isPaginationValidationError","anyError","DISALLOWED_MONGO_FIELD_SEGMENTS","Set","PAGINATION_LIMIT_MAX","normalizePaginationSpec","spec","limit","normalizeLimit","Array","isArray","sort","map","field","order","assertSafeMongoFieldPath","normalizeOrder","seenFields","has","primaryOrder","isInteger","startsWith","parts","split","part","test","encodePaginationCursor","node","normalized","values","Object","create","readFieldValue","encodeCursorValue","payload","v","payloadB64","from","JSON","stringify","toString","sigB64","signCursorPayloadB64","signingSecret","decodePaginationCursor","cursor","rest","verifyCursorSignature","payloadRaw","payloadUnknown","parse","decoded","prototype","hasOwnProperty","call","encodedValue","decodeCursorValue","secret","createHmac","update","digest","expectedSigB64","a","b","timingSafeEqual","ObjectId","$oid","toHexString","$date","toISOString","d","isNaN","getTime","isValid","reduce","acc","key","compileMongoPagination","mongoLimit","mongoSort","toMongoSort","mongoFilterDelta","cursorValues","buildKeysetFilterDelta","forQueryOrder","invertOrder","branches","i","current","and","j","prev","eq","getKeysetOp","cmpOp","cmp","$and","$or","materializeMongoPagination","compiled","fetchedNodes","hasMore","trimmed","slice","nodes","reverse","hasPrevPage","hasNextPage","pageInfo","prevCursor","nextCursor","MongoAdapter","applyPagination","query","where","paginateMongoQuery","pagination","exec","getQueryOptions","getOptions","getPaginationFromOptions","getCursorFromOptions","paginationCursor","mongoPaginationPlugin","pluginOptions","paginate","buildSearchTextStage","stage","$search","text","highlightPath","highlight","searchMetaProjection","score","$meta","highlights","listResultHasIndex","listResult","firstBatch","some","idx","isIndexAlreadyExistsError","codeName","ensureSearchIndex","params","collection","db","command","listSearchIndexes","created","createSearchIndexes","indexes","definition","getAppName","appName","APP_NAME","GLOBAL_DB_SUFFIX","getGlobalDbName","getTenantDbName","getMongoUrl","explicitUrl","MONGODB_URL","MONGO_URL","MONGODB_URI","DB_URL","port","DB_PORT","host","DB_HOST","connections","rootConnection","waitForOpen","connection","readyState","Promise","resolve","reject","once","ensureMongooseConnection","dbName","normalizedDbName","existing","mongoUrl","createConnection","sanitizeFilter","useDb","useCache","set","RTS_COUNTER_ID","EXCLUDED_MODEL_NAMES","maxDeleteIdsRaw","RB_RTS_DELETE_LOG_MAX_IDS","maxDeleteIds","deleteMetaByQuery","WeakMap","hasToString","maybe","normalizeId","id","getDbName","raw","databaseName","isGlobalDb","endsWith","getQuerySession","opts","session","getRtsModels","RtsCounter","models","RBRtsCounter","RtsChange","RBRtsChange","allocateSeqRange","count","updated","findOneAndUpdate","$inc","upsert","new","setDefaultsOnInsert","projection","lean","end","start","insertChanges","changes","docs","c","insertMany","recordDeleteChanges","ids","uniqueIds","filter","recordResetModel","captureDeleteMeta","mode","getFilter","getQuery","findQuery","find","reset","trimmedIds","meta","flushDeleteMeta","delete","rtsChangeLogPlugin","pre","document","post","doc","isRecord","mergeMongoQuery","left","right","leftQuery","keys","getStoredAclFromQuery","rbAcl","getStoredAclFromAggregate","aggregate","acl","addQueryAclFilter","action","storedAcl","ability","resolvedAction","accessQuery","accessibleBy","ofType","injectAggregateMatch","pipeline","match","unshift","$match","first","geoNear","$geoNear","splice","addAggregateAclFilter","patchAggregateAcl","globalKey","Symbol","for","globalState","globalThis","AggregatePrototype","Aggregate","option","createModelAclProxy","Proxy","target","prop","receiver","Reflect","args","result","apply","mongooseAclPlugin","setOptions","statics","cachedModels","DEFAULT_GLOBAL_RB_MODEL_NAMES_SET","assertSchema","exportName","join","getFrameworkSchemaForModelName","frameworkSchemas","applyTenantPlugins","plugin","accessibleRecordsPlugin","registerSchema","other","buildSchemasFromModules","entries","schemaValue","replace","registerModels","tenant","global","registerPoliciesFromModules","tenantSchemas","globalSchemas","cloned","frameworkSchema","allSchemas","getRegisteredModels","loadModelFromDb","schemas","assert","modelConnection","getTenantIdFromCtx","req","user","currentTenantId","register","getGlobal","createModels","modelNameOrNames","all","normalizeTenantId","getTenantFilesystemDbName","getTenantFilesystemDb","getTenantFilesystemDbFromCtx","getTenantIdFromLoadModelCtx","buildTenantLoadModelCtx","withTransaction","fn","normalizedTenantId","tenantDbName","globalDbName","filesystemDbName","tenantDb","globalDb","filesystemDb","startSession","tenantCtx","globalCtx","filesystem","endSession"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/models/RBUser.ts","../src/models/RBTenant.ts","../src/models/RBTenantSubscription.ts","../src/models/RBTenantSubscriptionEvent.ts","../src/models/RBRtsCounter.ts","../src/models/RBRtsChange.ts","../src/models/RBUploadSession.ts","../src/models/RBUploadChunk.ts","../src/models/RBNotification.ts","../src/models/RBNotificationSettings.ts","../src/models/RBOAuthRequest.ts","../src/mongoose/extendMongooseSchema.ts","../src/mongoose/localizedStringField.ts","../src/mongoose/index.ts","../src/pagination/errors.ts","../src/pagination/normalizeSpec.ts","../src/pagination/cursor.ts","../src/pagination/compileMongoPagination.ts","../src/pagination/materializePagination.ts","../src/pagination/mongoAdapter.ts","../src/pagination/paginateMongoQuery.ts","../src/pagination/mongoPaginationPlugin.ts","../src/search/index.ts","../src/dbNames.ts","../src/getMongoUrl.ts","../src/ensureMongooseConnection.ts","../src/rtsChangeLogPlugin.ts","../src/acl/mongooseAclPlugin.ts","../src/registerModels.ts","../src/modelsApi.ts","../src/createModels.ts","../src/tenantFilesystemDb.ts","../src/transactions.ts"],"sourcesContent":["import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBUser = z.object({\n email: z.string().email().optional(),\n password: z.string(),\n name: z.string().optional(),\n phone: z.string().optional(),\n tenants: z.array(z.string()),\n tenantRoles: z.record(z.string(), z.array(z.string())).optional(),\n oauthProviders: z.record(z.string(), z.object({\n subject: z.string(),\n email: z.string().email().optional(),\n name: z.string().optional(),\n accessToken: z.string().optional(),\n refreshToken: z.string().optional(),\n idToken: z.string().optional(),\n scope: z.string().optional(),\n tokenType: z.string().optional(),\n expiresAt: z.date().optional(),\n rawUserInfo: z.unknown().optional(),\n createdAt: z.date().optional(),\n updatedAt: z.date().optional(),\n })).optional(),\n emailVerificationCode: z.string().length(6).optional(),\n emailVerificationExpiresAt: z.date().optional(),\n})\n\nexport type IRBUser = z.infer<typeof ZRBUser>;\n\nexport const RBUserSchema: Schema = new Schema({\n email: { type: String, unique: true, sparse: true },\n phone: { type: String, unique: true, sparse: true },\n password: { type: String, required: true },\n name: String,\n tenants: { type: [String], index: true, required: true },\n tenantRoles: { type: Map, of: [String], required: false, default: {} },\n oauthProviders: {\n type: Map,\n of: new Schema({\n subject: { type: String, required: true },\n email: { type: String, required: false },\n name: { type: String, required: false },\n accessToken: { type: String, required: false },\n refreshToken: { type: String, required: false },\n idToken: { type: String, required: false },\n scope: { type: String, required: false },\n tokenType: { type: String, required: false },\n expiresAt: { type: Date, required: false },\n rawUserInfo: { type: Schema.Types.Mixed, required: false },\n createdAt: { type: Date, required: false },\n updatedAt: { type: Date, required: false },\n }, { _id: false }),\n default: {},\n required: false,\n },\n emailVerificationCode: { type: String, required: false },\n emailVerificationExpiresAt: { type: Date, required: false }\n})\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBTenant = z.object({\n tenantId: z.string(),\n parentTenantId: z.string().optional(),\n name: z.string().optional(),\n})\n\nexport type IRBTenant = z.infer<typeof ZRBTenant>;\n\nexport const RBTenantSchema: Schema = new Schema({\n tenantId: { type: String, required: true, unique: true, index: true },\n parentTenantId: { type: String },\n name: { type: String },\n})\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBTenantSubscriptionStatus = z.enum([\n \"trialing\",\n \"active\",\n \"past_due\",\n \"paused\",\n \"canceled\",\n \"expired\",\n])\n\nexport const ZRBTenantSubscriptionIntervalUnit = z.enum([\"month\", \"year\"])\n\nexport const ZRBTenantSubscriptionType = z.enum([\"primary\", \"addon\"])\n\nexport const ZRBTenantSubscriptionScope = z.enum([\"tenant\", \"shop\", \"custom\"])\n\nexport const ZRBTenantSubscription = z.object({\n tenantId: z.string(),\n subscriptionId: z.string(),\n type: ZRBTenantSubscriptionType.optional(),\n parentSubscriptionId: z.string().optional(),\n scope: ZRBTenantSubscriptionScope.optional(),\n scopeId: z.string().optional(),\n planKey: z.string(),\n status: ZRBTenantSubscriptionStatus,\n intervalUnit: ZRBTenantSubscriptionIntervalUnit,\n intervalCount: z.number().int().min(1).optional(),\n modules: z.array(z.string()).optional(),\n currentPeriodStart: z.date().optional(),\n currentPeriodEnd: z.date().optional(),\n trialEndsAt: z.date().optional(),\n cancelAt: z.date().optional(),\n cancelAtPeriodEnd: z.boolean().optional(),\n canceledAt: z.date().optional(),\n provider: z.string().optional(),\n providerCustomerId: z.string().optional(),\n providerSubscriptionId: z.string().optional(),\n latestEventId: z.string().optional(),\n latestEventAt: z.date().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBTenantSubscription = z.infer<typeof ZRBTenantSubscription>\n\nexport const RBTenantSubscriptionSchema: Schema = new Schema(\n {\n tenantId: { type: String, required: true, index: true },\n subscriptionId: { type: String, required: true },\n type: { type: String, required: true, enum: ZRBTenantSubscriptionType.options, default: \"primary\" },\n parentSubscriptionId: { type: String },\n scope: { type: String, enum: ZRBTenantSubscriptionScope.options, default: \"tenant\" },\n scopeId: { type: String },\n planKey: { type: String, required: true },\n status: { type: String, required: true, enum: ZRBTenantSubscriptionStatus.options },\n intervalUnit: { type: String, required: true, enum: ZRBTenantSubscriptionIntervalUnit.options },\n intervalCount: { type: Number, min: 1, default: 1 },\n modules: { type: [String], default: [] },\n currentPeriodStart: { type: Date },\n currentPeriodEnd: { type: Date },\n trialEndsAt: { type: Date },\n cancelAt: { type: Date },\n cancelAtPeriodEnd: { type: Boolean, default: false },\n canceledAt: { type: Date },\n provider: { type: String },\n providerCustomerId: { type: String },\n providerSubscriptionId: { type: String },\n latestEventId: { type: String },\n latestEventAt: { type: Date },\n metadata: { type: Schema.Types.Mixed },\n },\n)\n\nRBTenantSubscriptionSchema.index({ tenantId: 1, subscriptionId: 1 }, { unique: true })\nRBTenantSubscriptionSchema.index({ tenantId: 1, scope: 1, scopeId: 1 })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport {\n ZRBTenantSubscriptionIntervalUnit,\n ZRBTenantSubscriptionStatus,\n} from \"./RBTenantSubscription\"\n\n\nexport const ZRBTenantSubscriptionEventSource = z.enum([\n \"admin\",\n \"system\",\n \"webhook\",\n \"user\",\n])\n\nexport const ZRBTenantSubscriptionChangeDirection = z.enum([\n \"upgrade\",\n \"downgrade\",\n \"lateral\",\n])\n\nexport const ZRBTenantSubscriptionEvent = z.object({\n tenantId: z.string(),\n subscriptionId: z.string(),\n type: z.string(),\n occurredAt: z.date(),\n effectiveAt: z.date().optional(),\n fromPlanKey: z.string().optional(),\n toPlanKey: z.string().optional(),\n fromStatus: ZRBTenantSubscriptionStatus.optional(),\n toStatus: ZRBTenantSubscriptionStatus.optional(),\n fromModules: z.array(z.string()).optional(),\n toModules: z.array(z.string()).optional(),\n fromIntervalUnit: ZRBTenantSubscriptionIntervalUnit.optional(),\n toIntervalUnit: ZRBTenantSubscriptionIntervalUnit.optional(),\n fromIntervalCount: z.number().int().min(1).optional(),\n toIntervalCount: z.number().int().min(1).optional(),\n direction: ZRBTenantSubscriptionChangeDirection.optional(),\n actorUserId: z.string().optional(),\n source: ZRBTenantSubscriptionEventSource.optional(),\n reason: z.string().optional(),\n provider: z.string().optional(),\n providerEventId: z.string().optional(),\n providerPayload: z.unknown().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBTenantSubscriptionEvent = z.infer<typeof ZRBTenantSubscriptionEvent>\n\nexport const RBTenantSubscriptionEventSchema: Schema = new Schema(\n {\n tenantId: { type: String, required: true, index: true },\n subscriptionId: { type: String, required: true, index: true },\n type: { type: String, required: true },\n occurredAt: { type: Date, required: true, default: Date.now },\n effectiveAt: { type: Date },\n fromPlanKey: { type: String },\n toPlanKey: { type: String },\n fromStatus: { type: String, enum: ZRBTenantSubscriptionStatus.options },\n toStatus: { type: String, enum: ZRBTenantSubscriptionStatus.options },\n fromModules: { type: [String], default: undefined },\n toModules: { type: [String], default: undefined },\n fromIntervalUnit: { type: String, enum: ZRBTenantSubscriptionIntervalUnit.options },\n toIntervalUnit: { type: String, enum: ZRBTenantSubscriptionIntervalUnit.options },\n fromIntervalCount: { type: Number, min: 1 },\n toIntervalCount: { type: Number, min: 1 },\n direction: { type: String, enum: ZRBTenantSubscriptionChangeDirection.options },\n actorUserId: { type: String },\n source: { type: String, enum: ZRBTenantSubscriptionEventSource.options },\n reason: { type: String },\n provider: { type: String },\n providerEventId: { type: String },\n providerPayload: { type: Schema.Types.Mixed },\n metadata: { type: Schema.Types.Mixed },\n },\n)\n\nRBTenantSubscriptionEventSchema.index({ tenantId: 1, subscriptionId: 1, occurredAt: 1 })\nRBTenantSubscriptionEventSchema.index({ provider: 1, providerEventId: 1 }, { unique: true, sparse: true })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBRtsCounter = z.object({\n _id: z.string(),\n seq: z.number().int().min(0),\n})\n\nexport type IRBRtsCounter = z.infer<typeof ZRBRtsCounter>\n\nexport const RBRtsCounterSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n seq: { type: Number, required: true, default: 0 },\n },\n {\n versionKey: false,\n },\n)\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nconst ttlSecondsRaw = process.env.RB_RTS_CHANGES_TTL_S ?? \"\"\nconst ttlSeconds = Number.isFinite(Number(ttlSecondsRaw)) ? Math.max(60, Math.floor(Number(ttlSecondsRaw))) : 60 * 60 * 24 * 30\n\nexport const ZRBRtsChangeOp = z.enum([\"delete\", \"reset_model\"])\n\nexport const ZRBRtsChange = z.object({\n seq: z.number().int().min(0),\n modelName: z.string(),\n op: ZRBRtsChangeOp,\n docId: z.string().optional(),\n ts: z.date(),\n})\n\nexport type IRBRtsChange = z.infer<typeof ZRBRtsChange>\n\nexport const RBRtsChangeSchema: Schema = new Schema(\n {\n seq: { type: Number, required: true },\n modelName: { type: String, required: true, index: true },\n op: { type: String, required: true, enum: ZRBRtsChangeOp.options },\n docId: { type: String, required: false },\n ts: { type: Date, required: true, default: Date.now },\n },\n {\n versionKey: false,\n },\n)\n\nRBRtsChangeSchema.index({ seq: 1 }, { unique: true })\nRBRtsChangeSchema.index({ ts: 1 }, { expireAfterSeconds: ttlSeconds })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBUploadSessionStatus = z.enum([\"uploading\", \"assembling\", \"done\", \"error\"])\n\nexport const ZRBUploadSession = z.object({\n _id: z.string(),\n userId: z.string().optional(),\n ownerKeyHash: z.string().optional(),\n filename: z.string(),\n mimeType: z.string(),\n totalSize: z.number().int().min(0),\n chunkSize: z.number().int().min(1),\n chunksTotal: z.number().int().min(1),\n status: ZRBUploadSessionStatus,\n createdAt: z.date(),\n expiresAt: z.date(),\n fileId: z.string().optional(),\n isPublic: z.boolean().optional(),\n error: z.string().optional(),\n})\n\nexport type IRBUploadSession = z.infer<typeof ZRBUploadSession>\n\nexport const RBUploadSessionSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n userId: { type: String, required: false, index: true },\n ownerKeyHash: { type: String, required: false },\n filename: { type: String, required: true },\n mimeType: { type: String, required: true },\n totalSize: { type: Number, required: true },\n chunkSize: { type: Number, required: true },\n chunksTotal: { type: Number, required: true },\n status: { type: String, required: true, enum: ZRBUploadSessionStatus.options },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n fileId: { type: String, required: false },\n isPublic: { type: Boolean, required: false },\n error: { type: String, required: false },\n },\n {\n versionKey: false,\n },\n)\n\nRBUploadSessionSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n\nexport const RBUploadSessionPolicy: AclPolicy = {\n subject: \"RBUploadSession\",\n define: (builder, ctx) => {\n builder.can(\"create\", \"RBUploadSession\")\n\n if (ctx.userId) {\n builder.can(\"read\", \"RBUploadSession\", { userId: ctx.userId })\n builder.can(\"update\", \"RBUploadSession\", { userId: ctx.userId })\n builder.can(\"delete\", \"RBUploadSession\", { userId: ctx.userId })\n }\n\n const uploadKeyHash = typeof ctx.claims?.uploadKeyHash === \"string\" ? ctx.claims.uploadKeyHash.trim() : \"\"\n if (uploadKeyHash) {\n builder.can(\"read\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n builder.can(\"update\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n builder.can(\"delete\", \"RBUploadSession\", { ownerKeyHash: uploadKeyHash })\n }\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBUploadChunk = z.object({\n uploadId: z.string(),\n index: z.number().int().min(0),\n data: z.unknown(),\n size: z.number().int().min(0),\n sha256: z.string().optional(),\n createdAt: z.date(),\n expiresAt: z.date(),\n})\n\nexport type IRBUploadChunk = z.infer<typeof ZRBUploadChunk>\n\nexport const RBUploadChunkSchema: Schema = new Schema(\n {\n uploadId: { type: String, required: true, index: true },\n index: { type: Number, required: true },\n data: { type: Buffer, required: true },\n size: { type: Number, required: true },\n sha256: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n },\n {\n versionKey: false,\n },\n)\n\nRBUploadChunkSchema.index({ uploadId: 1, index: 1 }, { unique: true })\nRBUploadChunkSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBNotification = z.object({\n userId: z.string(),\n topic: z.string().optional(),\n title: z.string(),\n body: z.string().optional(),\n url: z.string().optional(),\n createdAt: z.date(),\n seenAt: z.date().optional(),\n readAt: z.date().optional(),\n archivedAt: z.date().optional(),\n metadata: z.record(z.string(), z.unknown()).optional(),\n})\n\nexport type IRBNotification = z.infer<typeof ZRBNotification>\n\nconst TTL_90_DAYS_S = 60 * 60 * 24 * 90\n\nexport const RBNotificationSchema: Schema = new Schema(\n {\n userId: { type: String, required: true, index: true },\n topic: { type: String, required: false, index: true },\n title: { type: String, required: true },\n body: { type: String, required: false },\n url: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now, index: true },\n seenAt: { type: Date, required: false, index: true },\n readAt: { type: Date, required: false, index: true },\n archivedAt: { type: Date, required: false },\n metadata: { type: Schema.Types.Mixed, required: false },\n },\n {\n versionKey: false,\n },\n)\n\nRBNotificationSchema.index({ userId: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ userId: 1, seenAt: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ userId: 1, readAt: 1, archivedAt: 1, createdAt: -1 })\nRBNotificationSchema.index({ archivedAt: 1 }, { expireAfterSeconds: TTL_90_DAYS_S })\n\nexport const RBNotificationPolicy: AclPolicy = {\n subject: \"RBNotification\",\n define: (builder, ctx) => {\n if (!ctx.userId) return\n builder.can(\"create\", \"RBNotification\")\n builder.can(\"read\", \"RBNotification\", { userId: ctx.userId })\n builder.can(\"update\", \"RBNotification\", { userId: ctx.userId })\n builder.can(\"delete\", \"RBNotification\", { userId: ctx.userId })\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\nimport type { AclPolicy } from \"../acl\"\n\n\nexport const ZRBNotificationDigestFrequency = z.enum([\"off\", \"daily\", \"weekly\"])\n\nexport const ZRBNotificationTopicPreference = z.object({\n topic: z.string(),\n inApp: z.boolean(),\n emailDigest: z.boolean(),\n push: z.boolean(),\n})\n\nexport const ZRBNotificationSettings = z.object({\n userId: z.string(),\n digestFrequency: ZRBNotificationDigestFrequency,\n topicPreferences: z.array(ZRBNotificationTopicPreference).optional(),\n lastDigestSentAt: z.date().optional(),\n})\n\nexport type IRBNotificationSettings = z.infer<typeof ZRBNotificationSettings>\n\nconst TopicPreferenceSchema = new Schema(\n {\n topic: { type: String, required: true },\n inApp: { type: Boolean, required: true, default: true },\n emailDigest: { type: Boolean, required: true, default: true },\n push: { type: Boolean, required: true, default: false },\n },\n { _id: false },\n)\n\nexport const RBNotificationSettingsSchema: Schema = new Schema(\n {\n userId: { type: String, required: true },\n digestFrequency: {\n type: String,\n required: true,\n enum: ZRBNotificationDigestFrequency.options,\n default: \"weekly\",\n },\n topicPreferences: {\n type: [TopicPreferenceSchema],\n default: [],\n },\n lastDigestSentAt: { type: Date, required: false },\n },\n {\n versionKey: false,\n timestamps: true,\n },\n)\n\nRBNotificationSettingsSchema.index({ userId: 1 }, { unique: true })\nRBNotificationSettingsSchema.index({ userId: 1, \"topicPreferences.topic\": 1 })\n\nexport const RBNotificationSettingsPolicy: AclPolicy = {\n subject: \"RBNotificationSettings\",\n define: (builder, ctx) => {\n if (!ctx.userId) return\n builder.can(\"create\", \"RBNotificationSettings\")\n builder.can(\"read\", \"RBNotificationSettings\", { userId: ctx.userId })\n builder.can(\"update\", \"RBNotificationSettings\", { userId: ctx.userId })\n },\n}\n","import { Schema } from \"mongoose\"\nimport { z } from \"zod\"\n\n\nexport const ZRBOAuthRequest = z.object({\n _id: z.string(),\n providerId: z.string(),\n codeVerifier: z.string(),\n returnTo: z.string().optional(),\n createdAt: z.date(),\n expiresAt: z.date(),\n})\n\nexport type IRBOAuthRequest = z.infer<typeof ZRBOAuthRequest>\n\nexport const RBOAuthRequestSchema: Schema = new Schema(\n {\n _id: { type: String, required: true },\n providerId: { type: String, required: true, index: true },\n codeVerifier: { type: String, required: true },\n returnTo: { type: String, required: false },\n createdAt: { type: Date, required: true, default: Date.now },\n expiresAt: { type: Date, required: true },\n },\n { versionKey: false },\n)\n\nRBOAuthRequestSchema.index({ expiresAt: 1 }, { expireAfterSeconds: 0 })\n","import { Schema } from \"mongoose\"\n\n\ntype MongooseSchemaExtension = Parameters<Schema[\"add\"]>[0]\n\nexport function extendMongooseSchema<TSchema extends Schema>(\n baseSchema: TSchema,\n ...extensions: MongooseSchemaExtension[]\n): TSchema {\n const schema = baseSchema.clone() as TSchema\n\n extensions.forEach((extension) => schema.add(extension))\n\n return schema\n}\n\nexport function omitMongooseSchemaPaths<TSchema extends Schema>(\n schema: TSchema,\n paths: string[],\n): TSchema {\n const clone = schema.clone() as TSchema\n paths.forEach((path) => clone.remove(path))\n return clone\n}\n","import { Schema } from \"mongoose\"\nimport type { SchemaTypeOptions } from \"mongoose\"\n\nimport type { LocalizedString } from \"../zod/localizedString\"\nimport { withLocalizedStringFallback } from \"../zod/localizedString\"\n\n\nexport function localizedStringField(\n options?: Omit<SchemaTypeOptions<LocalizedString>, \"type\">\n): SchemaTypeOptions<LocalizedString> {\n const userGet = options?.get\n\n return {\n ...options,\n type: Schema.Types.Mixed,\n get: (value: unknown) => withLocalizedStringFallback(userGet ? userGet(value) : value),\n }\n}\n","import mongoose from \"mongoose\"\nimport type { InferSchemaType } from \"mongoose\"\n\n\nconst { Schema, model } = mongoose\n\nexport { Schema, model, mongoose, type InferSchemaType }\nexport * from \"./extendMongooseSchema\"\nexport * from \"./localizedStringField\"\n","export type PaginationErrorCode = \"invalid_pagination\"\n\nexport class PaginationValidationError extends Error {\n readonly code: PaginationErrorCode = \"invalid_pagination\"\n readonly statusCode = 400\n\n constructor(message: string, options?: ErrorOptions) {\n super(message, options)\n this.name = \"PaginationValidationError\"\n }\n}\n\nexport const isPaginationValidationError = (error: unknown): error is PaginationValidationError => {\n if (!error || typeof error !== \"object\") return false\n const anyError = error as Partial<PaginationValidationError>\n return (\n anyError.name === \"PaginationValidationError\" &&\n anyError.code === \"invalid_pagination\" &&\n anyError.statusCode === 400\n )\n}\n","import type { PaginationDirection, PaginationOrder, PaginationSpec } from \"@rpcbase/api\"\n\nimport { PaginationValidationError } from \"./errors\"\n\n\nconst DISALLOWED_MONGO_FIELD_SEGMENTS = new Set([\"__proto__\", \"constructor\", \"prototype\"])\nconst PAGINATION_LIMIT_MAX = 128\n\nexport type NormalizedPaginationSpec = Omit<PaginationSpec, \"direction\" | \"sort\" | \"limit\"> & {\n direction: PaginationDirection;\n limit: number;\n sort: Array<{\n field: string;\n order: PaginationOrder;\n }>;\n}\n\nexport const normalizePaginationSpec = (spec: PaginationSpec): NormalizedPaginationSpec => {\n if (!spec || typeof spec !== \"object\") throw new PaginationValidationError(\"Invalid PaginationSpec\")\n\n const limit = normalizeLimit(spec.limit)\n const direction = spec.direction ?? \"next\"\n if (direction !== \"next\" && direction !== \"prev\") throw new PaginationValidationError(\"Invalid pagination direction\")\n\n if (!Array.isArray(spec.sort) || spec.sort.length === 0) throw new PaginationValidationError(\"Invalid pagination sort\")\n\n const sort: NormalizedPaginationSpec[\"sort\"] = spec.sort.map(({ field, order }) => ({\n field: assertSafeMongoFieldPath(field),\n order: normalizeOrder(order),\n }))\n\n const seenFields = new Set<string>()\n for (const { field } of sort) {\n if (seenFields.has(field)) throw new PaginationValidationError(`Duplicate pagination sort field: ${field}`)\n seenFields.add(field)\n }\n\n const primaryOrder = sort[0]?.order\n\n if (!seenFields.has(\"_id\")) {\n sort.push({ field: \"_id\", order: primaryOrder })\n }\n\n return {\n ...spec,\n limit,\n direction,\n sort,\n }\n}\n\nconst normalizeLimit = (limit: unknown): number => {\n if (typeof limit !== \"number\" || !Number.isFinite(limit) || !Number.isInteger(limit) || limit <= 0) {\n throw new PaginationValidationError(\"Invalid pagination limit\")\n }\n if (limit > PAGINATION_LIMIT_MAX) {\n throw new PaginationValidationError(\"Invalid pagination limit\")\n }\n return limit\n}\n\nconst normalizeOrder = (order: unknown): PaginationOrder => {\n if (order !== \"asc\" && order !== \"desc\") throw new PaginationValidationError(\"Invalid pagination order\")\n return order\n}\n\nconst assertSafeMongoFieldPath = (field: unknown): string => {\n if (typeof field !== \"string\" || field.length === 0) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (field.startsWith(\"$\")) throw new PaginationValidationError(\"Invalid pagination sort field\")\n\n const parts = field.split(\".\")\n for (const part of parts) {\n if (part.length === 0) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (DISALLOWED_MONGO_FIELD_SEGMENTS.has(part)) throw new PaginationValidationError(\"Invalid pagination sort field\")\n if (!/^[a-zA-Z0-9_]+$/.test(part)) throw new PaginationValidationError(\"Invalid pagination sort field\")\n }\n\n return field\n}\n","import { createHmac, timingSafeEqual } from \"node:crypto\"\n\nimport { Types } from \"mongoose\"\nimport type { PaginationSpec } from \"@rpcbase/api\"\n\nimport { PaginationValidationError } from \"./errors\"\nimport { normalizePaginationSpec } from \"./normalizeSpec\"\n\n\ntype CursorValue =\n | null\n | string\n | number\n | boolean\n | { $date: string }\n | { $oid: string }\n\ntype CursorPayloadV1 = {\n v: 1;\n values: Record<string, CursorValue>;\n}\n\nexport type PaginationCursorCodecOptions = {\n signingSecret: string | Buffer;\n}\n\nexport const encodePaginationCursor = (\n spec: PaginationSpec,\n node: unknown,\n options: PaginationCursorCodecOptions,\n): string => {\n const normalized = normalizePaginationSpec(spec)\n\n const values = Object.create(null) as Record<string, CursorValue>\n for (const { field } of normalized.sort) {\n const value = readFieldValue(node, field)\n if (typeof value === \"undefined\") {\n throw new Error(`Pagination cursor encode failed (missing field: ${field})`)\n }\n values[field] = encodeCursorValue(field, value)\n }\n\n const payload: CursorPayloadV1 = { v: 1, values }\n const payloadB64 = Buffer.from(JSON.stringify(payload), \"utf8\").toString(\"base64url\")\n\n const sigB64 = signCursorPayloadB64(payloadB64, options.signingSecret)\n return `${payloadB64}.${sigB64}`\n}\n\nexport const decodePaginationCursor = (\n spec: PaginationSpec,\n cursor: string,\n options: PaginationCursorCodecOptions,\n): Record<string, unknown> => {\n const normalized = normalizePaginationSpec(spec)\n\n const [payloadB64, sigB64, ...rest] = cursor.split(\".\")\n if (rest.length > 0) throw new PaginationValidationError(\"Invalid pagination cursor format\")\n if (!sigB64) throw new PaginationValidationError(\"Invalid pagination cursor format\")\n verifyCursorSignature(payloadB64, sigB64, options.signingSecret)\n\n const payloadRaw = Buffer.from(payloadB64, \"base64url\").toString(\"utf8\")\n\n let payloadUnknown: unknown\n try {\n payloadUnknown = JSON.parse(payloadRaw)\n } catch {\n throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n }\n\n if (!payloadUnknown || typeof payloadUnknown !== \"object\") throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n const payload = payloadUnknown as Partial<CursorPayloadV1>\n\n if (payload.v !== 1) throw new PaginationValidationError(\"Unsupported pagination cursor version\")\n if (!payload.values || typeof payload.values !== \"object\") throw new PaginationValidationError(\"Invalid pagination cursor payload\")\n\n const decoded = Object.create(null) as Record<string, unknown>\n for (const { field } of normalized.sort) {\n if (!Object.prototype.hasOwnProperty.call(payload.values, field)) {\n throw new PaginationValidationError(`Pagination cursor missing field: ${field}`)\n }\n const encodedValue = (payload.values as Record<string, CursorValue>)[field]\n decoded[field] = decodeCursorValue(field, encodedValue)\n }\n\n return decoded\n}\n\nconst signCursorPayloadB64 = (payloadB64: string, secret: string | Buffer): string => {\n return createHmac(\"sha256\", secret).update(payloadB64, \"utf8\").digest(\"base64url\")\n}\n\nconst verifyCursorSignature = (payloadB64: string, sigB64: string, secret: string | Buffer): void => {\n const expectedSigB64 = signCursorPayloadB64(payloadB64, secret)\n const a = Buffer.from(sigB64, \"utf8\")\n const b = Buffer.from(expectedSigB64, \"utf8\")\n if (a.length !== b.length || !timingSafeEqual(a, b)) {\n throw new PaginationValidationError(\"Invalid pagination cursor signature\")\n }\n}\n\nconst encodeCursorValue = (field: string, value: unknown): CursorValue => {\n if (value === null) return null\n\n if (field === \"_id\") {\n if (value instanceof Types.ObjectId) return { $oid: value.toHexString() }\n if (typeof value === \"string\") return value\n throw new Error(\"Pagination cursor encode failed (_id must be an ObjectId or string)\")\n }\n\n if (value instanceof Date) return { $date: value.toISOString() }\n\n if (typeof value === \"string\" || typeof value === \"number\" || typeof value === \"boolean\") return value\n\n if (value instanceof Types.ObjectId) return { $oid: value.toHexString() }\n\n throw new Error(`Unsupported pagination cursor value type for field: ${field}`)\n}\n\nconst decodeCursorValue = (field: string, value: CursorValue): unknown => {\n if (value === null) return null\n\n if (typeof value === \"string\") {\n return value\n }\n\n if (typeof value === \"number\" || typeof value === \"boolean\") return value\n\n if (!value || typeof value !== \"object\") throw new PaginationValidationError(`Invalid pagination cursor value for field: ${field}`)\n\n if (\"$date\" in value) {\n if (typeof value.$date !== \"string\") throw new PaginationValidationError(`Invalid pagination cursor date for field: ${field}`)\n const d = new Date(value.$date)\n if (Number.isNaN(d.getTime())) throw new PaginationValidationError(`Invalid pagination cursor date for field: ${field}`)\n return d\n }\n\n if (\"$oid\" in value) {\n if (typeof value.$oid !== \"string\" || !Types.ObjectId.isValid(value.$oid)) {\n throw new PaginationValidationError(`Invalid pagination cursor ObjectId for field: ${field}`)\n }\n return new Types.ObjectId(value.$oid)\n }\n\n throw new PaginationValidationError(`Invalid pagination cursor value for field: ${field}`)\n}\n\nconst readFieldValue = (node: unknown, field: string): unknown => {\n if (!node || typeof node !== \"object\") return undefined\n\n if (\"get\" in node && typeof (node as { get?: unknown }).get === \"function\") {\n return (node as { get: (path: string) => unknown }).get(field)\n }\n\n return field.split(\".\").reduce((acc, key) => {\n if (!acc || typeof acc !== \"object\") return undefined\n return (acc as Record<string, unknown>)[key]\n }, node as unknown)\n}\n","import type { PaginationOrder, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { decodePaginationCursor } from \"./cursor\"\nimport { PaginationValidationError } from \"./errors\"\nimport type { NormalizedPaginationSpec } from \"./normalizeSpec\"\nimport { normalizePaginationSpec } from \"./normalizeSpec\"\n\n\nexport type CompiledMongoPagination = {\n spec: NormalizedPaginationSpec;\n mongoFilterDelta: Record<string, unknown>;\n mongoSort: Record<string, 1 | -1>;\n mongoLimit: number;\n}\n\nexport type CompileMongoPaginationOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const compileMongoPagination = (\n spec: PaginationSpec,\n options: CompileMongoPaginationOptions,\n): CompiledMongoPagination => {\n const normalized = normalizePaginationSpec(spec)\n\n const mongoLimit = normalized.limit + 1\n const mongoSort = toMongoSort(normalized)\n\n if (normalized.cursor == null) {\n return {\n spec: normalized,\n mongoFilterDelta: {},\n mongoSort,\n mongoLimit,\n }\n }\n\n if (typeof normalized.cursor !== \"string\" || normalized.cursor.length === 0) {\n throw new PaginationValidationError(\"Invalid pagination cursor\")\n }\n\n const cursorValues = decodePaginationCursor(normalized, normalized.cursor, options.cursor)\n const mongoFilterDelta = buildKeysetFilterDelta(normalized, cursorValues)\n\n return {\n spec: normalized,\n mongoFilterDelta,\n mongoSort,\n mongoLimit,\n }\n}\n\nconst toMongoSort = (spec: NormalizedPaginationSpec): Record<string, 1 | -1> => {\n const mongoSort = Object.create(null) as Record<string, 1 | -1>\n for (const { field, order } of spec.sort) {\n const forQueryOrder = spec.direction === \"prev\" ? invertOrder(order) : order\n mongoSort[field] = forQueryOrder === \"asc\" ? 1 : -1\n }\n return mongoSort\n}\n\nconst buildKeysetFilterDelta = (\n spec: NormalizedPaginationSpec,\n cursorValues: Record<string, unknown>,\n): Record<string, unknown> => {\n const branches: Record<string, unknown>[] = []\n\n for (let i = 0; i < spec.sort.length; i++) {\n const current = spec.sort[i]\n if (!current) continue\n\n const and: Record<string, unknown>[] = []\n\n for (let j = 0; j < i; j++) {\n const prev = spec.sort[j]\n if (!prev) continue\n const eq = Object.create(null) as Record<string, unknown>\n eq[prev.field] = cursorValues[prev.field]\n and.push(eq)\n }\n\n const op = getKeysetOp(current.order, spec.direction)\n const cmpOp = Object.create(null) as Record<string, unknown>\n cmpOp[op] = cursorValues[current.field]\n const cmp = Object.create(null) as Record<string, unknown>\n cmp[current.field] = cmpOp\n and.push(cmp)\n\n branches.push(and.length === 1 ? and[0]! : { $and: and })\n }\n\n return { $or: branches }\n}\n\nconst getKeysetOp = (order: PaginationOrder, direction: NormalizedPaginationSpec[\"direction\"]): \"$gt\" | \"$lt\" => {\n if (direction === \"next\") return order === \"asc\" ? \"$gt\" : \"$lt\"\n return order === \"asc\" ? \"$lt\" : \"$gt\"\n}\n\nconst invertOrder = (order: PaginationOrder): PaginationOrder => {\n return order === \"asc\" ? \"desc\" : \"asc\"\n}\n","import type { PaginationResponse } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { encodePaginationCursor } from \"./cursor\"\nimport type { CompiledMongoPagination } from \"./compileMongoPagination\"\n\n\nexport type MaterializePaginationOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const materializeMongoPagination = <TNode>(\n compiled: CompiledMongoPagination,\n fetchedNodes: TNode[],\n options: MaterializePaginationOptions,\n): PaginationResponse<TNode> => {\n const limit = compiled.spec.limit\n const hasMore = fetchedNodes.length > limit\n\n const trimmed = fetchedNodes.slice(0, limit)\n const nodes = compiled.spec.direction === \"prev\" ? trimmed.reverse() : trimmed\n\n const hasPrevPage = compiled.spec.direction === \"next\" ? Boolean(compiled.spec.cursor) : hasMore\n const hasNextPage = compiled.spec.direction === \"next\" ? hasMore : Boolean(compiled.spec.cursor)\n\n const pageInfo: PaginationResponse<TNode>[\"pageInfo\"] = {\n hasNextPage,\n hasPrevPage,\n }\n\n if (nodes.length === 0) {\n return { nodes, pageInfo }\n }\n\n if (hasPrevPage) {\n pageInfo.prevCursor = encodePaginationCursor(compiled.spec, nodes[0], options.cursor)\n }\n\n if (hasNextPage) {\n pageInfo.nextCursor = encodePaginationCursor(compiled.spec, nodes[nodes.length - 1], options.cursor)\n }\n\n return { nodes, pageInfo }\n}\n","import type { CompiledMongoPagination } from \"./compileMongoPagination\"\n\n\ntype MongoQueryLike = {\n where: (delta: Record<string, unknown>) => unknown;\n sort: (sort: Record<string, 1 | -1>) => unknown;\n limit: (limit: number) => unknown;\n}\n\nexport const MongoAdapter = {\n applyPagination: <TQuery extends MongoQueryLike>(query: TQuery, compiled: CompiledMongoPagination): TQuery => {\n query.where(compiled.mongoFilterDelta)\n query.sort(compiled.mongoSort)\n query.limit(compiled.mongoLimit)\n return query\n },\n}\n\n","import type { PaginationResponse, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { compileMongoPagination } from \"./compileMongoPagination\"\nimport { materializeMongoPagination } from \"./materializePagination\"\nimport { MongoAdapter } from \"./mongoAdapter\"\n\n\ntype MongoPaginateQueryLike<TNode> = {\n where: (delta: Record<string, unknown>) => unknown;\n sort: (sort: Record<string, 1 | -1>) => unknown;\n limit: (limit: number) => unknown;\n exec: () => Promise<TNode[]>;\n}\n\nexport type PaginateMongoQueryOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\nexport const paginateMongoQuery = async <TNode>(\n query: MongoPaginateQueryLike<TNode>,\n pagination: PaginationSpec,\n options: PaginateMongoQueryOptions,\n): Promise<PaginationResponse<TNode>> => {\n const compiled = compileMongoPagination(pagination, { cursor: options.cursor })\n\n MongoAdapter.applyPagination(query, compiled)\n\n const fetchedNodes = await query.exec()\n if (!Array.isArray(fetchedNodes)) {\n throw new Error(\"paginateMongoQuery expects query.exec() to return an array\")\n }\n\n return materializeMongoPagination(compiled, fetchedNodes, { cursor: options.cursor })\n}\n","import mongoose from \"mongoose\"\nimport type { PaginationResponse, PaginationSpec } from \"@rpcbase/api\"\n\nimport type { PaginationCursorCodecOptions } from \"./cursor\"\nimport { paginateMongoQuery } from \"./paginateMongoQuery\"\n\n\ndeclare const mongoPaginationPluginBrand: unique symbol\n\n\ntype QueryOptionsLike = Record<string, unknown>\n\nconst getQueryOptions = (query: unknown): QueryOptionsLike | undefined => {\n if (!query || typeof query !== \"object\") return undefined\n if (!(\"getOptions\" in query) || typeof (query as { getOptions?: unknown }).getOptions !== \"function\") return undefined\n return (query as { getOptions: () => QueryOptionsLike }).getOptions()\n}\n\nconst getPaginationFromOptions = (query: unknown): PaginationSpec | undefined => {\n const options = getQueryOptions(query)\n return options?.pagination as PaginationSpec | undefined\n}\n\nconst getCursorFromOptions = (query: unknown): PaginationCursorCodecOptions | undefined => {\n const options = getQueryOptions(query)\n return options?.paginationCursor as PaginationCursorCodecOptions | undefined\n}\n\nexport type MongoPaginationPluginOptions = {\n cursor: PaginationCursorCodecOptions;\n}\n\ntype QueryResultNode<TResult> = TResult extends Array<infer TNode> ? TNode : unknown\n\ndeclare module \"mongoose\" {\n interface Query<\n ResultType,\n DocType,\n THelpers = {},\n RawDocType = unknown,\n QueryOp = \"find\",\n TDocOverrides = Record<string, never>,\n > {\n [mongoPaginationPluginBrand]?: [DocType, THelpers, RawDocType, QueryOp, TDocOverrides];\n paginate: (\n pagination?: PaginationSpec,\n options?: MongoPaginationPluginOptions,\n ) => Promise<PaginationResponse<QueryResultNode<ResultType>>>;\n }\n}\n\nexport const mongoPaginationPlugin = (schema: mongoose.Schema, pluginOptions?: MongoPaginationPluginOptions): void => {\n ;(schema.query as Record<string, unknown>).paginate = async function(\n this: mongoose.Query<unknown[], unknown>,\n pagination?: PaginationSpec,\n options?: MongoPaginationPluginOptions,\n ): Promise<PaginationResponse<unknown>> {\n const spec = pagination ?? getPaginationFromOptions(this)\n if (!spec) throw new Error(\"Missing pagination spec\")\n\n const cursor = options?.cursor ?? getCursorFromOptions(this) ?? pluginOptions?.cursor\n if (!cursor?.signingSecret) throw new Error(\"Missing pagination cursor signingSecret\")\n\n return await paginateMongoQuery(this, spec, { cursor })\n }\n}\n","type MongoDbLike = {\n databaseName?: string\n command: (command: Record<string, unknown>) => Promise<unknown>\n}\n\nexport type SearchTextStageOptions = {\n index: string\n query: string\n path: string | string[]\n highlightPath?: string | string[]\n}\n\nexport type SearchTextStage = {\n $search: {\n index: string\n text: {\n query: string\n path: string | string[]\n }\n highlight?: {\n path: string | string[]\n }\n }\n}\n\nexport const buildSearchTextStage = (options: SearchTextStageOptions): SearchTextStage => {\n const index = options.index.trim()\n if (!index) throw new Error(\"Missing search index name\")\n\n const query = options.query.trim()\n if (!query) throw new Error(\"Missing search query\")\n\n const stage: SearchTextStage = {\n $search: {\n index,\n text: {\n query,\n path: options.path,\n },\n },\n }\n\n if (options.highlightPath) {\n stage.$search.highlight = { path: options.highlightPath }\n }\n\n return stage\n}\n\nexport const searchMetaProjection = () => {\n return {\n score: { $meta: \"searchScore\" },\n highlights: { $meta: \"searchHighlights\" },\n } as const\n}\n\nexport type EnsureSearchIndexParams = {\n db: MongoDbLike\n collection: string\n name: string\n definition: Record<string, unknown>\n}\n\nconst listResultHasIndex = (listResult: unknown, name: string): boolean => {\n if (!listResult || typeof listResult !== \"object\") return false\n if (!(\"cursor\" in listResult)) return false\n const cursor = (listResult as { cursor?: unknown }).cursor\n if (!cursor || typeof cursor !== \"object\") return false\n const firstBatch = (cursor as { firstBatch?: unknown }).firstBatch\n if (!Array.isArray(firstBatch)) return false\n return firstBatch.some((idx) => idx && typeof idx === \"object\" && \"name\" in idx && (idx as { name?: unknown }).name === name)\n}\n\nconst isIndexAlreadyExistsError = (error: unknown): boolean => {\n if (!error || typeof error !== \"object\") return false\n const codeName = \"codeName\" in error ? (error as { codeName?: unknown }).codeName : undefined\n if (codeName === \"IndexAlreadyExists\") return true\n const message = \"message\" in error ? String((error as { message?: unknown }).message ?? \"\") : \"\"\n return /already exists/i.test(message)\n}\n\nexport const ensureSearchIndex = async (params: EnsureSearchIndexParams): Promise<{ created: boolean }> => {\n const collection = params.collection.trim()\n if (!collection) throw new Error(\"Missing collection name\")\n\n const name = params.name.trim()\n if (!name) throw new Error(\"Missing search index name\")\n\n let listResult: unknown\n try {\n listResult = await params.db.command({ listSearchIndexes: collection })\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n throw new Error(`listSearchIndexes failed for \"${collection}\": ${message}`)\n }\n\n if (listResultHasIndex(listResult, name)) {\n return { created: false }\n }\n\n try {\n await params.db.command({\n createSearchIndexes: collection,\n indexes: [{ name, definition: params.definition }],\n })\n } catch (error) {\n if (isIndexAlreadyExistsError(error)) {\n return { created: false }\n }\n const message = error instanceof Error ? error.message : String(error)\n throw new Error(`createSearchIndexes failed for \"${collection}\" (index \"${name}\"): ${message}`)\n }\n\n return { created: true }\n}\n","const getAppName = (env: NodeJS.ProcessEnv = process.env): string => {\n const appName = env.APP_NAME?.trim()\n if (!appName) {\n throw new Error(\"Missing APP_NAME\")\n }\n return appName\n}\n\nexport const GLOBAL_DB_SUFFIX = \"-global-db\"\n\nexport const getGlobalDbName = (env: NodeJS.ProcessEnv = process.env): string => {\n return `${getAppName(env)}${GLOBAL_DB_SUFFIX}`\n}\n\nexport const getTenantDbName = (tenantId: string, env: NodeJS.ProcessEnv = process.env): string => {\n return `${getAppName(env)}-${tenantId.trim()}-db`\n}\n","type EnvRecord = { [key: string]: string | undefined }\n\nexport const getMongoUrl = (env: EnvRecord = process.env): string => {\n const explicitUrl =\n env.MONGODB_URL\n ?? env.MONGO_URL\n ?? env.MONGODB_URI\n ?? env.DB_URL\n\n if (explicitUrl && explicitUrl.trim()) {\n return explicitUrl.trim()\n }\n\n const port = env.DB_PORT?.trim()\n if (!port) throw new Error(\"Missing Mongo connection details (MONGODB_URL/MONGO_URL/MONGODB_URI/DB_URL/DB_PORT)\")\n\n const host = env.DB_HOST?.trim() || \"localhost\"\n return `mongodb://${host}:${port}`\n}\n\n","import mongoose from \"mongoose\"\n\nimport { getMongoUrl } from \"./getMongoUrl\"\n\n\nconst connections = new Map<string, mongoose.Connection>()\nlet rootConnection: mongoose.Connection | null = null\n\nconst waitForOpen = async (connection: mongoose.Connection): Promise<void> => {\n if (connection.readyState === 1) return\n\n await new Promise<void>((resolve, reject) => {\n connection.once(\"open\", resolve)\n connection.once(\"error\", reject)\n })\n}\n\nexport const ensureMongooseConnection = async (dbName: string): Promise<mongoose.Connection> => {\n const normalizedDbName = dbName.trim()\n if (!normalizedDbName) {\n throw new Error(\"Missing dbName\")\n }\n\n const existing = connections.get(normalizedDbName)\n if (existing) {\n await waitForOpen(existing)\n return existing\n }\n\n if (!rootConnection) {\n const mongoUrl = getMongoUrl()\n rootConnection = mongoose.createConnection(mongoUrl, {\n sanitizeFilter: true,\n dbName: normalizedDbName,\n })\n }\n\n await waitForOpen(rootConnection)\n\n const connection = rootConnection.name === normalizedDbName\n ? rootConnection\n : rootConnection.useDb(normalizedDbName, { useCache: true })\n\n await waitForOpen(connection)\n\n connections.set(normalizedDbName, connection)\n return connection\n}\n","import type mongoose from \"mongoose\"\n\nimport { GLOBAL_DB_SUFFIX } from \"./dbNames\"\nimport { RBRtsChangeSchema, type IRBRtsChange } from \"./models/RBRtsChange\"\nimport { RBRtsCounterSchema, type IRBRtsCounter } from \"./models/RBRtsCounter\"\n\n\ntype RtsChangeOp = IRBRtsChange[\"op\"]\n\nconst RTS_COUNTER_ID = \"rts\"\nconst EXCLUDED_MODEL_NAMES = new Set([\"RBRtsChange\", \"RBRtsCounter\"])\n\nconst maxDeleteIdsRaw = process.env.RB_RTS_DELETE_LOG_MAX_IDS ?? \"\"\nconst maxDeleteIds = Number.isFinite(Number(maxDeleteIdsRaw)) ? Math.max(1, Math.floor(Number(maxDeleteIdsRaw))) : 5000\n\ntype DeleteMeta = {\n modelName: string\n ids: string[]\n reset: boolean\n session?: mongoose.ClientSession\n}\n\nconst deleteMetaByQuery = new WeakMap<object, DeleteMeta>()\n\nconst hasToString = (value: unknown): value is { toString: () => string } => {\n if (typeof value !== \"object\" || value === null) return false\n const maybe = value as { toString?: unknown }\n return typeof maybe.toString === \"function\"\n}\n\nconst normalizeId = (id: unknown): string | null => {\n if (!id) return null\n if (typeof id === \"string\") return id\n if (hasToString(id)) return id.toString()\n return null\n}\n\nconst getDbName = (db: unknown): string => {\n if (!db || typeof db !== \"object\") return \"\"\n const maybe = db as { name?: unknown; db?: { databaseName?: unknown } }\n const raw = maybe.name ?? maybe.db?.databaseName\n return typeof raw === \"string\" ? raw : \"\"\n}\n\nconst isGlobalDb = (db: unknown): boolean => getDbName(db).endsWith(GLOBAL_DB_SUFFIX)\n\ntype RtsCounterDoc = IRBRtsCounter\ntype RtsChangeDoc = IRBRtsChange\n\nconst getQuerySession = (query: MongooseQuery): mongoose.ClientSession | undefined => {\n const opts = typeof query.getOptions === \"function\" ? query.getOptions() : undefined\n if (!opts || typeof opts !== \"object\") return undefined\n const session = (opts as { session?: unknown }).session\n if (!session || typeof session !== \"object\") return undefined\n return session as mongoose.ClientSession\n}\n\nconst getRtsModels = (db: mongoose.Connection) => {\n const RtsCounter = (db.models.RBRtsCounter as mongoose.Model<RtsCounterDoc>)\n ?? db.model<RtsCounterDoc>(\"RBRtsCounter\", RBRtsCounterSchema)\n const RtsChange = (db.models.RBRtsChange as mongoose.Model<RtsChangeDoc>)\n ?? db.model<RtsChangeDoc>(\"RBRtsChange\", RBRtsChangeSchema)\n return { RtsCounter, RtsChange }\n}\n\nconst allocateSeqRange = async (\n db: mongoose.Connection,\n count: number,\n session?: mongoose.ClientSession,\n): Promise<{ start: number; end: number }> => {\n const { RtsCounter } = getRtsModels(db)\n const updated = await RtsCounter.findOneAndUpdate(\n { _id: RTS_COUNTER_ID },\n { $inc: { seq: count } },\n { upsert: true, returnDocument: \"after\", setDefaultsOnInsert: true, projection: { seq: 1 }, session },\n ).lean()\n\n const end = Number(updated?.seq ?? 0)\n const start = end - count + 1\n return { start, end }\n}\n\nconst insertChanges = async (\n db: mongoose.Connection,\n changes: Array<{ seq: number; modelName: string; op: RtsChangeOp; docId?: string | null }>,\n session?: mongoose.ClientSession,\n): Promise<void> => {\n if (!changes.length) return\n const { RtsChange } = getRtsModels(db)\n const ts = new Date()\n const docs = changes.map((c) => ({\n seq: c.seq,\n modelName: c.modelName,\n op: c.op,\n docId: c.docId ?? undefined,\n ts,\n }))\n\n if (session) {\n await RtsChange.insertMany(docs, { session })\n return\n }\n\n await RtsChange.insertMany(docs)\n}\n\nconst recordDeleteChanges = async (\n db: mongoose.Connection,\n modelName: string,\n ids: string[],\n session?: mongoose.ClientSession,\n): Promise<void> => {\n const uniqueIds = Array.from(new Set(ids)).filter(Boolean)\n if (!uniqueIds.length) return\n const { start } = await allocateSeqRange(db, uniqueIds.length, session)\n await insertChanges(db, uniqueIds.map((docId, idx) => ({\n seq: start + idx,\n modelName,\n op: \"delete\",\n docId,\n })), session)\n}\n\nconst recordResetModel = async (db: mongoose.Connection, modelName: string, session?: mongoose.ClientSession): Promise<void> => {\n const { start } = await allocateSeqRange(db, 1, session)\n await insertChanges(db, [{ seq: start, modelName, op: \"reset_model\" }], session)\n}\n\ntype MongooseQuery = mongoose.Query<unknown, unknown> & {\n model?: {\n modelName?: string\n db?: unknown\n find: (filter: unknown, projection: unknown) => unknown\n }\n getFilter?: () => unknown\n getQuery?: () => unknown\n getOptions?: () => unknown\n}\n\nconst captureDeleteMeta = async (query: MongooseQuery, mode: \"one\" | \"many\") => {\n const modelName = String(query?.model?.modelName ?? \"\")\n if (!modelName || modelName.startsWith(\"RB\") || EXCLUDED_MODEL_NAMES.has(modelName)) return\n if (isGlobalDb(query?.model?.db)) return\n\n const filter = typeof query.getFilter === \"function\" ? query.getFilter() : query.getQuery?.() ?? {}\n const session = getQuerySession(query)\n const findQuery = query.model.find(filter, { _id: 1 }) as unknown as {\n session?: (s: mongoose.ClientSession) => unknown\n limit: (n: number) => unknown\n lean: () => unknown\n }\n if (session && typeof findQuery.session === \"function\") {\n findQuery.session(session)\n }\n\n findQuery.lean()\n\n if (mode === \"one\") {\n findQuery.limit(1)\n } else {\n findQuery.limit(maxDeleteIds + 1)\n }\n\n const docs = await findQuery\n const ids = Array.isArray(docs)\n ? docs\n .map((d) => normalizeId((d as { _id?: unknown })?._id))\n .filter((id): id is string => Boolean(id))\n : []\n const reset = mode === \"many\" && ids.length > maxDeleteIds\n const trimmedIds = reset ? [] : ids\n\n const meta: DeleteMeta = {\n modelName,\n ids: trimmedIds,\n reset,\n session,\n }\n\n deleteMetaByQuery.set(query, meta)\n}\n\nconst flushDeleteMeta = async (query: MongooseQuery) => {\n const meta = deleteMetaByQuery.get(query)\n deleteMetaByQuery.delete(query)\n if (!meta) return\n\n const db = query?.model?.db as mongoose.Connection | undefined\n if (!db) return\n\n try {\n if (meta.reset) {\n await recordResetModel(db, meta.modelName, meta.session)\n } else {\n await recordDeleteChanges(db, meta.modelName, meta.ids, meta.session)\n }\n } catch {\n return\n }\n}\n\nexport const rtsChangeLogPlugin = (schema: mongoose.Schema): void => {\n schema.pre(\"deleteOne\", { query: true, document: false }, async function(this: MongooseQuery) {\n await captureDeleteMeta(this, \"one\")\n })\n\n schema.pre(\"deleteMany\", { query: true, document: false }, async function(this: MongooseQuery) {\n await captureDeleteMeta(this, \"many\")\n })\n\n schema.post(\"deleteOne\", { query: true, document: false }, async function(this: MongooseQuery) {\n await flushDeleteMeta(this)\n })\n\n schema.post(\"deleteMany\", { query: true, document: false }, async function(this: MongooseQuery) {\n await flushDeleteMeta(this)\n })\n\n schema.post(\"findOneAndDelete\", { query: true, document: false }, async function(this: MongooseQuery, doc: unknown) {\n const modelName = String(this?.model?.modelName ?? \"\")\n if (!modelName || modelName.startsWith(\"RB\") || EXCLUDED_MODEL_NAMES.has(modelName)) return\n\n const db = this?.model?.db as mongoose.Connection | undefined\n if (!db) return\n if (isGlobalDb(db)) return\n\n const docId = normalizeId((doc as { _id?: unknown } | null | undefined)?._id)\n if (!docId) return\n\n try {\n const session = getQuerySession(this)\n await recordDeleteChanges(db, modelName, [docId], session)\n } catch {\n return\n }\n })\n}\n","import mongoose from \"mongoose\"\nimport { accessibleBy } from \"@casl/mongoose\"\n\nimport type { AclAction, AclSubjectType, AppAbility } from \"./types\"\n\n\ntype StoredAcl = {\n ability: AppAbility\n action?: AclAction\n}\n\ntype QueryOptionsLike = Record<string, unknown>\n\ntype PipelineStageLike = Record<string, unknown>\n\nconst isRecord = (value: unknown): value is Record<string, unknown> => Boolean(value) && typeof value === \"object\" && !Array.isArray(value)\n\nconst mergeMongoQuery = (left: unknown, right: Record<string, unknown>): Record<string, unknown> => {\n const leftQuery = isRecord(left) ? left : {}\n if (Object.keys(leftQuery).length === 0) return right\n if (Object.keys(right).length === 0) return leftQuery\n return { $and: [leftQuery, right] }\n}\n\nconst getQueryOptions = (query: unknown): QueryOptionsLike | undefined => {\n if (!query || typeof query !== \"object\") return undefined\n if (!(\"getOptions\" in query) || typeof (query as { getOptions?: unknown }).getOptions !== \"function\") return undefined\n return (query as { getOptions: () => QueryOptionsLike }).getOptions()\n}\n\nconst getStoredAclFromQuery = (query: unknown): StoredAcl | null => {\n const options = getQueryOptions(query)\n const raw = options?.rbAcl\n if (!isRecord(raw)) return null\n if (!(\"ability\" in raw)) return null\n return raw as unknown as StoredAcl\n}\n\nconst getStoredAclFromAggregate = (aggregate: unknown): StoredAcl | null => {\n if (!aggregate || typeof aggregate !== \"object\") return null\n const raw = (aggregate as { options?: unknown }).options\n if (!isRecord(raw)) return null\n const acl = raw.rbAcl\n if (!isRecord(acl)) return null\n if (!(\"ability\" in acl)) return null\n return acl as unknown as StoredAcl\n}\n\nconst addQueryAclFilter = (query: mongoose.Query<unknown, unknown>, action: AclAction): void => {\n const storedAcl = getStoredAclFromQuery(query)\n if (!storedAcl) return\n\n const ability = storedAcl.ability\n const resolvedAction = storedAcl.action ?? action\n const modelName = query.model.modelName\n\n const accessQuery = accessibleBy(ability, resolvedAction).ofType(modelName as AclSubjectType)\n query.and([accessQuery])\n}\n\nconst injectAggregateMatch = (pipeline: PipelineStageLike[], match: Record<string, unknown>): void => {\n if (pipeline.length === 0) {\n pipeline.unshift({ $match: match })\n return\n }\n\n const first = pipeline[0]\n if (!isRecord(first)) {\n pipeline.unshift({ $match: match })\n return\n }\n\n if (\"$geoNear\" in first) {\n const geoNear = first.$geoNear\n if (isRecord(geoNear)) {\n geoNear.query = mergeMongoQuery(geoNear.query, match)\n return\n }\n }\n\n if (\"$search\" in first || \"$vectorSearch\" in first || \"$searchMeta\" in first) {\n pipeline.splice(1, 0, { $match: match })\n return\n }\n\n pipeline.unshift({ $match: match })\n}\n\nconst addAggregateAclFilter = (aggregate: mongoose.Aggregate<unknown>, action: AclAction): void => {\n const storedAcl = getStoredAclFromAggregate(aggregate)\n if (!storedAcl) return\n\n const ability = storedAcl.ability\n const resolvedAction = storedAcl.action ?? action\n const modelName = aggregate.model().modelName\n\n const accessQuery = accessibleBy(ability, resolvedAction).ofType(modelName as AclSubjectType)\n injectAggregateMatch(aggregate.pipeline() as unknown as PipelineStageLike[], accessQuery)\n}\n\nconst patchAggregateAcl = (): void => {\n const globalKey = Symbol.for(\"@rpcbase/db/acl/mongooseAggregateAclPatched\")\n const globalState = globalThis as unknown as Record<string | symbol, unknown>\n if (globalState[globalKey]) return\n globalState[globalKey] = true\n\n const AggregatePrototype = (mongoose.Aggregate as unknown as { prototype: Record<string, unknown> }).prototype\n if (typeof AggregatePrototype.acl === \"function\") return\n\n AggregatePrototype.acl = function(\n this: mongoose.Aggregate<unknown>,\n ability: AppAbility,\n action: AclAction = \"read\",\n ) {\n this.option({ rbAcl: { ability, action } })\n return this\n }\n}\n\nconst createModelAclProxy = <TModel extends mongoose.Model<unknown>>(\n model: TModel,\n ability: AppAbility,\n): TModel => {\n return new Proxy(model, {\n get(target, prop, receiver) {\n if (prop === \"acl\") {\n return () => {\n throw new Error(\n `Model \"${target.modelName}\" is already ACL-scoped. Do not call .acl(...) again.`,\n )\n }\n }\n\n const value = Reflect.get(target, prop, receiver) as unknown\n if (typeof value !== \"function\") return value\n return (...args: unknown[]) => {\n const result = Reflect.apply(value, target, args) as unknown\n if (result && typeof result === \"object\" && \"acl\" in result && typeof (result as { acl?: unknown }).acl === \"function\") {\n return (result as { acl: (ability: AppAbility) => unknown }).acl(ability)\n }\n return result\n }\n },\n }) as unknown as TModel\n}\n\ndeclare const mongooseAclPluginBrand: unique symbol\n\ndeclare module \"mongoose\" {\n interface QueryOptions<DocType = unknown> {\n rbAcl?: StoredAcl;\n [mongooseAclPluginBrand]?: DocType;\n }\n\n interface AggregateOptions {\n rbAcl?: StoredAcl;\n }\n\n interface Query<\n ResultType,\n DocType,\n THelpers = {},\n RawDocType = unknown,\n QueryOp = \"find\",\n TDocOverrides = Record<string, never>,\n > {\n [mongooseAclPluginBrand]?: [ResultType, DocType, THelpers, RawDocType, QueryOp, TDocOverrides];\n acl: (ability: AppAbility, action?: AclAction) => this;\n }\n\n interface Aggregate<ResultType> {\n [mongooseAclPluginBrand]?: ResultType;\n acl: (ability: AppAbility, action?: AclAction) => this;\n }\n\n interface Model<\n TRawDocType,\n TQueryHelpers,\n TInstanceMethods,\n TVirtuals,\n THydratedDocumentType,\n TSchema,\n TLeanResultType,\n > {\n [mongooseAclPluginBrand]?: [TRawDocType, TQueryHelpers, TInstanceMethods, TVirtuals, THydratedDocumentType, TSchema, TLeanResultType];\n acl: (ability: AppAbility) => this;\n }\n}\n\nexport const mongooseAclPlugin = (schema: mongoose.Schema): void => {\n patchAggregateAcl()\n\n ;(schema.query as Record<string, unknown>).acl = function(\n this: mongoose.Query<unknown, unknown>,\n ability: AppAbility,\n action?: AclAction,\n ) {\n this.setOptions({ rbAcl: { ability, action } })\n return this\n }\n\n ;(schema.statics as Record<string, unknown>).acl = function(\n this: mongoose.Model<unknown>,\n ability: AppAbility,\n ) {\n return createModelAclProxy(this, ability)\n }\n\n schema.pre(\"aggregate\", function() {\n addAggregateAclFilter(this, \"read\")\n })\n\n schema.pre(\"countDocuments\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"deleteMany\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"deleteOne\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"distinct\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"find\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"findOne\", function() {\n addQueryAclFilter(this, \"read\")\n })\n\n schema.pre(\"findOneAndDelete\", function() {\n addQueryAclFilter(this, \"delete\")\n })\n\n schema.pre(\"findOneAndReplace\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"findOneAndUpdate\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"replaceOne\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"updateMany\", function() {\n addQueryAclFilter(this, \"update\")\n })\n\n schema.pre(\"updateOne\", function() {\n addQueryAclFilter(this, \"update\")\n })\n}\n\nexport const _private = {\n createModelAclProxy,\n injectAggregateMatch,\n mergeMongoQuery,\n}\n","import mongoose from \"mongoose\"\nimport { accessibleRecordsPlugin } from \"@casl/mongoose\"\n\nimport * as frameworkSchemas from \"./models\"\nimport { rtsChangeLogPlugin } from \"./rtsChangeLogPlugin\"\nimport { registerPoliciesFromModules } from \"./acl\"\nimport { mongooseAclPlugin } from \"./acl/mongooseAclPlugin\"\nimport { mongoPaginationPlugin } from \"./pagination/mongoPaginationPlugin\"\n\n\ntype ModelModules = Record<string, unknown>\ntype ModelsScope = \"tenant\" | \"global\"\n\ntype RegisteredSchemas = Record<string, mongoose.Schema>\n\ntype RegisteredModels = {\n tenant: RegisteredSchemas\n global: RegisteredSchemas\n}\n\nlet cachedModels: RegisteredModels | null = null\n\nconst DEFAULT_GLOBAL_RB_MODEL_NAMES_SET = new Set<string>([\n \"RBUser\",\n \"RBTenant\",\n \"RBOAuthRequest\",\n])\n\nconst assertSchema = (exportName: string, value: unknown): mongoose.Schema => {\n if (value instanceof mongoose.Schema) return value\n\n throw new Error(\n [\n `Expected ${exportName} to be an instance of mongoose.Schema, but it was not.`,\n \"rpcbase supports mongoose 9+ only.\",\n \"Fix: ensure the project is using mongoose 9.x and that all packages resolve the same mongoose instance (try `npm ls mongoose`).\",\n ].join(\" \"),\n )\n}\n\nconst getFrameworkSchemaForModelName = (modelName: string): mongoose.Schema | null => {\n const exportName = `${modelName}Schema`\n const value = (frameworkSchemas as unknown as Record<string, unknown>)[exportName]\n if (!(value instanceof mongoose.Schema)) return null\n return value\n}\n\nconst applyTenantPlugins = (schema: mongoose.Schema): void => {\n schema.plugin(accessibleRecordsPlugin)\n schema.plugin(mongooseAclPlugin)\n schema.plugin(mongoPaginationPlugin)\n schema.plugin(rtsChangeLogPlugin)\n}\n\nconst registerSchema = (\n target: RegisteredSchemas,\n other: RegisteredSchemas,\n modelName: string,\n schema: mongoose.Schema,\n scope: ModelsScope,\n): void => {\n if (target[modelName] || other[modelName]) {\n throw new Error(`Duplicate model name \"${modelName}\" across tenant/global scopes`)\n }\n target[modelName] = schema\n}\n\nconst buildSchemasFromModules = (modules: ModelModules): Array<{ modelName: string; schema: mongoose.Schema }> =>\n Object.entries(modules)\n .filter(([key]) => key.endsWith(\"Schema\"))\n .map(([key, schemaValue]) => {\n const schema = assertSchema(key, schemaValue)\n const modelName = key.replace(/Schema$/, \"\")\n return { modelName, schema }\n })\n\nexport const registerModels = ({ tenant, global }: { tenant: ModelModules; global?: ModelModules }) => {\n registerPoliciesFromModules(frameworkSchemas as unknown as Record<string, unknown>)\n registerPoliciesFromModules(tenant)\n\n const tenantSchemas: RegisteredSchemas = {}\n const globalSchemas: RegisteredSchemas = {}\n\n for (const { modelName, schema } of buildSchemasFromModules(frameworkSchemas as unknown as ModelModules)) {\n if (DEFAULT_GLOBAL_RB_MODEL_NAMES_SET.has(modelName)) {\n const cloned = schema.clone()\n registerSchema(globalSchemas, tenantSchemas, modelName, cloned, \"global\")\n } else {\n const cloned = schema.clone()\n applyTenantPlugins(cloned)\n registerSchema(tenantSchemas, globalSchemas, modelName, cloned, \"tenant\")\n }\n }\n\n for (const { modelName, schema } of buildSchemasFromModules(tenant)) {\n if (modelName === \"RBUser\" || modelName === \"RBTenant\") {\n throw new Error(`Invalid tenant model name \"${modelName}\". RBUser/RBTenant are global models.`)\n }\n if (modelName.startsWith(\"RB\")) {\n const frameworkSchema = getFrameworkSchemaForModelName(modelName)\n if (frameworkSchema && schema === frameworkSchema) continue\n throw new Error(`Invalid tenant model name \"${modelName}\". RB* models are reserved for rpcbase.`)\n }\n const cloned = schema.clone()\n applyTenantPlugins(cloned)\n registerSchema(tenantSchemas, globalSchemas, modelName, cloned, \"tenant\")\n }\n\n for (const { modelName, schema } of buildSchemasFromModules(global ?? {})) {\n if (modelName.startsWith(\"RB\")) {\n const frameworkSchema = getFrameworkSchemaForModelName(modelName)\n if (frameworkSchema && schema === frameworkSchema) continue\n throw new Error(`Invalid global model name \"${modelName}\". RB* models are reserved for rpcbase.`)\n }\n const cloned = schema.clone()\n registerSchema(globalSchemas, tenantSchemas, modelName, cloned, \"global\")\n }\n\n const allSchemas = { ...globalSchemas, ...tenantSchemas }\n\n for (const [modelName, schema] of Object.entries(allSchemas)) {\n if (!mongoose.models[modelName]) {\n mongoose.model(modelName, schema)\n }\n }\n\n cachedModels = {\n tenant: { ...(cachedModels?.tenant ?? {}), ...tenantSchemas },\n global: { ...(cachedModels?.global ?? {}), ...globalSchemas },\n }\n}\n\nexport const getRegisteredModels = (scope: ModelsScope) => {\n if (!cachedModels) {\n throw new Error(\"Models not registered. Call createModels(...) once at startup (or import your models module) before using models.get.\")\n }\n return cachedModels[scope]\n}\n\nexport type { ModelModules, ModelsScope }\n","import assert from \"assert\"\n\nimport { getGlobalDbName, getTenantDbName } from \"./dbNames\"\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport { getRegisteredModels, registerModels, type ModelsScope } from \"./registerModels\"\nimport { hasRegisteredPolicy, type AppAbility } from \"./acl\"\n\n\nexport type LoadModelCtx = {\n req: {\n session?: {\n user?: {\n currentTenantId?: string;\n }\n } | null;\n };\n ability?: AppAbility;\n};\n\nconst loadModelFromDb = async (\n modelName: string,\n dbName: string,\n scope: ModelsScope,\n) => {\n const schemas = getRegisteredModels(scope)\n const schema = schemas[modelName]\n assert(schema, `Model ${modelName} not registered. Available models: ${Object.keys(schemas).join(\", \")}`)\n\n const modelConnection = await ensureMongooseConnection(dbName)\n\n if (!modelConnection.models[modelName]) {\n modelConnection.model(modelName, schema)\n }\n\n return modelConnection.models[modelName]\n}\n\nconst getTenantIdFromCtx = (ctx: LoadModelCtx): string => {\n const tenantId = ctx.req.session?.user?.currentTenantId\n assert(typeof tenantId === \"string\" && tenantId.trim(), \"Tenant ID is missing from session\")\n return tenantId\n}\n\nexport const models = {\n register: registerModels,\n\n getUnsafe: async (modelName: string, ctx: LoadModelCtx) => {\n const tenantId = getTenantIdFromCtx(ctx)\n const dbName = getTenantDbName(tenantId)\n return loadModelFromDb(modelName, dbName, \"tenant\")\n },\n\n get: async (modelName: string, ctx: LoadModelCtx) => {\n const model = await models.getUnsafe(modelName, ctx)\n const resolvedAbility = ctx.ability\n\n const isProtected = hasRegisteredPolicy(modelName)\n if (!isProtected) {\n return model\n }\n\n if (!resolvedAbility) {\n throw new Error(\n `Model \"${modelName}\" is ACL-protected. Set ctx.ability or use models.getUnsafe(...) explicitly.`,\n )\n }\n\n if (typeof (model as { acl?: unknown }).acl !== \"function\") return model\n return (model as { acl: (appAbility: AppAbility) => typeof model }).acl(resolvedAbility)\n },\n\n getGlobal: async (modelName: string, ctx: LoadModelCtx) => {\n const dbName = getGlobalDbName()\n return loadModelFromDb(modelName, dbName, \"global\")\n },\n} as const\n","import type { LoadModelCtx } from \"./modelsApi\"\nimport type { ModelModules } from \"./registerModels\"\nimport type * as frameworkSchemas from \"./models\"\nimport { models } from \"./modelsApi\"\nimport { registerModels } from \"./registerModels\"\n\n\ntype ExtractModelNamesFromSchemas<TModules> = {\n [K in keyof TModules]-?: K extends `${infer Name}Schema` ? Name : never\n}[keyof TModules] & string\n\ntype FrameworkModelName = ExtractModelNamesFromSchemas<typeof frameworkSchemas>\n\ntype RpcbaseGlobalModelName = Extract<FrameworkModelName, \"RBUser\" | \"RBTenant\" | \"RBOAuthRequest\">\n\nexport type TenantModelName<TTenantModules extends ModelModules> =\n ExtractModelNamesFromSchemas<TTenantModules>\n\nexport type GlobalModelName<TGlobalModules extends ModelModules> =\n | RpcbaseGlobalModelName\n | ExtractModelNamesFromSchemas<TGlobalModules>\n\ntype LoadedTenantModel = Awaited<ReturnType<(typeof models)[\"get\"]>>\ntype LoadedGlobalModel = Awaited<ReturnType<(typeof models)[\"getGlobal\"]>>\n\ntype ModelsGetFn<TTenantModules extends ModelModules> = {\n (\n modelName: TenantModelName<TTenantModules>,\n ctx: LoadModelCtx,\n ): ReturnType<(typeof models)[\"get\"]>\n <const TNames extends readonly TenantModelName<TTenantModules>[]>(\n modelNames: TNames,\n ctx: LoadModelCtx,\n ): Promise<{ [K in keyof TNames]: LoadedTenantModel }>\n}\n\ntype ModelsGetUnsafeFn<TTenantModules extends ModelModules> = {\n (modelName: TenantModelName<TTenantModules>, ctx: LoadModelCtx): ReturnType<(typeof models)[\"getUnsafe\"]>\n <const TNames extends readonly TenantModelName<TTenantModules>[]>(\n modelNames: TNames,\n ctx: LoadModelCtx,\n ): Promise<{ [K in keyof TNames]: LoadedTenantModel }>\n}\n\ntype ModelsGetGlobalFn<TGlobalModules extends ModelModules> = {\n (modelName: GlobalModelName<TGlobalModules>, ctx: LoadModelCtx): ReturnType<(typeof models)[\"getGlobal\"]>\n <const TNames extends readonly GlobalModelName<TGlobalModules>[]>(\n modelNames: TNames,\n ctx: LoadModelCtx,\n ): Promise<{ [K in keyof TNames]: LoadedGlobalModel }>\n}\n\nexport type ModelsConfig<TTenantModules extends ModelModules, TGlobalModules extends ModelModules> = {\n tenant: TTenantModules\n global?: TGlobalModules\n}\n\nexport type ModelsClient<TTenantModules extends ModelModules, TGlobalModules extends ModelModules> = {\n register: (modules: ModelsConfig<TTenantModules, TGlobalModules>) => void\n get: ModelsGetFn<TTenantModules>\n getUnsafe: ModelsGetUnsafeFn<TTenantModules>\n getGlobal: ModelsGetGlobalFn<TGlobalModules>\n}\n\nexport const createModels = <\n TTenantModules extends ModelModules,\n TGlobalModules extends ModelModules = Record<string, never>,\n>(modules: ModelsConfig<TTenantModules, TGlobalModules>): ModelsClient<TTenantModules, TGlobalModules> => {\n registerModels(modules)\n\n const get = (async (\n modelNameOrNames: TenantModelName<TTenantModules> | readonly TenantModelName<TTenantModules>[],\n ctx: LoadModelCtx,\n ) => {\n if (Array.isArray(modelNameOrNames)) {\n return Promise.all(modelNameOrNames.map((modelName) => models.get(modelName as string, ctx)))\n }\n return models.get(modelNameOrNames as string, ctx)\n }) as ModelsClient<TTenantModules, TGlobalModules>[\"get\"]\n\n const getUnsafe = (async (\n modelNameOrNames: TenantModelName<TTenantModules> | readonly TenantModelName<TTenantModules>[],\n ctx: LoadModelCtx,\n ) => {\n if (Array.isArray(modelNameOrNames)) {\n return Promise.all(modelNameOrNames.map((modelName) => models.getUnsafe(modelName as string, ctx)))\n }\n return models.getUnsafe(modelNameOrNames as string, ctx)\n }) as ModelsClient<TTenantModules, TGlobalModules>[\"getUnsafe\"]\n\n const getGlobal = (async (\n modelNameOrNames: GlobalModelName<TGlobalModules> | readonly GlobalModelName<TGlobalModules>[],\n ctx: LoadModelCtx,\n ) => {\n if (Array.isArray(modelNameOrNames)) {\n return Promise.all(modelNameOrNames.map((modelName) => models.getGlobal(modelName as string, ctx)))\n }\n return models.getGlobal(modelNameOrNames as string, ctx)\n }) as ModelsClient<TTenantModules, TGlobalModules>[\"getGlobal\"]\n\n return {\n register: registerModels,\n get,\n getUnsafe,\n getGlobal,\n }\n}\n","import assert from \"assert\"\n\nimport type mongoose from \"mongoose\"\n\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport type { LoadModelCtx } from \"./modelsApi\"\n\n\nconst getAppName = (): string => {\n const appName = process.env.APP_NAME?.trim()\n assert(appName, \"Missing APP_NAME\")\n return appName\n}\n\nconst normalizeTenantId = (tenantId: string): string => {\n const normalized = tenantId.trim()\n assert(normalized, \"Tenant ID is missing\")\n return normalized\n}\n\nexport const getTenantFilesystemDbName = (tenantId: string): string =>\n `${getAppName()}-${normalizeTenantId(tenantId)}-filesystem-db`\n\nexport const getTenantFilesystemDb = async (tenantId: string): Promise<mongoose.Connection> =>\n ensureMongooseConnection(getTenantFilesystemDbName(tenantId))\n\nexport const getTenantFilesystemDbFromCtx = async (ctx: LoadModelCtx): Promise<mongoose.Connection> => {\n const tenantId = ctx.req.session?.user?.currentTenantId\n assert(typeof tenantId === \"string\" && tenantId.trim(), \"Tenant ID is missing from session\")\n return getTenantFilesystemDb(tenantId)\n}\n","import type mongoose from \"mongoose\"\nimport type { ClientSession } from \"mongoose\"\n\nimport { getGlobalDbName, getTenantDbName } from \"./dbNames\"\nimport { ensureMongooseConnection } from \"./ensureMongooseConnection\"\nimport type { LoadModelCtx } from \"./modelsApi\"\nimport { getTenantFilesystemDbName } from \"./tenantFilesystemDb\"\n\n\ntype MongooseTransactionOptions = Parameters<ClientSession[\"withTransaction\"]>[1]\n\nexport type TenantGlobalFilesystemTransactionCtx = {\n tenantId: string\n session: ClientSession\n ctx: {\n tenant: LoadModelCtx\n global: LoadModelCtx\n }\n db: {\n tenant: mongoose.Connection\n global: mongoose.Connection\n filesystem: mongoose.Connection\n }\n}\n\ntype WithTransactionScope =\n | string\n | { tenantId: string }\n | { ctx: LoadModelCtx }\n\nconst getTenantIdFromLoadModelCtx = (ctx: LoadModelCtx): string => {\n const raw = ctx.req.session?.user?.currentTenantId\n if (typeof raw !== \"string\") {\n throw new Error(\"Tenant ID is missing from ctx\")\n }\n const tenantId = raw.trim()\n if (!tenantId) {\n throw new Error(\"Tenant ID is missing from ctx\")\n }\n return tenantId\n}\n\nconst buildTenantLoadModelCtx = (tenantId: string): LoadModelCtx => ({\n req: {\n session: {\n user: {\n currentTenantId: tenantId,\n },\n },\n },\n})\n\nexport function withTransaction<T>(\n tenantId: string,\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T>\nexport function withTransaction<T>(\n scope: { tenantId: string } | { ctx: LoadModelCtx },\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T>\nexport async function withTransaction<T>(\n scope: WithTransactionScope,\n fn: (ctx: TenantGlobalFilesystemTransactionCtx) => Promise<T>,\n options?: MongooseTransactionOptions,\n): Promise<T> {\n const normalizedTenantId = (() => {\n if (typeof scope === \"string\") return scope.trim()\n if (\"tenantId\" in scope) return scope.tenantId.trim()\n return getTenantIdFromLoadModelCtx(scope.ctx)\n })()\n\n if (!normalizedTenantId) throw new Error(\"Tenant ID is missing\")\n\n const tenantDbName = getTenantDbName(normalizedTenantId)\n const globalDbName = getGlobalDbName()\n const filesystemDbName = getTenantFilesystemDbName(normalizedTenantId)\n\n const tenantDb = await ensureMongooseConnection(tenantDbName)\n const globalDb = await ensureMongooseConnection(globalDbName)\n const filesystemDb = await ensureMongooseConnection(filesystemDbName)\n\n const session = await tenantDb.startSession()\n\n const tenantCtx: LoadModelCtx = typeof scope === \"object\" && \"ctx\" in scope\n ? scope.ctx\n : buildTenantLoadModelCtx(normalizedTenantId)\n\n const globalCtx: LoadModelCtx = { req: { session: null } }\n\n try {\n return await session.withTransaction(async () => fn({\n tenantId: normalizedTenantId,\n session,\n ctx: {\n tenant: tenantCtx,\n global: globalCtx,\n },\n db: {\n tenant: tenantDb,\n global: globalDb,\n filesystem: filesystemDb,\n },\n }), options)\n } finally {\n await session.endSession()\n }\n}\n"],"names":["ZRBUser","z","object","email","string","optional","password","name","phone","tenants","array","tenantRoles","record","oauthProviders","subject","accessToken","refreshToken","idToken","scope","tokenType","expiresAt","date","rawUserInfo","unknown","createdAt","updatedAt","emailVerificationCode","length","emailVerificationExpiresAt","RBUserSchema","Schema","type","String","unique","sparse","required","index","Map","of","default","Date","Types","Mixed","_id","ZRBTenant","tenantId","parentTenantId","RBTenantSchema","ZRBTenantSubscriptionStatus","enum","ZRBTenantSubscriptionIntervalUnit","ZRBTenantSubscriptionType","ZRBTenantSubscriptionScope","ZRBTenantSubscription","subscriptionId","parentSubscriptionId","scopeId","planKey","status","intervalUnit","intervalCount","number","int","min","modules","currentPeriodStart","currentPeriodEnd","trialEndsAt","cancelAt","cancelAtPeriodEnd","boolean","canceledAt","provider","providerCustomerId","providerSubscriptionId","latestEventId","latestEventAt","metadata","RBTenantSubscriptionSchema","options","Number","Boolean","ZRBTenantSubscriptionEventSource","ZRBTenantSubscriptionChangeDirection","ZRBTenantSubscriptionEvent","occurredAt","effectiveAt","fromPlanKey","toPlanKey","fromStatus","toStatus","fromModules","toModules","fromIntervalUnit","toIntervalUnit","fromIntervalCount","toIntervalCount","direction","actorUserId","source","reason","providerEventId","providerPayload","RBTenantSubscriptionEventSchema","now","undefined","ZRBRtsCounter","seq","RBRtsCounterSchema","versionKey","ttlSecondsRaw","process","env","RB_RTS_CHANGES_TTL_S","ttlSeconds","isFinite","Math","max","floor","ZRBRtsChangeOp","ZRBRtsChange","modelName","op","docId","ts","RBRtsChangeSchema","expireAfterSeconds","ZRBUploadSessionStatus","ZRBUploadSession","userId","ownerKeyHash","filename","mimeType","totalSize","chunkSize","chunksTotal","fileId","isPublic","error","RBUploadSessionSchema","RBUploadSessionPolicy","define","builder","ctx","can","uploadKeyHash","claims","trim","ZRBUploadChunk","uploadId","data","size","sha256","RBUploadChunkSchema","Buffer","ZRBNotification","topic","title","body","url","seenAt","readAt","archivedAt","TTL_90_DAYS_S","RBNotificationSchema","RBNotificationPolicy","ZRBNotificationDigestFrequency","ZRBNotificationTopicPreference","inApp","emailDigest","push","ZRBNotificationSettings","digestFrequency","topicPreferences","lastDigestSentAt","TopicPreferenceSchema","RBNotificationSettingsSchema","timestamps","RBNotificationSettingsPolicy","ZRBOAuthRequest","providerId","codeVerifier","returnTo","RBOAuthRequestSchema","extendMongooseSchema","baseSchema","extensions","schema","clone","forEach","extension","add","omitMongooseSchemaPaths","paths","path","remove","localizedStringField","userGet","get","value","withLocalizedStringFallback","model","mongoose","PaginationValidationError","Error","code","statusCode","constructor","message","isPaginationValidationError","anyError","DISALLOWED_MONGO_FIELD_SEGMENTS","Set","PAGINATION_LIMIT_MAX","normalizePaginationSpec","spec","limit","normalizeLimit","Array","isArray","sort","map","field","order","assertSafeMongoFieldPath","normalizeOrder","seenFields","has","primaryOrder","isInteger","startsWith","parts","split","part","test","encodePaginationCursor","node","normalized","values","Object","create","readFieldValue","encodeCursorValue","payload","v","payloadB64","from","JSON","stringify","toString","sigB64","signCursorPayloadB64","signingSecret","decodePaginationCursor","cursor","rest","verifyCursorSignature","payloadRaw","payloadUnknown","parse","decoded","prototype","hasOwnProperty","call","encodedValue","decodeCursorValue","secret","createHmac","update","digest","expectedSigB64","a","b","timingSafeEqual","ObjectId","$oid","toHexString","$date","toISOString","d","isNaN","getTime","isValid","reduce","acc","key","compileMongoPagination","mongoLimit","mongoSort","toMongoSort","mongoFilterDelta","cursorValues","buildKeysetFilterDelta","forQueryOrder","invertOrder","branches","i","current","and","j","prev","eq","getKeysetOp","cmpOp","cmp","$and","$or","materializeMongoPagination","compiled","fetchedNodes","hasMore","trimmed","slice","nodes","reverse","hasPrevPage","hasNextPage","pageInfo","prevCursor","nextCursor","MongoAdapter","applyPagination","query","where","paginateMongoQuery","pagination","exec","getQueryOptions","getOptions","getPaginationFromOptions","getCursorFromOptions","paginationCursor","mongoPaginationPlugin","pluginOptions","paginate","buildSearchTextStage","stage","$search","text","highlightPath","highlight","searchMetaProjection","score","$meta","highlights","listResultHasIndex","listResult","firstBatch","some","idx","isIndexAlreadyExistsError","codeName","ensureSearchIndex","params","collection","db","command","listSearchIndexes","created","createSearchIndexes","indexes","definition","getAppName","appName","APP_NAME","GLOBAL_DB_SUFFIX","getGlobalDbName","getTenantDbName","getMongoUrl","explicitUrl","MONGODB_URL","MONGO_URL","MONGODB_URI","DB_URL","port","DB_PORT","host","DB_HOST","connections","rootConnection","waitForOpen","connection","readyState","Promise","resolve","reject","once","ensureMongooseConnection","dbName","normalizedDbName","existing","mongoUrl","createConnection","sanitizeFilter","useDb","useCache","set","RTS_COUNTER_ID","EXCLUDED_MODEL_NAMES","maxDeleteIdsRaw","RB_RTS_DELETE_LOG_MAX_IDS","maxDeleteIds","deleteMetaByQuery","WeakMap","hasToString","maybe","normalizeId","id","getDbName","raw","databaseName","isGlobalDb","endsWith","getQuerySession","opts","session","getRtsModels","RtsCounter","models","RBRtsCounter","RtsChange","RBRtsChange","allocateSeqRange","count","updated","findOneAndUpdate","$inc","upsert","returnDocument","setDefaultsOnInsert","projection","lean","end","start","insertChanges","changes","docs","c","insertMany","recordDeleteChanges","ids","uniqueIds","filter","recordResetModel","captureDeleteMeta","mode","getFilter","getQuery","findQuery","find","reset","trimmedIds","meta","flushDeleteMeta","delete","rtsChangeLogPlugin","pre","document","post","doc","isRecord","mergeMongoQuery","left","right","leftQuery","keys","getStoredAclFromQuery","rbAcl","getStoredAclFromAggregate","aggregate","acl","addQueryAclFilter","action","storedAcl","ability","resolvedAction","accessQuery","accessibleBy","ofType","injectAggregateMatch","pipeline","match","unshift","$match","first","geoNear","$geoNear","splice","addAggregateAclFilter","patchAggregateAcl","globalKey","Symbol","for","globalState","globalThis","AggregatePrototype","Aggregate","option","createModelAclProxy","Proxy","target","prop","receiver","Reflect","args","result","apply","mongooseAclPlugin","setOptions","statics","cachedModels","DEFAULT_GLOBAL_RB_MODEL_NAMES_SET","assertSchema","exportName","join","getFrameworkSchemaForModelName","frameworkSchemas","applyTenantPlugins","plugin","accessibleRecordsPlugin","registerSchema","other","buildSchemasFromModules","entries","schemaValue","replace","registerModels","tenant","global","registerPoliciesFromModules","tenantSchemas","globalSchemas","cloned","frameworkSchema","allSchemas","getRegisteredModels","loadModelFromDb","schemas","assert","modelConnection","getTenantIdFromCtx","req","user","currentTenantId","register","getUnsafe","resolvedAbility","isProtected","hasRegisteredPolicy","getGlobal","createModels","modelNameOrNames","all","normalizeTenantId","getTenantFilesystemDbName","getTenantFilesystemDb","getTenantFilesystemDbFromCtx","getTenantIdFromLoadModelCtx","buildTenantLoadModelCtx","withTransaction","fn","normalizedTenantId","tenantDbName","globalDbName","filesystemDbName","tenantDb","globalDb","filesystemDb","startSession","tenantCtx","globalCtx","filesystem","endSession"],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import { AppAbility } from './acl';
1
2
  export type LoadModelCtx = {
2
3
  req: {
3
4
  session?: {
@@ -6,12 +7,14 @@ export type LoadModelCtx = {
6
7
  };
7
8
  } | null;
8
9
  };
10
+ ability?: AppAbility;
9
11
  };
10
12
  export declare const models: {
11
13
  readonly register: ({ tenant, global }: {
12
14
  tenant: import('./registerModels').ModelModules;
13
15
  global?: import('./registerModels').ModelModules;
14
16
  }) => void;
17
+ readonly getUnsafe: (modelName: string, ctx: LoadModelCtx) => Promise<import('mongoose').Model<any, {}, {}, {}, any, any, any>>;
15
18
  readonly get: (modelName: string, ctx: LoadModelCtx) => Promise<import('mongoose').Model<any, {}, {}, {}, any, any, any>>;
16
19
  readonly getGlobal: (modelName: string, ctx: LoadModelCtx) => Promise<import('mongoose').Model<any, {}, {}, {}, any, any, any>>;
17
20
  };
@@ -1 +1 @@
1
- {"version":3,"file":"modelsApi.d.ts","sourceRoot":"","sources":["../src/modelsApi.ts"],"names":[],"mappings":"AAOA,MAAM,MAAM,YAAY,GAAG;IACzB,GAAG,EAAE;QACH,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,EAAE;gBACL,eAAe,CAAC,EAAE,MAAM,CAAC;aAC1B,CAAA;SACF,GAAG,IAAI,CAAC;KACV,CAAC;CACH,CAAC;AA0BF,eAAO,MAAM,MAAM;;;cAc66B,CAAC;;8BAXx6B,MAAM,OAAO,YAAY;oCAMnB,MAAM,OAAO,YAAY;CAI9C,CAAA"}
1
+ {"version":3,"file":"modelsApi.d.ts","sourceRoot":"","sources":["../src/modelsApi.ts"],"names":[],"mappings":"AAKA,OAAO,EAAuB,KAAK,UAAU,EAAE,MAAM,OAAO,CAAA;AAG5D,MAAM,MAAM,YAAY,GAAG;IACzB,GAAG,EAAE;QACH,OAAO,CAAC,EAAE;YACR,IAAI,CAAC,EAAE;gBACL,eAAe,CAAC,EAAE,MAAM,CAAC;aAC1B,CAAA;SACF,GAAG,IAAI,CAAC;KACV,CAAC;IACF,OAAO,CAAC,EAAE,UAAU,CAAC;CACtB,CAAC;AA0BF,eAAO,MAAM,MAAM;;;cAiCiP,CAAC;;oCA9BtO,MAAM,OAAO,YAAY;8BAM/B,MAAM,OAAO,YAAY;oCAmBnB,MAAM,OAAO,YAAY;CAI9C,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rpcbase/db",
3
- "version": "0.64.0",
3
+ "version": "0.65.0",
4
4
  "type": "module",
5
5
  "files": [
6
6
  "dist"
@@ -1 +0,0 @@
1
- {"version":3,"file":"can-D558uqd-.js","sources":["../src/acl/registry.ts","../src/acl/buildAbility.ts","../src/acl/session.ts","../src/acl/accessible.ts","../src/acl/can.ts"],"sourcesContent":["import type { AbilityBuilder } from \"@casl/ability\"\n\nimport type { AclContext, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport type AclPolicy = {\n subject: Exclude<AclSubjectType, \"all\">\n define: (builder: AbilityBuilder<AppAbility>, ctx: AclContext) => void\n}\n\nconst POLICIES_GLOBAL_KEY = Symbol.for(\"@rpcbase/db/acl/policiesBySubject\")\n\nconst getGlobalPoliciesMap = (): Map<string, Set<AclPolicy[\"define\"]>> => {\n const store = globalThis as unknown as Record<symbol, unknown>\n const existing = store[POLICIES_GLOBAL_KEY]\n if (existing instanceof Map) {\n return existing as Map<string, Set<AclPolicy[\"define\"]>>\n }\n const created = new Map<string, Set<AclPolicy[\"define\"]>>()\n store[POLICIES_GLOBAL_KEY] = created\n return created\n}\n\nconst policiesBySubject = getGlobalPoliciesMap()\n\nconst isPolicy = (value: unknown): value is AclPolicy => {\n if (!value || typeof value !== \"object\") return false\n const maybe = value as Partial<AclPolicy>\n return typeof maybe.subject === \"string\" && typeof maybe.define === \"function\"\n}\n\nexport const registerPolicy = (policy: AclPolicy): void => {\n const set = policiesBySubject.get(policy.subject) ?? new Set<AclPolicy[\"define\"]>()\n set.add(policy.define)\n policiesBySubject.set(policy.subject, set)\n}\n\nexport const registerPoliciesFromModules = (modules: Record<string, unknown>): void => {\n for (const [exportName, value] of Object.entries(modules)) {\n if (!isPolicy(value)) continue\n\n if (!exportName.endsWith(\"Policy\")) {\n throw new Error(\n `Invalid policy export name \"${exportName}\". Policies must be exported as \"<ModelName>Policy\".`,\n )\n }\n\n const expectedSubject = exportName.slice(0, -(\"Policy\".length))\n if (value.subject !== expectedSubject) {\n throw new Error(\n `Invalid policy \"${exportName}\": expected subject \"${expectedSubject}\", got \"${value.subject}\".`,\n )\n }\n\n registerPolicy(value)\n }\n}\n\nexport const getRegisteredPolicies = (): Array<AclPolicy[\"define\"]> => {\n const out: Array<AclPolicy[\"define\"]> = []\n for (const set of policiesBySubject.values()) {\n for (const fn of set) out.push(fn)\n }\n return out\n}\n","import { AbilityBuilder, createMongoAbility } from \"@casl/ability\"\n\nimport { getRegisteredPolicies } from \"./registry\"\nimport type { AclContext, AppAbility } from \"./types\"\n\n\nexport const buildAbility = (ctx: AclContext): AppAbility => {\n const builder = new AbilityBuilder<AppAbility>(createMongoAbility)\n\n const { can } = builder\n\n if (ctx.roles.includes(\"owner\") || ctx.roles.includes(\"admin\")) {\n can(\"manage\", \"all\")\n }\n\n for (const define of getRegisteredPolicies()) {\n define(builder, ctx)\n }\n\n return builder.build()\n}\n\n","import { buildAbility } from \"./buildAbility\"\nimport type { AppAbility, TenantRolesByTenantId } from \"./types\"\n\n\ntype SessionUserLike = {\n id?: unknown\n signedInTenants?: unknown\n tenantRoles?: unknown\n}\n\ntype SessionLike = {\n user?: SessionUserLike\n}\n\nconst normalizeRole = (raw: unknown): string | null => {\n if (typeof raw !== \"string\") return null\n const normalized = raw.trim()\n return normalized ? normalized : null\n}\n\nconst normalizeRoles = (raw: unknown): string[] => {\n if (Array.isArray(raw)) {\n return raw.map(normalizeRole).filter((r): r is string => Boolean(r))\n }\n const role = normalizeRole(raw)\n return role ? [role] : []\n}\n\nconst normalizeRolesByTenantId = (raw: unknown): TenantRolesByTenantId | null => {\n if (!raw || typeof raw !== \"object\") return null\n if (raw instanceof Map) {\n return Object.fromEntries(Array.from(raw.entries()).map(([key, value]) => [String(key), normalizeRoles(value)]))\n }\n const obj = raw as Record<string, unknown>\n const out: TenantRolesByTenantId = {}\n for (const [key, value] of Object.entries(obj)) {\n const tenantId = String(key).trim()\n if (!tenantId) continue\n out[tenantId] = normalizeRoles(value)\n }\n return out\n}\n\nexport const getTenantRolesFromSessionUser = (user: unknown, tenantId: string): string[] => {\n if (!user || typeof user !== \"object\") return []\n const rolesByTenantId = normalizeRolesByTenantId((user as SessionUserLike).tenantRoles)\n if (!rolesByTenantId) return []\n return rolesByTenantId[tenantId]?.filter(Boolean) ?? []\n}\n\nexport const buildAbilityFromSession = ({\n tenantId,\n session,\n claims,\n}: {\n tenantId: string\n session: SessionLike | null | undefined\n claims?: Record<string, unknown>\n}): AppAbility => {\n const user = session?.user\n const userId = typeof user?.id === \"string\" ? user.id.trim() : \"\"\n const rolesByTenantId = normalizeRolesByTenantId(user?.tenantRoles)\n const hasExplicitTenantEntry = Boolean(\n rolesByTenantId && Object.prototype.hasOwnProperty.call(rolesByTenantId, tenantId),\n )\n\n const signedInTenantsRaw = user?.signedInTenants\n const signedInTenants = Array.isArray(signedInTenantsRaw) ? signedInTenantsRaw.map(String) : []\n\n const roles = hasExplicitTenantEntry\n ? rolesByTenantId![tenantId] ?? []\n : userId && signedInTenants.includes(tenantId)\n ? [\"owner\"]\n : getTenantRolesFromSessionUser(user, tenantId)\n\n return buildAbility({\n tenantId,\n userId: userId || null,\n roles,\n claims,\n })\n}\n","import { accessibleBy } from \"@casl/mongoose\"\n\nimport type { AclAction, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport const getAccessibleByQuery = (\n ability: AppAbility,\n action: AclAction,\n subject: Exclude<AclSubjectType, \"all\">,\n): Record<string, unknown> => {\n return accessibleBy(ability, action).ofType(subject)\n}\n","import { subject } from \"@casl/ability\"\n\nimport type { AclAction, AclSubject, AclSubjectMap, AclSubjectType, AppAbility } from \"./types\"\n\n\nexport const can = <TSubject extends Exclude<AclSubjectType, \"all\">>(\n ability: AppAbility,\n action: AclAction,\n subjectType: TSubject,\n object?: Partial<AclSubjectMap[TSubject]> | null,\n): boolean => {\n if (object && typeof object === \"object\") {\n return ability.can(action, subject(subjectType, object) as unknown as AclSubject)\n }\n return ability.can(action, subjectType)\n}\n"],"names":["POLICIES_GLOBAL_KEY","Symbol","for","getGlobalPoliciesMap","store","globalThis","existing","Map","created","policiesBySubject","isPolicy","value","maybe","subject","define","registerPolicy","policy","set","get","Set","add","registerPoliciesFromModules","modules","exportName","Object","entries","endsWith","Error","expectedSubject","slice","length","getRegisteredPolicies","out","values","fn","push","buildAbility","ctx","builder","AbilityBuilder","createMongoAbility","can","roles","includes","build","normalizeRole","raw","normalized","trim","normalizeRoles","Array","isArray","map","filter","r","Boolean","role","normalizeRolesByTenantId","fromEntries","from","key","String","obj","tenantId","getTenantRolesFromSessionUser","user","rolesByTenantId","tenantRoles","buildAbilityFromSession","session","claims","userId","id","hasExplicitTenantEntry","prototype","hasOwnProperty","call","signedInTenantsRaw","signedInTenants","getAccessibleByQuery","ability","action","accessibleBy","ofType","subjectType","object"],"mappings":"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"}