@inixiative/json-rules 2.0.3 → 2.1.1
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/README.md +30 -11
- package/dist/index.cjs +7 -7
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +59 -12
- package/dist/index.d.ts +59 -12
- package/dist/index.js +7 -7
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -517,15 +517,28 @@ check(
|
|
|
517
517
|
|
|
518
518
|
## Lens & Multi-Source Data
|
|
519
519
|
|
|
520
|
-
|
|
520
|
+
> **For the full v2.1 lens guide — including the three anchor layers for `where`
|
|
521
|
+
> (lens-level, model-default, relation-descent), the `all` operator filter-first
|
|
522
|
+
> trick, per-model enum narrowing, and a validate-then-apply usage pattern —
|
|
523
|
+
> see [docs/LENS.md](./docs/LENS.md).**
|
|
524
|
+
> This section covers the high-level shape and the multi-source bridges.
|
|
521
525
|
|
|
522
|
-
|
|
526
|
+
The `Lens` primitive is a schema-aware view layer over one or more `FieldMap`s. It enables rule authoring against multi-source data (e.g. Prisma + an external CRM), with declarative cross-source `Bridge`s and recursive `Narrowing`s for both schema (picks/omits/enumPicks/enumOmits) and data (`where`).
|
|
523
527
|
|
|
524
|
-
|
|
528
|
+
### FieldMap & FieldMapSet
|
|
529
|
+
|
|
530
|
+
A `FieldMap` is `{ models, enums? }` — models keyed by name, plus an optional enum registry scoped to that source. A `FieldMapSet` groups one or more `FieldMap`s and declares the cross-source edges between them:
|
|
525
531
|
|
|
526
532
|
```ts
|
|
527
533
|
import { stitchFieldMaps } from '@inixiative/json-rules';
|
|
528
534
|
|
|
535
|
+
const prismaMap = {
|
|
536
|
+
models: {
|
|
537
|
+
FanUser: { fields: { /* ... */ } },
|
|
538
|
+
},
|
|
539
|
+
enums: { UserRole: ['admin', 'member'] },
|
|
540
|
+
};
|
|
541
|
+
|
|
529
542
|
const set = stitchFieldMaps({
|
|
530
543
|
maps: { prisma: prismaMap, salesforce: salesforceMap },
|
|
531
544
|
bridges: [
|
|
@@ -559,9 +572,9 @@ const lens = createLens({
|
|
|
559
572
|
|
|
560
573
|
The lens is **schema only** — no data lives on it. Runtime data (rows, foreign tables, FE picker sources) is passed alongside, separately, when you need it.
|
|
561
574
|
|
|
562
|
-
### LensNarrowing & `
|
|
575
|
+
### LensNarrowing & `where`
|
|
563
576
|
|
|
564
|
-
`LensNarrowing` is a recursive tree that narrows a parent `Lens` (or another `LensNarrowing`). Each narrowing can add picks/omits per model
|
|
577
|
+
`LensNarrowing` is a recursive tree that narrows a parent `Lens` (or another `LensNarrowing`). Each narrowing can add schema picks/omits per model, per-field enum picks/omits, and `where` clauses for data scope:
|
|
565
578
|
|
|
566
579
|
```ts
|
|
567
580
|
const narrowing: LensNarrowing = {
|
|
@@ -571,22 +584,28 @@ const narrowing: LensNarrowing = {
|
|
|
571
584
|
models: {
|
|
572
585
|
FanUser: { picks: ['email', 'firstName', 'crmId'] },
|
|
573
586
|
},
|
|
587
|
+
defaults: {
|
|
588
|
+
models: {
|
|
589
|
+
// applies wherever FanUser appears, root or nested
|
|
590
|
+
FanUser: { where: { field: 'deletedAt', operator: Operator.isEmpty } },
|
|
591
|
+
},
|
|
592
|
+
},
|
|
574
593
|
},
|
|
575
594
|
},
|
|
576
|
-
|
|
595
|
+
where: { field: 'tenantId', operator: Operator.equals, path: 'tenantId' },
|
|
577
596
|
};
|
|
578
597
|
```
|
|
579
598
|
|
|
580
|
-
|
|
599
|
+
Composition across chained narrowings is pure intersection. `where` clauses are anchored to the model they describe — the lens-level `where` ANDs at the root, model-default `where` injects at every visit of the model, and relation `where` injects when the rule descends. The `all` array operator gets a filter-first rewrite via implication so out-of-scope rows don't fail the user's "every row matches" check. See [docs/LENS.md](./docs/LENS.md) for the full anchor semantics.
|
|
581
600
|
|
|
582
601
|
### Lens Utilities
|
|
583
602
|
|
|
584
603
|
| Function | Purpose |
|
|
585
604
|
| --- | --- |
|
|
586
|
-
| `validateNarrowing(narrowing)` | Throws on structural or chain violations (incl. unresolvable
|
|
587
|
-
| `projectNarrowing(lens)` | Returns the effective `FieldMapSet` after applying every narrowing in the chain.
|
|
588
|
-
| `checkRuleAgainstLens(rule, lens)` | Validates a user rule's field paths against the
|
|
589
|
-
| `applyLens(rule, narrowing)` |
|
|
605
|
+
| `validateNarrowing(narrowing)` | Throws on structural or chain violations (incl. unresolvable `where` paths and items invisible from ancestors). Call this before `projectNarrowing` and at narrowing construction. |
|
|
606
|
+
| `projectNarrowing(lens)` | Returns the effective `FieldMapSet` after applying every narrowing in the chain. Composition is intersection across all layers. Use for SDK-contract / OpenAPI emission. |
|
|
607
|
+
| `checkRuleAgainstLens(rule, lens)` | Validates a user rule's field paths and enum values against the narrowed lens, path-aware. Returns `{ ok, violations }`. The security gate. |
|
|
608
|
+
| `applyLens(rule, narrowing)` | Composes the user rule with the lens's `where` clauses, injecting each at its anchor in the rule tree. Pass the result to `check` / `toPrisma` / `toSql`. |
|
|
590
609
|
|
|
591
610
|
### Evaluating Across Bridges
|
|
592
611
|
|
package/dist/index.cjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
'use strict';var j=require('dayjs'),qf=require('dayjs/plugin/isSameOrAfter.js'),Lf=require('dayjs/plugin/isSameOrBefore.js'),If=require('dayjs/plugin/timezone.js'),Nf=require('dayjs/plugin/utc.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var j__default=/*#__PURE__*/_interopDefault(j);var qf__default=/*#__PURE__*/_interopDefault(qf);var Lf__default=/*#__PURE__*/_interopDefault(Lf);var If__default=/*#__PURE__*/_interopDefault(If);var Nf__default=/*#__PURE__*/_interopDefault(Nf);var yo=typeof global=="object"&&global&&global.Object===Object&&global,De=yo;var ho=typeof self=="object"&&self&&self.Object===Object&&self,xo=De||ho||Function("return this")(),R=xo;var wo=R.Symbol,C=wo;var qr=Object.prototype,bo=qr.hasOwnProperty,Oo=qr.toString,_e=C?C.toStringTag:void 0;function Ao(e){var r=bo.call(e,_e),t=e[_e];try{e[_e]=void 0;var a=!0;}catch{}var o=Oo.call(e);return a&&(r?e[_e]=t:delete e[_e]),o}var Lr=Ao;var $o=Object.prototype,vo=$o.toString;function Eo(e){return vo.call(e)}var Ir=Eo;var So="[object Null]",Ro="[object Undefined]",Nr=C?C.toStringTag:void 0;function To(e){return e==null?e===void 0?Ro:So:Nr&&Nr in Object(e)?Lr(e):Ir(e)}var P=To;function _o(e){return e!=null&&typeof e=="object"}var B=_o;var ko="[object Symbol]";function Mo(e){return typeof e=="symbol"||B(e)&&P(e)==ko}var fe=Mo;function Fo(e,r){for(var t=-1,a=e==null?0:e.length,o=Array(a);++t<a;)o[t]=r(e[t],t,e);return o}var jr=Fo;var Co=Array.isArray,S=Co;var Wr=C?C.prototype:void 0,Vr=Wr?Wr.toString:void 0;function Ur(e){if(typeof e=="string")return e;if(S(e))return jr(e,Ur)+"";if(fe(e))return Vr?Vr.call(e):"";var r=e+"";return r=="0"&&1/e==-Infinity?"-0":r}var Gr=Ur;function Bo(e){var r=typeof e;return e!=null&&(r=="object"||r=="function")}var D=Bo;function Do(e){return e}var Kr=Do;var qo="[object AsyncFunction]",Lo="[object Function]",Io="[object GeneratorFunction]",No="[object Proxy]";function jo(e){if(!D(e))return false;var r=P(e);return r==Lo||r==Io||r==qo||r==No}var qe=jo;var Wo=R["__core-js_shared__"],Le=Wo;var zr=(function(){var e=/[^.]+$/.exec(Le&&Le.keys&&Le.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function Vo(e){return !!zr&&zr in e}var Hr=Vo;var Uo=Function.prototype,Go=Uo.toString;function Ko(e){if(e!=null){try{return Go.call(e)}catch{}try{return e+""}catch{}}return ""}var I=Ko;var zo=/[\\^$.*+?()[\]{}|]/g,Ho=/^\[object .+?Constructor\]$/,Jo=Function.prototype,Qo=Object.prototype,Yo=Jo.toString,Xo=Qo.hasOwnProperty,Zo=RegExp("^"+Yo.call(Xo).replace(zo,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function en(e){if(!D(e)||Hr(e))return false;var r=qe(e)?Zo:Ho;return r.test(I(e))}var Jr=en;function rn(e,r){return e?.[r]}var Qr=rn;function tn(e,r){var t=Qr(e,r);return Jr(t)?t:void 0}var M=tn;var an=M(R,"WeakMap"),Ie=an;var on=(function(){try{var e=M(Object,"defineProperty");return e({},"",{}),e}catch{}})(),ur=on;var nn=9007199254740991,sn=/^(?:0|[1-9]\d*)$/;function fn(e,r){var t=typeof e;return r=r??nn,!!r&&(t=="number"||t!="symbol"&&sn.test(e))&&e>-1&&e%1==0&&e<r}var le=fn;function ln(e,r,t){r=="__proto__"&&ur?ur(e,r,{configurable:true,enumerable:true,value:t,writable:true}):e[r]=t;}var Yr=ln;function un(e,r){return e===r||e!==e&&r!==r}var ue=un;var pn=9007199254740991;function dn(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=pn}var pe=dn;function mn(e){return e!=null&&pe(e.length)&&!qe(e)}var U=mn;function cn(e,r,t){if(!D(t))return false;var a=typeof r;return (a=="number"?U(t)&&le(r,t.length):a=="string"&&r in t)?ue(t[r],e):false}var Xr=cn;var gn=Object.prototype;function yn(e){var r=e&&e.constructor,t=typeof r=="function"&&r.prototype||gn;return e===t}var Ne=yn;function hn(e,r){for(var t=-1,a=Array(e);++t<e;)a[t]=r(t);return a}var Zr=hn;var xn="[object Arguments]";function wn(e){return B(e)&&P(e)==xn}var pr=wn;var et=Object.prototype,bn=et.hasOwnProperty,On=et.propertyIsEnumerable,An=pr((function(){return arguments})())?pr:function(e){return B(e)&&bn.call(e,"callee")&&!On.call(e,"callee")},de=An;function $n(){return false}var rt=$n;var ot=typeof exports=="object"&&exports&&!exports.nodeType&&exports,tt=ot&&typeof module=="object"&&module&&!module.nodeType&&module,vn=tt&&tt.exports===ot,at=vn?R.Buffer:void 0,En=at?at.isBuffer:void 0,Sn=En||rt,ee=Sn;var Rn="[object Arguments]",Tn="[object Array]",_n="[object Boolean]",kn="[object Date]",Mn="[object Error]",Fn="[object Function]",Cn="[object Map]",Pn="[object Number]",Bn="[object Object]",Dn="[object RegExp]",qn="[object Set]",Ln="[object String]",In="[object WeakMap]",Nn="[object ArrayBuffer]",jn="[object DataView]",Wn="[object Float32Array]",Vn="[object Float64Array]",Un="[object Int8Array]",Gn="[object Int16Array]",Kn="[object Int32Array]",zn="[object Uint8Array]",Hn="[object Uint8ClampedArray]",Jn="[object Uint16Array]",Qn="[object Uint32Array]",v={};v[Wn]=v[Vn]=v[Un]=v[Gn]=v[Kn]=v[zn]=v[Hn]=v[Jn]=v[Qn]=true;v[Rn]=v[Tn]=v[Nn]=v[_n]=v[jn]=v[kn]=v[Mn]=v[Fn]=v[Cn]=v[Pn]=v[Bn]=v[Dn]=v[qn]=v[Ln]=v[In]=false;function Yn(e){return B(e)&&pe(e.length)&&!!v[P(e)]}var nt=Yn;function Xn(e){return function(r){return e(r)}}var it=Xn;var st=typeof exports=="object"&&exports&&!exports.nodeType&&exports,ke=st&&typeof module=="object"&&module&&!module.nodeType&&module,Zn=ke&&ke.exports===st,dr=Zn&&De.process,ei=(function(){try{var e=ke&&ke.require&&ke.require("util").types;return e||dr&&dr.binding&&dr.binding("util")}catch{}})(),mr=ei;var ft=mr&&mr.isTypedArray,ri=ft?it(ft):nt,me=ri;var ti=Object.prototype,ai=ti.hasOwnProperty;function oi(e,r){var t=S(e),a=!t&&de(e),o=!t&&!a&&ee(e),n=!t&&!a&&!o&&me(e),i=t||a||o||n,s=i?Zr(e.length,String):[],f=s.length;for(var u in e)(r||ai.call(e,u))&&!(i&&(u=="length"||o&&(u=="offset"||u=="parent")||n&&(u=="buffer"||u=="byteLength"||u=="byteOffset")||le(u,f)))&&s.push(u);return s}var lt=oi;function ni(e,r){return function(t){return e(r(t))}}var ut=ni;var ii=ut(Object.keys,Object),pt=ii;var si=Object.prototype,fi=si.hasOwnProperty;function li(e){if(!Ne(e))return pt(e);var r=[];for(var t in Object(e))fi.call(e,t)&&t!="constructor"&&r.push(t);return r}var je=li;function ui(e){return U(e)?lt(e):je(e)}var ce=ui;var pi=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,di=/^\w*$/;function mi(e,r){if(S(e))return false;var t=typeof e;return t=="number"||t=="symbol"||t=="boolean"||e==null||fe(e)?true:di.test(e)||!pi.test(e)||r!=null&&e in Object(r)}var ge=mi;var ci=M(Object,"create"),N=ci;function gi(){this.__data__=N?N(null):{},this.size=0;}var dt=gi;function yi(e){var r=this.has(e)&&delete this.__data__[e];return this.size-=r?1:0,r}var mt=yi;var hi="__lodash_hash_undefined__",xi=Object.prototype,wi=xi.hasOwnProperty;function bi(e){var r=this.__data__;if(N){var t=r[e];return t===hi?void 0:t}return wi.call(r,e)?r[e]:void 0}var ct=bi;var Oi=Object.prototype,Ai=Oi.hasOwnProperty;function $i(e){var r=this.__data__;return N?r[e]!==void 0:Ai.call(r,e)}var gt=$i;var vi="__lodash_hash_undefined__";function Ei(e,r){var t=this.__data__;return this.size+=this.has(e)?0:1,t[e]=N&&r===void 0?vi:r,this}var yt=Ei;function ye(e){var r=-1,t=e==null?0:e.length;for(this.clear();++r<t;){var a=e[r];this.set(a[0],a[1]);}}ye.prototype.clear=dt;ye.prototype.delete=mt;ye.prototype.get=ct;ye.prototype.has=gt;ye.prototype.set=yt;var cr=ye;function Si(){this.__data__=[],this.size=0;}var ht=Si;function Ri(e,r){for(var t=e.length;t--;)if(ue(e[t][0],r))return t;return -1}var G=Ri;var Ti=Array.prototype,_i=Ti.splice;function ki(e){var r=this.__data__,t=G(r,e);if(t<0)return false;var a=r.length-1;return t==a?r.pop():_i.call(r,t,1),--this.size,true}var xt=ki;function Mi(e){var r=this.__data__,t=G(r,e);return t<0?void 0:r[t][1]}var wt=Mi;function Fi(e){return G(this.__data__,e)>-1}var bt=Fi;function Ci(e,r){var t=this.__data__,a=G(t,e);return a<0?(++this.size,t.push([e,r])):t[a][1]=r,this}var Ot=Ci;function he(e){var r=-1,t=e==null?0:e.length;for(this.clear();++r<t;){var a=e[r];this.set(a[0],a[1]);}}he.prototype.clear=ht;he.prototype.delete=xt;he.prototype.get=wt;he.prototype.has=bt;he.prototype.set=Ot;var K=he;var Pi=M(R,"Map"),z=Pi;function Bi(){this.size=0,this.__data__={hash:new cr,map:new(z||K),string:new cr};}var At=Bi;function Di(e){var r=typeof e;return r=="string"||r=="number"||r=="symbol"||r=="boolean"?e!=="__proto__":e===null}var $t=Di;function qi(e,r){var t=e.__data__;return $t(r)?t[typeof r=="string"?"string":"hash"]:t.map}var H=qi;function Li(e){var r=H(this,e).delete(e);return this.size-=r?1:0,r}var vt=Li;function Ii(e){return H(this,e).get(e)}var Et=Ii;function Ni(e){return H(this,e).has(e)}var St=Ni;function ji(e,r){var t=H(this,e),a=t.size;return t.set(e,r),this.size+=t.size==a?0:1,this}var Rt=ji;function xe(e){var r=-1,t=e==null?0:e.length;for(this.clear();++r<t;){var a=e[r];this.set(a[0],a[1]);}}xe.prototype.clear=At;xe.prototype.delete=vt;xe.prototype.get=Et;xe.prototype.has=St;xe.prototype.set=Rt;var re=xe;var Wi="Expected a function";function gr(e,r){if(typeof e!="function"||r!=null&&typeof r!="function")throw new TypeError(Wi);var t=function(){var a=arguments,o=r?r.apply(this,a):a[0],n=t.cache;if(n.has(o))return n.get(o);var i=e.apply(this,a);return t.cache=n.set(o,i)||n,i};return t.cache=new(gr.Cache||re),t}gr.Cache=re;var Tt=gr;var Vi=500;function Ui(e){var r=Tt(e,function(a){return t.size===Vi&&t.clear(),a}),t=r.cache;return r}var _t=Ui;var Gi=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,Ki=/\\(\\)?/g,zi=_t(function(e){var r=[];return e.charCodeAt(0)===46&&r.push(""),e.replace(Gi,function(t,a,o,n){r.push(o?n.replace(Ki,"$1"):a||t);}),r}),kt=zi;function Hi(e){return e==null?"":Gr(e)}var Mt=Hi;function Ji(e,r){return S(e)?e:ge(e,r)?[e]:kt(Mt(e))}var We=Ji;function Yi(e){if(typeof e=="string"||fe(e))return e;var r=e+"";return r=="0"&&1/e==-Infinity?"-0":r}var J=Yi;function Xi(e,r){r=We(r,e);for(var t=0,a=r.length;e!=null&&t<a;)e=e[J(r[t++])];return t&&t==a?e:void 0}var Ve=Xi;function Zi(e,r,t){var a=e==null?void 0:Ve(e,r);return a===void 0?t:a}var A=Zi;function es(e,r){for(var t=-1,a=r.length,o=e.length;++t<a;)e[o+t]=r[t];return e}var Ft=es;function rs(){this.__data__=new K,this.size=0;}var Ct=rs;function ts(e){var r=this.__data__,t=r.delete(e);return this.size=r.size,t}var Pt=ts;function as(e){return this.__data__.get(e)}var Bt=as;function os(e){return this.__data__.has(e)}var Dt=os;var ns=200;function is(e,r){var t=this.__data__;if(t instanceof K){var a=t.__data__;if(!z||a.length<ns-1)return a.push([e,r]),this.size=++t.size,this;t=this.__data__=new re(a);}return t.set(e,r),this.size=t.size,this}var qt=is;function we(e){var r=this.__data__=new K(e);this.size=r.size;}we.prototype.clear=Ct;we.prototype.delete=Pt;we.prototype.get=Bt;we.prototype.has=Dt;we.prototype.set=qt;var be=we;function ss(e,r){for(var t=-1,a=e==null?0:e.length,o=0,n=[];++t<a;){var i=e[t];r(i,t,e)&&(n[o++]=i);}return n}var Lt=ss;function fs(){return []}var It=fs;var ls=Object.prototype,us=ls.propertyIsEnumerable,Nt=Object.getOwnPropertySymbols,ps=Nt?function(e){return e==null?[]:(e=Object(e),Lt(Nt(e),function(r){return us.call(e,r)}))}:It,jt=ps;function ds(e,r,t){var a=r(e);return S(e)?a:Ft(a,t(e))}var Wt=ds;function ms(e){return Wt(e,ce,jt)}var yr=ms;var cs=M(R,"DataView"),Ue=cs;var gs=M(R,"Promise"),Ge=gs;var ys=M(R,"Set"),Ke=ys;var Vt="[object Map]",hs="[object Object]",Ut="[object Promise]",Gt="[object Set]",Kt="[object WeakMap]",zt="[object DataView]",xs=I(Ue),ws=I(z),bs=I(Ge),Os=I(Ke),As=I(Ie),te=P;(Ue&&te(new Ue(new ArrayBuffer(1)))!=zt||z&&te(new z)!=Vt||Ge&&te(Ge.resolve())!=Ut||Ke&&te(new Ke)!=Gt||Ie&&te(new Ie)!=Kt)&&(te=function(e){var r=P(e),t=r==hs?e.constructor:void 0,a=t?I(t):"";if(a)switch(a){case xs:return zt;case ws:return Vt;case bs:return Ut;case Os:return Gt;case As:return Kt}return r});var Me=te;var $s=R.Uint8Array,hr=$s;var vs="__lodash_hash_undefined__";function Es(e){return this.__data__.set(e,vs),this}var Ht=Es;function Ss(e){return this.__data__.has(e)}var Jt=Ss;function ze(e){var r=-1,t=e==null?0:e.length;for(this.__data__=new re;++r<t;)this.add(e[r]);}ze.prototype.add=ze.prototype.push=Ht;ze.prototype.has=Jt;var Qt=ze;function Rs(e,r){for(var t=-1,a=e==null?0:e.length;++t<a;)if(r(e[t],t,e))return true;return false}var He=Rs;function Ts(e,r){return e.has(r)}var Yt=Ts;var _s=1,ks=2;function Ms(e,r,t,a,o,n){var i=t&_s,s=e.length,f=r.length;if(s!=f&&!(i&&f>s))return false;var u=n.get(e),p=n.get(r);if(u&&p)return u==r&&p==e;var c=-1,d=true,b=t&ks?new Qt:void 0;for(n.set(e,r),n.set(r,e);++c<s;){var x=e[c],O=r[c];if(a)var E=i?a(O,x,c,r,e,n):a(x,O,c,e,r,n);if(E!==void 0){if(E)continue;d=false;break}if(b){if(!He(r,function(T,F){if(!Yt(b,F)&&(x===T||o(x,T,t,a,n)))return b.push(F)})){d=false;break}}else if(!(x===O||o(x,O,t,a,n))){d=false;break}}return n.delete(e),n.delete(r),d}var Je=Ms;function Fs(e){var r=-1,t=Array(e.size);return e.forEach(function(a,o){t[++r]=[o,a];}),t}var Xt=Fs;function Cs(e){var r=-1,t=Array(e.size);return e.forEach(function(a){t[++r]=a;}),t}var Zt=Cs;var Ps=1,Bs=2,Ds="[object Boolean]",qs="[object Date]",Ls="[object Error]",Is="[object Map]",Ns="[object Number]",js="[object RegExp]",Ws="[object Set]",Vs="[object String]",Us="[object Symbol]",Gs="[object ArrayBuffer]",Ks="[object DataView]",ea=C?C.prototype:void 0,xr=ea?ea.valueOf:void 0;function zs(e,r,t,a,o,n,i){switch(t){case Ks:if(e.byteLength!=r.byteLength||e.byteOffset!=r.byteOffset)return false;e=e.buffer,r=r.buffer;case Gs:return !(e.byteLength!=r.byteLength||!n(new hr(e),new hr(r)));case Ds:case qs:case Ns:return ue(+e,+r);case Ls:return e.name==r.name&&e.message==r.message;case js:case Vs:return e==r+"";case Is:var s=Xt;case Ws:var f=a&Ps;if(s||(s=Zt),e.size!=r.size&&!f)return false;var u=i.get(e);if(u)return u==r;a|=Bs,i.set(e,r);var p=Je(s(e),s(r),a,o,n,i);return i.delete(e),p;case Us:if(xr)return xr.call(e)==xr.call(r)}return false}var ra=zs;var Hs=1,Js=Object.prototype,Qs=Js.hasOwnProperty;function Ys(e,r,t,a,o,n){var i=t&Hs,s=yr(e),f=s.length,u=yr(r),p=u.length;if(f!=p&&!i)return false;for(var c=f;c--;){var d=s[c];if(!(i?d in r:Qs.call(r,d)))return false}var b=n.get(e),x=n.get(r);if(b&&x)return b==r&&x==e;var O=true;n.set(e,r),n.set(r,e);for(var E=i;++c<f;){d=s[c];var T=e[d],F=r[d];if(a)var k=i?a(F,T,d,r,e,n):a(T,F,d,e,r,n);if(!(k===void 0?T===F||o(T,F,t,a,n):k)){O=false;break}E||(E=d=="constructor");}if(O&&!E){var ie=e.constructor,se=r.constructor;ie!=se&&"constructor"in e&&"constructor"in r&&!(typeof ie=="function"&&ie instanceof ie&&typeof se=="function"&&se instanceof se)&&(O=false);}return n.delete(e),n.delete(r),O}var ta=Ys;var Xs=1,aa="[object Arguments]",oa="[object Array]",Qe="[object Object]",Zs=Object.prototype,na=Zs.hasOwnProperty;function ef(e,r,t,a,o,n){var i=S(e),s=S(r),f=i?oa:Me(e),u=s?oa:Me(r);f=f==aa?Qe:f,u=u==aa?Qe:u;var p=f==Qe,c=u==Qe,d=f==u;if(d&&ee(e)){if(!ee(r))return false;i=true,p=false;}if(d&&!p)return n||(n=new be),i||me(e)?Je(e,r,t,a,o,n):ra(e,r,f,t,a,o,n);if(!(t&Xs)){var b=p&&na.call(e,"__wrapped__"),x=c&&na.call(r,"__wrapped__");if(b||x){var O=b?e.value():e,E=x?r.value():r;return n||(n=new be),o(O,E,t,a,n)}}return d?(n||(n=new be),ta(e,r,t,a,o,n)):false}var ia=ef;function sa(e,r,t,a,o){return e===r?true:e==null||r==null||!B(e)&&!B(r)?e!==e&&r!==r:ia(e,r,t,a,sa,o)}var Ye=sa;var rf=1,tf=2;function af(e,r,t,a){var o=t.length,n=o,i=!a;if(e==null)return !n;for(e=Object(e);o--;){var s=t[o];if(i&&s[2]?s[1]!==e[s[0]]:!(s[0]in e))return false}for(;++o<n;){s=t[o];var f=s[0],u=e[f],p=s[1];if(i&&s[2]){if(u===void 0&&!(f in e))return false}else {var c=new be;if(a)var d=a(u,p,f,e,r,c);if(!(d===void 0?Ye(p,u,rf|tf,a,c):d))return false}}return true}var fa=af;function of(e){return e===e&&!D(e)}var Xe=of;function nf(e){for(var r=ce(e),t=r.length;t--;){var a=r[t],o=e[a];r[t]=[a,o,Xe(o)];}return r}var la=nf;function sf(e,r){return function(t){return t==null?false:t[e]===r&&(r!==void 0||e in Object(t))}}var Ze=sf;function ff(e){var r=la(e);return r.length==1&&r[0][2]?Ze(r[0][0],r[0][1]):function(t){return t===e||fa(t,e,r)}}var ua=ff;function lf(e,r){return e!=null&&r in Object(e)}var pa=lf;function uf(e,r,t){r=We(r,e);for(var a=-1,o=r.length,n=false;++a<o;){var i=J(r[a]);if(!(n=e!=null&&t(e,i)))break;e=e[i];}return n||++a!=o?n:(o=e==null?0:e.length,!!o&&pe(o)&&le(i,o)&&(S(e)||de(e)))}var da=uf;function pf(e,r){return e!=null&&da(e,r,pa)}var ma=pf;var df=1,mf=2;function cf(e,r){return ge(e)&&Xe(r)?Ze(J(e),r):function(t){var a=A(t,e);return a===void 0&&a===r?ma(t,e):Ye(r,a,df|mf)}}var ca=cf;function gf(e){return function(r){return r?.[e]}}var ga=gf;function yf(e){return function(r){return Ve(r,e)}}var ya=yf;function hf(e){return ge(e)?ga(J(e)):ya(e)}var ha=hf;function xf(e){return typeof e=="function"?e:e==null?Kr:typeof e=="object"?S(e)?ca(e[0],e[1]):ua(e):ha(e)}var er=xf;function wf(e,r,t,a){for(var o=-1,n=e==null?0:e.length;++o<n;){var i=e[o];r(a,i,t(i),e);}return a}var xa=wf;function bf(e){return function(r,t,a){for(var o=-1,n=Object(r),i=a(r),s=i.length;s--;){var f=i[e?s:++o];if(t(n[f],f,n)===false)break}return r}}var wa=bf;var Of=wa(),ba=Of;function Af(e,r){return e&&ba(e,r,ce)}var Oa=Af;function $f(e,r){return function(t,a){if(t==null)return t;if(!U(t))return e(t,a);for(var o=t.length,n=r?o:-1,i=Object(t);(r?n--:++n<o)&&a(i[n],n,i)!==false;);return t}}var Aa=$f;var vf=Aa(Oa),rr=vf;function Ef(e,r,t,a){return rr(e,function(o,n,i){r(a,o,t(o),i);}),a}var $a=Ef;function Sf(e,r){return function(t,a){var o=S(t)?xa:$a,n=r?r():{};return o(t,e,er(a),n)}}var va=Sf;var Rf=Object.prototype,Tf=Rf.hasOwnProperty,_f=va(function(e,r,t){Tf.call(e,t)?e[t].push(r):Yr(e,t,[r]);}),wr=_f;var kf="[object Map]",Mf="[object Set]",Ff=Object.prototype,Cf=Ff.hasOwnProperty;function Pf(e){if(e==null)return true;if(U(e)&&(S(e)||typeof e=="string"||typeof e.splice=="function"||ee(e)||me(e)||de(e)))return !e.length;var r=Me(e);if(r==kf||r==Mf)return !e.size;if(Ne(e))return !je(e).length;for(var t in e)if(Cf.call(e,t))return false;return true}var tr=Pf;function Bf(e,r){var t;return rr(e,function(a,o,n){return t=r(a,o,n),!t}),!!t}var Ea=Bf;function Df(e,r,t){var a=S(e)?He:Ea;return t&&Xr(e,r,t)&&(r=void 0),a(e,er(r))}var br=Df;var l={equals:"equals",notEquals:"notEquals",lessThan:"lessThan",lessThanEquals:"lessThanEquals",greaterThan:"greaterThan",greaterThanEquals:"greaterThanEquals",contains:"contains",notContains:"notContains",in:"in",notIn:"notIn",matches:"matches",notMatches:"notMatches",between:"between",notBetween:"notBetween",isEmpty:"isEmpty",notEmpty:"notEmpty",exists:"exists",notExists:"notExists",startsWith:"startsWith",endsWith:"endsWith"},m={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},y={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};j__default.default.extend(Nf__default.default);j__default.default.extend(If__default.default);j__default.default.extend(Lf__default.default);j__default.default.extend(qf__default.default);var Sa=(e,r,t)=>{let a=A(r,e.field);if(!a)throw new Error(`${e.field} is null or undefined`);if(!Ar(a))throw new Error(`${e.field} is not a valid date: ${String(a)}`);let o=j__default.default(a);if(!o.isValid())throw new Error(`${e.field} is not a valid date: ${a}`);let n=u=>e.error||`${e.field} ${u}`,i=jf(e,r,t,o,a),s=i[0],f=i[1];switch(e.dateOperator){case y.before:return o.isBefore(s)||n(`must be before ${s.format()}`);case y.after:return o.isAfter(s)||n(`must be after ${s.format()}`);case y.onOrBefore:return o.isSameOrBefore(s)||n(`must be on or before ${s.format()}`);case y.onOrAfter:return o.isSameOrAfter(s)||n(`must be on or after ${s.format()}`);case y.between:{if(!f)throw new Error("between operator requires an end date");return o.isSameOrAfter(s)&&o.isSameOrBefore(f)||n(`must be between ${s.format()} and ${f?.format()}`)}case y.notBetween:{if(!f)throw new Error("notBetween operator requires an end date");return o.isBefore(s)||o.isAfter(f)||n(`must not be between ${s.format()} and ${f?.format()}`)}case y.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let u=o.format("dddd").toLowerCase(),p=e.value.map(c=>String(c).toLowerCase());return p.includes(u)||n(`must be on ${p.join(" or ")}`)}case y.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let u=o.format("dddd").toLowerCase(),p=e.value.map(c=>String(c).toLowerCase());return !p.includes(u)||n(`must not be on ${p.join(" or ")}`)}default:throw new Error("Unknown date operator")}},jf=(e,r,t,a,o)=>{if([y.between,y.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[s,f]=e.value,u=Or(s,o),p=Or(f,o);if(!u.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!p.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[c,d]=u.isBefore(p)||u.isSame(p)?[u,p]:[p,u];return [c,d]}if([y.before,y.after,y.onOrBefore,y.onOrAfter].includes(e.dateOperator)){let s;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);s=e.value;}else if(e.path)if(e.path.startsWith("$.")){let u=A(r,e.path.substring(2));s=Ar(u)?u:void 0;}else {let u=A(t,e.path);s=Ar(u)?u:void 0;}else throw new Error("No value or path specified for date comparison");let f=Or(s,o);if(!f.isValid())throw new Error(`Invalid comparison date: ${s}`);return [f,void 0]}return [j__default.default(),void 0]},Or=(e,r)=>{let t=String(e);if(t.includes("Z")||t.includes("T")&&(t.includes("+")||t.match(/T.*-\d{2}:/)))return j__default.default(e);let o=String(r),n=0;if(o.includes("+")||o.includes("T")&&o.match(/T.*-\d{2}:/)){let s=o.match(/([+-])(\d{2}):(\d{2})/);s&&(n=(s[1]==="+"?1:-1)*(parseInt(s[2],10)*60+parseInt(s[3],10)));}else o.includes("Z")||(n=0);return t.match(/^\d{4}-\d{2}-\d{2}$/)?j__default.default(`${e}T00:00:00`).subtract(n,"minute"):j__default.default(e).subtract(n,"minute")},Ar=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var ka=(e,r,t)=>{let a=A(r,e.field),n=![l.isEmpty,l.notEmpty,l.exists,l.notExists].includes(e.operator),i=n?Wf(e,r,t):void 0,s=f=>e.error||`${e.field} ${f}${n?` ${JSON.stringify(i)}`:""}`;switch(e.operator){case l.equals:return a===i||s("must equal");case l.notEquals:return a!==i||s("must not equal");case l.lessThan:return ar(a,i,"lt")||s("must be less than");case l.lessThanEquals:return ar(a,i,"lte")||s("must be less than or equal to");case l.greaterThan:return ar(a,i,"gt")||s("must be greater than");case l.greaterThanEquals:return ar(a,i,"gte")||s("must be greater than or equal to");case l.in:return Array.isArray(i)&&i.includes(a)||s("must be one of");case l.notIn:return !Array.isArray(i)||!i.includes(a)||s("must not be one of");case l.contains:return _a(a,i)||s("must contain");case l.notContains:return !_a(a,i)||s("must not contain");case l.matches:return Ra(a)&&(i instanceof RegExp||typeof i=="string")&&!!a.match(i)||s("must match pattern");case l.notMatches:return !Ra(a)||!(i instanceof RegExp||typeof i=="string")||!a.match(i)||s("must not match pattern");case l.between:{let f=Ta(i);if(!f)throw new Error("between operator requires an array of two values");if(!Oe(a))return s("must be between");let u=Ae(a),[p,c]=f;return u>=p&&u<=c||s("must be between")}case l.notBetween:{let f=Ta(i);if(!f)throw new Error("notBetween operator requires an array of two values");if(!Oe(a))return true;let u=Ae(a),[p,c]=f;return u<p||u>c||s("must not be between")}case l.isEmpty:return tr(a)||s("must be empty");case l.notEmpty:return !tr(a)||s("must not be empty");case l.exists:return a!==void 0||s("must exist");case l.notExists:return a===void 0||s("must not exist");case l.startsWith:return typeof a=="string"&&typeof i=="string"&&a.startsWith(i)||s("must start with");case l.endsWith:return typeof a=="string"&&typeof i=="string"&&a.endsWith(i)||s("must end with");default:throw new Error("Unknown operator")}},Wf=(e,r,t)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?A(r,e.path.substring(2)):A(t,e.path);throw new Error("No value or path specified")},Oe=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ae=e=>e instanceof Date?e.getTime():e,ar=(e,r,t)=>{if(!Oe(e)||!Oe(r))return false;let a=Ae(e),o=Ae(r);switch(t){case "lt":return a<o;case "lte":return a<=o;case "gt":return a>o;case "gte":return a>=o}},Ra=e=>typeof e=="string",Ta=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[r,t]=e;if(!Oe(r)||!Oe(t))return null;let a=Ae(r),o=Ae(t);return a<=o?[a,o]:[o,a]},_a=(e,r)=>typeof e=="string"?typeof r=="string"&&e.includes(r):Array.isArray(e)?e.includes(r):false;var $r=e=>{if(typeof e!="boolean"){if("all"in e){for(let r of e.all)$r(r);return}if("any"in e){for(let r of e.any)$r(r);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},ae=(e,r,t)=>{if(Array.isArray(r)&&$r(e),typeof e=="boolean")return e;let a={...t,context:t?.context??r};return "all"in e?Vf(e.all,r,a,e.error):"any"in e?Uf(e.any,r,a,e.error):"arrayOperator"in e?zf(e,r,a):"dateOperator"in e?Sa(e,r,a.context):"aggregate"in e?Kf(e,r,a):"field"in e?ka(e,r,a.context):"if"in e?Gf(e,r,a):false},Vf=(e,r,t,a)=>{let o=[];for(let n of e){let i=ae(n,r,t);i!==true&&(typeof i=="string"?o.push(i):o.push("false"));}return o.length?a||(o.length===1?o[0]:`All conditions must pass: ${o.join(" AND ")}`):true},Uf=(e,r,t,a)=>{let o=[];for(let n of e){let i=ae(n,r,t);if(i===true)return true;typeof i=="string"&&o.push(i);}return a||(o.length===1?o[0]:`At least one condition must pass: ${o.join(" OR ")}`)},Gf=(e,r,t)=>ae(e.if,r,t)===true?ae(e.then,r,t):e.else!==void 0?ae(e.else,r,t):true,Kf=(e,r,t)=>{let a=A(r,e.field);if(!Array.isArray(a))throw new Error(`${e.field} must be an array`);let{mode:o,field:n}=e.aggregate;if(o!=="sum"&&o!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let i=e.condition,f=(i?a.filter(x=>ae(i,x,t)===true):a).map((x,O)=>{let E=n?A(x,n):x;if(typeof E!="number"||!Number.isFinite(E)){let T=`${e.field}[${O}]${n?`.${n}`:""}`;throw new Error(`${T} must be a finite number`)}return E}),u=f.reduce((x,O)=>x+O,0),p=o==="sum"?u:f.length===0?0:u/f.length,c=t.context,d;if(e.value!==void 0)d=e.value;else if(e.path)d=e.path.startsWith("$.")?A(r,e.path.substring(2)):A(c,e.path);else throw new Error("Aggregate rule requires value or path");let b=x=>e.error||`${e.field} ${o} ${x} ${JSON.stringify(d)}`;switch(e.operator){case l.equals:return p===d||b("must equal");case l.notEquals:return p!==d||b("must not equal");case l.lessThan:return typeof d=="number"&&p<d||b("must be less than");case l.lessThanEquals:return typeof d=="number"&&p<=d||b("must be less than or equal to");case l.greaterThan:return typeof d=="number"&&p>d||b("must be greater than");case l.greaterThanEquals:return typeof d=="number"&&p>=d||b("must be greater than or equal to");case l.between:{if(!Array.isArray(d)||d.length!==2)throw new Error("between requires a two-element array");let[x,O]=d,[E,T]=x<=O?[x,O]:[O,x];return p>=E&&p<=T||b("must be between")}case l.notBetween:{if(!Array.isArray(d)||d.length!==2)throw new Error("notBetween requires a two-element array");let[x,O]=d,[E,T]=x<=O?[x,O]:[O,x];return p<E||p>T||b("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},zf=(e,r,t)=>{let a=e.field?A(r,e.field):r;if(!Array.isArray(a))throw new Error(`${e.field||"(root)"} must be an array`);let o=c=>e.error||`${e.field} ${c}`,n=[m.all,m.any,m.none,m.atLeast,m.atMost,m.exactly],i=[m.atLeast,m.atMost,m.exactly],s=e.condition;if(n.includes(e.arrayOperator)&&!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let f=e.count;if(i.includes(e.arrayOperator)&&f===void 0)throw new Error(`${e.arrayOperator} requires a count`);let u=0,p=0;if(n.includes(e.arrayOperator)){if(!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!br(a,D))return o("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let c=a.map(d=>ae(s,d,t));u=c.filter(d=>d===true).length,p=c.filter(d=>typeof d=="string").length;}switch(e.arrayOperator){case m.empty:return !a.length||o("must be empty");case m.notEmpty:return !!a.length||o("must not be empty");case m.all:return u===a.length||o(`all elements must match (${p} failed)`);case m.any:return !!u||o("at least one element must match");case m.none:return !u||o(`no elements should match (${u} matched)`);case m.atLeast:if(f===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u>=f||o(`at least ${f} elements must match (${u} matched)`);case m.atMost:if(f===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u<=f||o(`at most ${f} elements must match (${u} matched)`);case m.exactly:if(f===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u===f||o(`exactly ${f} elements must match (${u} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Ma=(e,r,t,a)=>{let o={};for(let n of e){let i=n[r];if(i==null)continue;let s=String(i);if(o[s]!==void 0){let f=a==="one"?`endpoint[0] must be the "one" side of a oneToMany bridge \u2014 swap endpoints if '${t}' is the "many" side`:`oneToOne bridges require unique '${r}' on both endpoints`;throw new Error(`buildBridgeDictionary: duplicate '${r}' value '${s}' on '${t}' \u2014 ${f}.`)}o[s]=n;}return o},Hf=(e,r)=>{let t={};for(let a of e.bridges??[]){let[o,n]=a.endpoints,i=`${o.fieldMap}:${o.model}`,s=`${n.fieldMap}:${n.model}`,f=a.cardinality==="oneToMany"?"one":"oneToOne";if(r[i]&&(t[o.fieldMap]??={},t[o.fieldMap][o.model]??={},t[o.fieldMap][o.model][o.on]=Ma(r[i],o.on,i,f)),r[s])if(t[n.fieldMap]??={},t[n.fieldMap][n.model]??={},a.cardinality==="oneToMany"){let u=r[s].filter(p=>p[n.on]!==null&&p[n.on]!==void 0);t[n.fieldMap][n.model][n.on]=wr(u,n.on);}else t[n.fieldMap][n.model][n.on]=Ma(r[s],n.on,s,"oneToOne");}return t};var vr=e=>{let r={maps:structuredClone(e.maps),bridges:e.bridges?structuredClone(e.bridges):void 0};for(let t of e.bridges??[]){let[a,o]=t.endpoints,n=r.maps[a.fieldMap]?.[a.model],i=r.maps[o.fieldMap]?.[o.model];if(!n)throw new Error(`stitchFieldMaps: endpoint '${a.fieldMap}:${a.model}' not found`);if(!i)throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' not found`);if(a.fieldMap===o.fieldMap&&a.model===o.model)throw new Error(`stitchFieldMaps: self-bridge '${a.fieldMap}:${a.model}' to itself is not supported`);if(!n.fields[a.on])throw new Error(`stitchFieldMaps: endpoint '${a.fieldMap}:${a.model}' has no field '${a.on}' for join`);if(!i.fields[o.on])throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' has no field '${o.on}' for join`);let s=`${a.fieldMap}:${a.model}`,f=`${o.fieldMap}:${o.model}`;if(n.fields[f])throw new Error(`stitchFieldMaps: bridge '${f}' already injected on '${s}'`);if(i.fields[s])throw new Error(`stitchFieldMaps: bridge '${s}' already injected on '${f}'`);let u=t.cardinality==="oneToMany";n.fields[f]={kind:"bridge",type:f,isList:u},i.fields[s]={kind:"bridge",type:s,isList:false};}return r};var Jf=/[.:]/,Fa=e=>{let r=[];for(let[t,a]of Object.entries(e.maps))for(let[o,n]of Object.entries(a))for(let[i,s]of Object.entries(n.fields))s.kind!=="bridge"&&Jf.test(i)&&r.push(`'${t}:${o}.${i}' contains forbidden character . or :`);if(r.length)throw new Error(`validateFieldMapSet:
|
|
2
|
-
${
|
|
3
|
-
`)}`)},Qf=(e,r="fieldMap")=>{Fa({maps:{[r]:e}});};var Ca=e=>"model"in e,$e=e=>{let r=new Set,t=e;for(;!Ca(t);){if(r.has(t))throw new Error("cycle detected in narrowing parent chain");r.add(t),t=t.parent;}return t},ve=e=>{let r=[],t=new Set,a=e;for(;!Ca(a);){if(t.has(a))throw new Error("cycle detected in narrowing parent chain");t.add(a),r.unshift(a),a=a.parent;}return r},oe=(e,r)=>{if(e.kind==="object")return {mapName:r,modelName:e.type};if(e.kind==="bridge"){let[t,a]=e.type.includes(":")?e.type.split(":"):[r,e.type];return {mapName:t,modelName:a}}return null},Er=(e,r,t,a)=>{let o=a.split("."),n=r,i=t;for(let s=0;s<o.length;s++){let f=e.maps[n]?.[i];if(!f)return null;let u=f.fields[o[s]];if(!u)return null;if(s===o.length-1)return {entry:u,mapName:n,modelName:i};let p=oe(u,n);if(!p)return null;n=p.mapName,i=p.modelName;}return null};var Yf=(e,r)=>{let t=ve(r),a=[];for(let o of t)o.constrains!==void 0&&a.push(o.constrains);return a.length?{all:[...a,e]}:e};var Pa=(e,r,t,a,o)=>{let n=e[r];if(n){if(o.picks){let i=new Set(o.picks);for(let s of Object.keys(o.relations??{}))i.add(s);for(let s of Object.keys(n.fields))i.has(s)||delete n.fields[s];}if(o.omits)for(let i of o.omits)delete n.fields[i];for(let[i,s]of Object.entries(o.relations??{})){let f=n.fields[i];if(!f)continue;let u=oe(f,t);if(!u)continue;let p=a.maps[u.mapName];p&&Pa(p,u.modelName,u.mapName,a,s);}}},Sr=e=>{let r=$e(e),t={maps:structuredClone(r.maps),bridges:r.bridges?structuredClone(r.bridges):void 0},a=ve(e);for(let o of a)for(let[n,i]of Object.entries(o.maps)){let s=t.maps[n];if(s)for(let[f,u]of Object.entries(i.models))Pa(s,f,n,t,u);}return t.bridges&&(t.bridges=t.bridges.filter(o=>{let[n,i]=o.endpoints,s=`${i.fieldMap}:${i.model}`,f=`${n.fieldMap}:${n.model}`,u=t.maps[n.fieldMap]?.[n.model]?.fields[s]!==void 0,p=t.maps[i.fieldMap]?.[i.model]?.fields[f]!==void 0;return u&&p})),t};var ne=(e,r,t,a,o)=>{if(typeof e=="boolean")return;if("all"in e){for(let s of e.all)ne(s,r,t,a,o);return}if("any"in e){for(let s of e.any)ne(s,r,t,a,o);return}if("if"in e){ne(e.if,r,t,a,o),ne(e.then,r,t,a,o),e.else!==void 0&&ne(e.else,r,t,a,o);return}let n=t,i=a;if("field"in e&&typeof e.field=="string"&&e.field!==""){let s=Er(r,t,a,e.field);if(!s){o.push({path:e.field,reason:"path does not resolve through the narrowed lens"});return}let f=oe(s.entry,s.mapName);f&&(n=f.mapName,i=f.modelName);}if("aggregate"in e&&typeof e.aggregate=="object"&&e.aggregate!==null&&typeof e.aggregate.field=="string"&&e.aggregate.field!==""){let s=e.aggregate.field;Er(r,n,i,s)||o.push({path:s,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ne(e.condition,r,n,i,o);},Rr=(e,r)=>{let t=$e(r),a=Sr(r),o=[];return ne(e,a,t.mapName,t.model,o),{ok:o.length===0,violations:o}};var Xf=e=>({...vr({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var Ba=(e,r,t,a,o,n,i)=>{e.picks&&e.omits&&i.push(`${n}: cannot specify both picks and omits`);for(let s of e.picks??[]){if(!t[s]){i.push(`${n}.picks: field '${s}' not on model`);continue}for(let f of r){if(f.picks&&!f.picks.includes(s)){i.push(`${n}.picks: '${s}' not in ancestor's picks`);break}if(f.omits?.includes(s)){i.push(`${n}.picks: '${s}' was omitted by ancestor`);break}}}for(let s of e.omits??[]){if(!t[s]){i.push(`${n}.omits: field '${s}' not on model`);continue}for(let f of r)if(f.picks&&!f.picks.includes(s)){i.push(`${n}.omits: '${s}' not in ancestor's picks (already invisible)`);break}}for(let[s,f]of Object.entries(e.relations??{})){let u=t[s];if(!u){i.push(`${n}.relations: '${s}' not on model`);continue}if(u.kind!=="object"&&u.kind!=="bridge"){i.push(`${n}.relations: '${s}' is not a relation (kind=${u.kind})`);continue}let p=oe(u,a);if(!p)continue;let c=o.maps[p.mapName]?.[p.modelName]?.fields;if(!c){i.push(`${n}.relations.${s}: target model not found in lens`);continue}let d=r.map(b=>b.relations?.[s]).filter(b=>b!==void 0);Ba(f,d,c,p.mapName,o,`${n}.relations.${s}`,i);}},Zf=e=>{let r=[],t=$e(e),a=ve(e.parent);for(let[o,n]of Object.entries(e.maps)){let i=t.maps[o];if(!i){r.push(`maps.${o}: not in lens`);continue}for(let[s,f]of Object.entries(n.models)){let u=i[s];if(!u){r.push(`maps.${o}.models.${s}: not in fieldMap`);continue}let p=a.map(c=>c.maps[o]?.models[s]).filter(c=>c!==void 0);Ba(f,p,u.fields,o,t,`maps.${o}.models.${s}`,r);}}if(e.constrains!==void 0){let o=Rr(e.constrains,e);for(let n of o.violations)r.push(`constrains: '${n.path}' ${n.reason}`);}if(r.length)throw new Error(`validateNarrowing:
|
|
4
|
-
${
|
|
5
|
-
`)}`)};var el={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},rl=["Int","Float","Decimal","BigInt"],Ee=["String",...rl,"DateTime"],Q=["String"],or=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],Da=Object.values(el),mh={check:"check",toPrisma:"toPrisma",toSql:"toSql"},$=["check","toPrisma","toSql"],Se=["check","toPrisma"],nr=["check","toSql"],ch={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},q={[l.equals]:{kinds:or,targets:$,valueShape:"scalar"},[l.notEquals]:{kinds:or,targets:$,valueShape:"scalar"},[l.lessThan]:{kinds:Ee,targets:$,valueShape:"ordered"},[l.lessThanEquals]:{kinds:Ee,targets:$,valueShape:"ordered"},[l.greaterThan]:{kinds:Ee,targets:$,valueShape:"ordered"},[l.greaterThanEquals]:{kinds:Ee,targets:$,valueShape:"ordered"},[l.in]:{kinds:or,targets:$,valueShape:"array"},[l.notIn]:{kinds:or,targets:$,valueShape:"array"},[l.contains]:{kinds:Q,targets:$,valueShape:"string"},[l.notContains]:{kinds:Q,targets:$,valueShape:"string"},[l.startsWith]:{kinds:Q,targets:$,valueShape:"string"},[l.endsWith]:{kinds:Q,targets:$,valueShape:"string"},[l.matches]:{kinds:Q,targets:nr,valueShape:"pattern"},[l.notMatches]:{kinds:Q,targets:nr,valueShape:"pattern"},[l.between]:{kinds:Ee,targets:$,valueShape:"range"},[l.notBetween]:{kinds:Ee,targets:$,valueShape:"range"},[l.isEmpty]:{kinds:Q,targets:$,valueShape:"none"},[l.notEmpty]:{kinds:Q,targets:$,valueShape:"none"},[l.exists]:{kinds:Da,targets:$,valueShape:"none"},[l.notExists]:{kinds:Da,targets:$,valueShape:"none"}},Y={[y.before]:{kinds:["DateTime"],targets:$,valueShape:"dateValue"},[y.after]:{kinds:["DateTime"],targets:$,valueShape:"dateValue"},[y.onOrBefore]:{kinds:["DateTime"],targets:$,valueShape:"dateValue"},[y.onOrAfter]:{kinds:["DateTime"],targets:$,valueShape:"dateValue"},[y.between]:{kinds:["DateTime"],targets:$,valueShape:"dateRange"},[y.notBetween]:{kinds:["DateTime"],targets:$,valueShape:"dateRange"},[y.dayIn]:{kinds:["DateTime"],targets:nr,valueShape:"dayList"},[y.dayNotIn]:{kinds:["DateTime"],targets:nr,valueShape:"dayList"}},X={[m.all]:{targets:Se,valueShape:"predicate"},[m.any]:{targets:Se,valueShape:"predicate"},[m.none]:{targets:Se,valueShape:"predicate"},[m.atLeast]:{targets:Se,valueShape:"count"},[m.atMost]:{targets:Se,valueShape:"count"},[m.exactly]:{targets:Se,valueShape:"count"},[m.empty]:{targets:$,valueShape:"none"},[m.notEmpty]:{targets:$,valueShape:"none"}},tl=new Set(["scalar","ordered"]),al=new Set(["range"]),gh=[l.equals,l.notEquals,l.lessThan,l.lessThanEquals,l.greaterThan,l.greaterThanEquals,l.between,l.notBetween],qa=e=>{let r=q[e];return r?tl.has(r.valueShape):false},La=e=>{let r=q[e];return r?al.has(r.valueShape):false},Tr=e=>{if(Object.hasOwn(q,e))return q[e].valueShape;if(Object.hasOwn(Y,e))return Y[e].valueShape;if(Object.hasOwn(X,e))return X[e].valueShape;throw new Error(`Unknown operator: ${e}`)},ir=(e,r)=>Object.hasOwn(q,e)?q[e].targets.includes(r):Object.hasOwn(Y,e)?Y[e].targets.includes(r):Object.hasOwn(X,e)?X[e].targets.includes(r):false,yh=(e,r)=>{let t=Object.keys(q).filter(o=>{let n=q[o];return !(!n.kinds.includes(e)||r&&!n.targets.includes(r))}),a=Object.keys(Y).filter(o=>{let n=Y[o];return !(!n.kinds.includes(e)||r&&!n.targets.includes(r))});return {field:t,date:a}},hh=e=>Object.keys(X).filter(r=>e?X[r].targets.includes(e):true);var sr=(e,r,t,a)=>{let o=e[r];if(!o)return null;for(let n of Object.values(o.fields))if(n.kind==="object"&&n.type===t&&(n.fromFields?.length??0)>0&&(n.toFields?.length??0)>0&&(a===void 0||n.relationName===a))return n;return null};var L=(e,r)=>{let t=e.split("."),a=r;for(let o=t.length-1;o>=0;o--)a={[t[o]]:a};return a};var Ia,Na=e=>{Ia=e;},ja=(e,r,t)=>{if(!r?.map||!r?.model||!t)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return nl(e,r,t)},ol=(e,r,t)=>{let a=e.split("."),o=[],n=t;for(let i=0;i<a.length;i++){let s=a[i],f=r[n]?.fields[s];if(!f||f.kind!=="object")throw new Error(`Field '${s}' is not a relation in model '${n}'. Prisma aggregate rules only support relation fields.`);if(i===a.length-1){if(!f.isList)throw new Error(`Field '${s}' is not a list relation in model '${n}'.`);return {segments:a,intermediateRelations:o,terminalModel:n,terminalEntry:f}}if(f.isList)throw new Error(`Intermediate field '${s}' in path '${e}' is a list relation. Only the final segment can be a list relation for aggregate rules.`);o.push({fieldName:s,entry:f,onModel:n}),n=f.type;}throw new Error(`Field path '${e}' did not terminate at a list relation.`)},nl=(e,r,t)=>{let{map:a,model:o}=r,{intermediateRelations:n,terminalModel:i,terminalEntry:s}=ol(e.field,a,o),f=s.type,u=e.aggregate.field??"",p=a[f]?.fields[u];if(!p)throw new Error(`aggregate.field '${u}' does not exist on model '${f}'.`);if(p.kind!=="scalar")throw new Error(`aggregate.field '${u}' on model '${f}' must be a scalar field, got '${p.kind}'.`);if(p.type==="Json")throw new Error(`aggregate.field '${u}' on model '${f}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let c,d;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");c=s.toFields?.[0]??"id",d=s.fromFields[0];}else {let k=sr(a,f,i,s.relationName);if(!k)throw new Error(`Cannot determine FK relationship between '${i}' and '${f}'. Ensure the FieldMap contains both sides of the relation.`);if((k.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");c=k.fromFields?.[0]??"",d=k.toFields?.[0]??"";}let b=e.condition?Ia(e.condition,{...r,model:f},t):{},x=e.aggregate.mode==="sum"?"_sum":"_avg",O={[u]:{[x]:il(e)}},E={operation:"groupBy",model:f,args:{by:[c],where:b,having:O},extract:c},T=t.steps.length;t.steps.push(E);let F={__step:T};if(n.length>0){let k={[d]:{in:F}},ie=n.map(se=>se.fieldName).join(".");return L(ie,k)}return {[d]:{in:F}}},il=e=>{let r=e.value;switch(e.operator){case l.equals:return {equals:r};case l.notEquals:return {not:r};case l.lessThan:return {lt:r};case l.lessThanEquals:return {lte:r};case l.greaterThan:return {gt:r};case l.greaterThanEquals:return {gte:r};case l.between:{if(!Array.isArray(r)||r.length!==2)throw new Error("between requires two values");let[t,a]=r,[o,n]=t<=a?[t,a]:[a,t];return {gte:o,lte:n}}case l.notBetween:throw new Error("Operator 'notBetween' is not supported for Prisma aggregate rules.");default:throw new Error(`Operator '${e.operator}' is not supported for Prisma aggregate rules.`)}};var Wa=(e,r,t,a)=>{let{map:o,model:n}=r;if(!e.field)throw new Error("toPrisma: count-based ArrayRule requires a field path");let i=o[n]?.fields[e.field];if(!i||i.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${n}'. Count operators require a relation field.`);if(!i.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${n}'. Count operators only apply to one-to-many or many-to-many relations.`);let s=i.type,f,u;if(i.fromFields&&i.fromFields.length>0){if(i.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${n}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);f=i.toFields?.[0]??"id",u=i.fromFields[0];}else {let E=sr(o,s,n,i.relationName);if(!E){let F=Object.values(o[s]?.fields??{}).some(k=>k.kind==="object"&&k.type===n&&k.isList&&!k.fromFields?.length);throw new Error(F?`'${n}.${e.field}' is an implicit many-to-many relation. Count operators require an explicit join model with a FK \u2014 convert to an explicit @relation or use prisma.$queryRaw.`:`Cannot determine FK relationship between '${n}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`)}if((E.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${n}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);f=E.fromFields?.[0]??"",u=E.toFields?.[0]??"";}let p=e.condition?a(e.condition,{...r,model:s},t):{},c=e.count??1,d=sl(e.arrayOperator,c,f),b={operation:"groupBy",model:s,args:{by:[f],where:p,having:d},extract:f},x=t.steps.length;t.steps.push(b);let O={__step:x};return {[u]:{in:O}}},sl=(e,r,t)=>{switch(e){case m.atLeast:return {[t]:{_count:{gte:r}}};case m.atMost:return {[t]:{_count:{lte:r}}};case m.exactly:return {[t]:{_count:{equals:r}}};default:throw new Error("unreachable")}};var Fe,Va=e=>{Fe=e;},Ua=(e,r,t)=>{if(e.arrayOperator===m.atLeast||e.arrayOperator===m.atMost||e.arrayOperator===m.exactly){if(r?.map&&r?.model&&t)return Wa(e,r,t,Fe);throw new Error(`ArrayOperator '${e.arrayOperator}' requires a FieldMap and model to generate a multi-step plan. Pass { map, model } options to toPrisma(). Without them, use prisma.$queryRaw for count-based relation filtering.`)}if(!e.field)throw new Error("toPrisma: ArrayRule.field is required (fieldless arrayOps are check-only)");let a=ul(e,r,t);return L(e.field,a)},fl=(e,r,t)=>{let a=e.split("."),o=t;for(let n of a){let i=r[o]?.fields[n];if(!i||i.kind!=="object")return null;o=i.type;}return o},ll=(e,r)=>{if(!r?.map||!r?.model||!e.field)return r;let t=fl(e.field,r.map,r.model);return t?{...r,model:t}:r},ul=(e,r,t)=>{let a=ll(e,r);switch(e.arrayOperator){case m.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:Fe(e.condition,a,t)};case m.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:Fe(e.condition,a,t)};case m.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:Fe(e.condition,a,t)};case m.empty:return {none:{}};case m.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var za=(e,r)=>{let t=dl(e,r);return L(e.field,t)},pl=(e,r)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column date comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!r?.context)throw new Error(`options.context is required to resolve date path '${e.path}'. Pass context when calling toPrisma().`);return A(r.context,e.path)}},dl=(e,r)=>{let t=()=>pl(e,r);switch(e.dateOperator){case y.before:return {lt:t()};case y.after:return {gt:t()};case y.onOrBefore:return {lte:t()};case y.onOrAfter:return {gte:t()};case y.between:{let a=t();if(!Array.isArray(a)||a.length!==2)throw new Error("between date operator requires an array of two values");let[o,n]=Ga(a);return {gte:o,lte:n}}case y.notBetween:{let a=t();if(!Array.isArray(a)||a.length!==2)throw new Error("notBetween date operator requires an array of two values");let[o,n]=Ga(a);return {NOT:{gte:o,lte:n}}}case y.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case y.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Ga=e=>{let[r,t]=e;return ml(r,t)<=0?[r,t]:[t,r]},ml=(e,r)=>{let t=Ka(e),a=Ka(r);return t<a?-1:t>a?1:0},Ka=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var fr=(e,r,t)=>{let a=e.split("."),o=t;for(let n=0;n<a.length;n++){let i=r[o];if(!i)return {kind:"fallback"};let s=i.fields[a[n]];if(!s)return {kind:"fallback"};if(s.kind==="bridge")return {kind:"bridge"};if(s.kind==="scalar"&&s.type==="Json"&&n<a.length-1)return {kind:"json-path",stopIndex:n+1,jsonPath:a.slice(n+1)};if(s.kind==="object"){if(!r[s.type])return {kind:"fallback"};o=s.type;continue}return {kind:"direct"}}return {kind:"direct"}};var Ha=(e,r)=>{if(e.operator===l.isEmpty)return {OR:[Ce(e.field,{equals:null},r),Ce(e.field,{equals:""},r)]};if(e.operator===l.notEmpty)return {AND:[Ce(e.field,{not:null},r),Ce(e.field,{not:""},r)]};let t=gl(e,r);return Ce(e.field,t,r)},cl=(e,r)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!r?.context)throw new Error(`options.context is required to resolve path '${e.path}'. Pass context when calling toPrisma().`);return A(r.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},gl=(e,r)=>{let t=()=>cl(e,r);switch(e.operator){case l.equals:return {equals:t()??null};case l.notEquals:return {not:t()??null};case l.lessThan:return {lt:t()};case l.lessThanEquals:return {lte:t()};case l.greaterThan:return {gt:t()};case l.greaterThanEquals:return {gte:t()};case l.in:return {in:t()};case l.notIn:return {notIn:t()};case l.contains:return {contains:t()};case l.notContains:return {not:{contains:t()}};case l.startsWith:return {startsWith:t()};case l.endsWith:return {endsWith:t()};case l.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case l.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case l.between:{let a=t();if(!Array.isArray(a)||a.length!==2)throw new Error("between operator requires an array of two values");let[o,n]=a[0]<=a[1]?a:[a[1],a[0]];return {gte:o,lte:n}}case l.notBetween:{let a=t();if(!Array.isArray(a)||a.length!==2)throw new Error("notBetween operator requires an array of two values");let[o,n]=a[0]<=a[1]?a:[a[1],a[0]];return {NOT:{gte:o,lte:n}}}case l.isEmpty:case l.notEmpty:throw new Error("isEmpty/notEmpty handled at buildFieldRule level");case l.exists:return {not:null};case l.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},Ce=(e,r,t)=>{if(!t?.map||!t?.model)return L(e,r);let a=fr(e,t.map,t.model),o=e.split(".");switch(a.kind){case "fallback":case "direct":return L(e,r);case "bridge":return {};case "json-path":{let n={path:a.jsonPath,...r},i=o.slice(0,a.stopIndex).join(".");return L(i,n)}}};var Re,Qa=e=>{Re=e;},yl=(e,r,t)=>{let a=e.split("."),o=t;for(let n of a){let i=r[o]?.fields[n];if(!i||i.kind!=="object")return null;o=i.type;}return o},W=(e,r)=>{if(typeof e=="boolean"||!r?.map||!r?.model)return false;if("all"in e)return e.all.some(t=>W(t,r));if("any"in e)return e.any.some(t=>W(t,r));if("if"in e)return W(e.if,r)||W(e.then,r)||e.else!==void 0&&W(e.else,r);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(fr(e.field,r.map,r.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let a=yl(e.field,r.map,r.model);if(a&&W(e.condition,{...r,model:a}))return true}}return false},Ya=(e,r,t)=>e.all.length===0?{}:{AND:e.all.map(a=>Re(a,r,t))},Xa=(e,r,t)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(a=>Re(a,r,t))},Za=(e,r,t)=>{if(W(e.if,r)||W(e.then,r)||e.else!==void 0&&W(e.else,r))return {};let a=Re(e.if,r,t),o={NOT:a},n=e.then===false?Ja:Re(e.then,r,t);if(e.else!==void 0){let i=e.else===false?Ja:Re(e.else,r,t);return {AND:[{OR:[o,n]},{OR:[a,i]}]}}return {OR:[o,n]}},Ja={AND:[{id:null},{id:{not:null}}]};var Pe=(e,r,t)=>{if(typeof e=="boolean"){if(e)return {};throw new Error("Boolean 'false' has no direct Prisma WHERE equivalent. toPrisma is designed for structured Rule conditions.")}if("all"in e)return Ya(e,r,t);if("any"in e)return Xa(e,r,t);if("if"in e)return Za(e,r,t);if("arrayOperator"in e)return Ua(e,r,t);if("dateOperator"in e)return za(e,r);if("aggregate"in e)return ja(e,r,t);if("field"in e)return Ha(e,r);throw new Error("Unknown condition type")};Qa(Pe);Va(Pe);Na(Pe);var hl=async(e,r)=>{let t=e.steps.filter(n=>n.operation==="groupBy"),a=e.steps.find(n=>n.operation==="where");if(!a)throw new Error("executePrismaQueryPlan: result has no where step");let o=[];for(let n of t){let i=n.model.charAt(0).toLowerCase()+n.model.slice(1),s=r[i];if(!s)throw new Error(`executePrismaQueryPlan: no delegate for model '${n.model}'. Ensure prismaDelegate has a key '${i}'.`);let f=await s[n.operation](n.args);o.push(f.map(u=>u[n.extract]));}return _r(a.where,o)},_r=(e,r)=>{if(e==null)return e;if(Array.isArray(e))return e.map(t=>_r(t,r));if(typeof e=="object"){let t=e;if("__step"in t&&typeof t.__step=="number"){let o=t.__step;if(o>=r.length)throw new Error(`Step ref __step: ${o} out of range (${r.length} steps executed)`);return r[o]}let a={};for(let[o,n]of Object.entries(t))a[o]=_r(n,r);return a}return e};var xl=e=>{if(!e?.map)return e;let r="maps"in e.map;if(r&&!e.mapName)throw new Error("toPrisma: 'map' is a FieldMapSet \u2014 'mapName' is required to resolve which map to use.");if(!r||!e.mapName)return e;let t=e.map.maps[e.mapName];if(!t)throw new Error(`toPrisma: fieldMap set has no entry for '${e.mapName}'`);return {...e,map:t}},Xh=(e,r)=>{let t={steps:[]},a=Pe(e,xl(r),t);return {steps:[...t.steps,{operation:"where",where:a}]}};var w=e=>`"${e.replace(/"/g,'""')}"`;var h=(e,r)=>(e.params.push(r),`$${++e.paramIndex}`);var Be=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),_=e=>{let r=e.split(".");if(r.length===1)return w(e);let[t,...a]=r;return a.length===0?w(t):ro(w(t),a)},eo=(e,r)=>{let t=e.split(".");if(t.length===1)return `${w(r)}.${w(e)}`;let[a,...o]=t;return ro(`${w(r)}.${w(a)}`,o)},kr=e=>`'${e.replace(/'/g,"''")}'`,ro=(e,r)=>{if(r.length===0)return e;let t=r.slice(0,-1).map(kr).join("->"),a=kr(r[r.length-1]);return t?`${e}->${t}->>${a}`:`${e}->>${a}`},to=e=>{let r=e.split(".");if(r.length===1)return w(e);let[t,...a]=r;return a.length===0?w(t):wl(w(t),a)},wl=(e,r)=>{let t=r.map(kr).join("->");return `${e}->${t}`};var ao=(e,r)=>{if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let t=bl(e,r);return Al(t,e,r)},bl=(e,r)=>{let t=to(e.field),{mode:a,field:o}=e.aggregate,n=a==="sum"?"SUM":"AVG",i=r.map?.[r.currentModel??""]?.fields[e.field];if(i?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(o?.includes("."))throw new Error(`aggregate.field '${o}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(i?.kind==="scalar"&&i?.isList===true){if(o)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${n==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${t}) AS elem)`}if(o){let p=`(elem->>'${o}')::numeric`;return `(SELECT ${n==="SUM"?`COALESCE(SUM(${p}), 0)`:`AVG(${p})`} FROM jsonb_array_elements(${t}) AS elem)`}let f="elem::numeric";return `(SELECT ${n==="SUM"?`COALESCE(SUM(${f}), 0)`:`AVG(${f})`} FROM jsonb_array_elements_text(${t}) AS elem)`},Ol=(e,r)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let t=e.path.substring(2);return {type:"column",sql:r.currentAlias?`${w(r.currentAlias)}.${w(t)}`:_(t)}}if(!r.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:A(r.context,e.path)}}throw new Error("Aggregate rule requires value or path")},Al=(e,r,t)=>{let a=Ol(r,t),o=a.type==="value"?a.value:void 0,n=a.type==="column"?a.sql:void 0;switch(r.operator){case l.equals:return n?`${e} = ${n}`:o===null?`${e} IS NULL`:`${e} = ${h(t,o)}`;case l.notEquals:return n?`${e} <> ${n}`:o===null?`${e} IS NOT NULL`:`${e} <> ${h(t,o)}`;case l.lessThan:return n?`${e} < ${n}`:`${e} < ${h(t,o)}`;case l.lessThanEquals:return n?`${e} <= ${n}`:`${e} <= ${h(t,o)}`;case l.greaterThan:return n?`${e} > ${n}`:`${e} > ${h(t,o)}`;case l.greaterThanEquals:return n?`${e} >= ${n}`:`${e} >= ${h(t,o)}`;case l.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between requires two values");let[s,f]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} BETWEEN ${h(t,s)} AND ${h(t,f)}`}case l.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween requires two values");let[s,f]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} NOT BETWEEN ${h(t,s)} AND ${h(t,f)}`}default:throw new Error(`Operator '${r.operator}' is not supported for aggregate rules`)}};var oo=(e,r)=>{if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let t=_(e.field),a=r.map?.[r.currentModel??""]?.fields[e.field],o=a?.kind==="scalar"&&a?.isList===true,n=o?`array_length(${t}, 1)`:`jsonb_array_length(${t})`;switch(e.arrayOperator){case m.empty:return o?`(${t} IS NULL OR ${n} IS NULL)`:`(${t} IS NULL OR ${n} = 0)`;case m.notEmpty:return o?`(${t} IS NOT NULL AND ${n} IS NOT NULL)`:`(${t} IS NOT NULL AND ${n} > 0)`;case m.all:case m.any:case m.none:case m.atLeast:case m.atMost:case m.exactly:throw new Error(`Array operator '${e.arrayOperator}' with conditions is not supported in SQL. Use application-level filtering for complex array operations.`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Mr=e=>{let r={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};return e.map(t=>{let a=r[t.toLowerCase()];if(a===void 0)throw new Error(`Unknown day name: ${t}`);return a})};var lr=(e,r)=>{if(!r.map||!r.currentModel||!r.currentAlias)return _(e);let t=e.split("."),a=r.currentModel,o=r.currentAlias;for(let n=0;n<t.length;n++){let i=r.map[a];if(!i)return _(e);let s=i.fields[t[n]];if(!s)return _(e);if(s.kind==="object"){let u=`${o}.${t[n]}`,p=r.joinRegistry?.get(u),c;if(p)c=p;else {let d=r.joinCounter;if(!d)return _(e);c=`t${++d.n}`;let b=$l(r.map,a,o,s,c);if(!b)return _(e);r.joins?.push(b),r.joinRegistry?.set(u,c);}a=s.type,o=c;continue}let f=t.slice(n);return eo(f.join("."),o)}return _(e)},$l=(e,r,t,a,o)=>{let n=a.type,i=e[n]?.dbName??n,s;if(a.fromFields&&a.fromFields.length>0&&a.toFields&&a.toFields.length>0)s=a.fromFields.map((f,u)=>`${w(o)}.${w(a.toFields?.[u]??"")} = ${w(t)}.${w(f)}`).join(" AND ");else {let f=vl(e,n,r,a.relationName);if(!f)return null;s=(f.fromFields??[]).map((u,p)=>`${w(o)}.${w(u)} = ${w(t)}.${w(f.toFields?.[p]??"")}`).join(" AND ");}return `LEFT JOIN ${w(i)} AS ${w(o)} ON ${s}`},vl=(e,r,t,a)=>{let o=e[r];if(!o)return null;for(let n of Object.values(o.fields))if(n.kind==="object"&&n.type===t&&(n.fromFields?.length??0)>0&&(n.toFields?.length??0)>0&&(a===void 0||n.relationName===a))return n;return null};var so=(e,r)=>{let t=lr(e.field,r),a=Sl(e,r),o=a.type==="value"?a.value:void 0,n=a.type==="column"?a.sql:void 0;switch(e.dateOperator){case y.before:return n!==void 0?`${t} < ${n}`:`${t} < ${h(r,o)}`;case y.after:return n!==void 0?`${t} > ${n}`:`${t} > ${h(r,o)}`;case y.onOrBefore:return n!==void 0?`${t} <= ${n}`:`${t} <= ${h(r,o)}`;case y.onOrAfter:return n!==void 0?`${t} >= ${n}`:`${t} >= ${h(r,o)}`;case y.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between date operator requires an array of two values");let[s,f]=no(i);return `${t} BETWEEN ${h(r,s)} AND ${h(r,f)}`}case y.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween date operator requires an array of two values");let[s,f]=no(i);return `${t} NOT BETWEEN ${h(r,s)} AND ${h(r,f)}`}case y.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=Mr(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${t}) = ANY(${h(r,i)})`}case y.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let i=Mr(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${t}) <> ALL(${h(r,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},no=e=>{let[r,t]=e;return El(r,t)<=0?[r,t]:[t,r]},El=(e,r)=>{let t=io(e),a=io(r);return t<a?-1:t>a?1:0},io=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),Sl=(e,r)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let t=e.path.substring(2);return {type:"column",sql:r.currentAlias?`${w(r.currentAlias)}.${w(t)}`:_(t)}}if(!r.context)throw new Error(`BuilderState.context is required to resolve date path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:A(r.context,e.path)}}return {type:"value",value:void 0}};var fo=(e,r)=>{let t=lr(e.field,r),a=Rl(e,r),o=a.type==="value"?a.value:void 0,n=a.type==="column"?a.sql:void 0;switch(e.operator){case l.equals:return n!==void 0?`${t} = ${n}`:o===null?`${t} IS NULL`:`${t} = ${h(r,o)}`;case l.notEquals:return n!==void 0?`${t} <> ${n}`:o===null?`${t} IS NOT NULL`:`${t} <> ${h(r,o)}`;case l.lessThan:return n!==void 0?`${t} < ${n}`:`${t} < ${h(r,o)}`;case l.lessThanEquals:return n!==void 0?`${t} <= ${n}`:`${t} <= ${h(r,o)}`;case l.greaterThan:return n!==void 0?`${t} > ${n}`:`${t} > ${h(r,o)}`;case l.greaterThanEquals:return n!==void 0?`${t} >= ${n}`:`${t} >= ${h(r,o)}`;case l.in:return !Array.isArray(o)||o.length===0?"FALSE":`${t} = ANY(${h(r,o)})`;case l.notIn:return !Array.isArray(o)||o.length===0?"TRUE":`${t} <> ALL(${h(r,o)})`;case l.contains:return `${t} LIKE ${h(r,`%${Be(String(o))}%`)}`;case l.notContains:return `${t} NOT LIKE ${h(r,`%${Be(String(o))}%`)}`;case l.startsWith:return `${t} LIKE ${h(r,`${Be(String(o))}%`)}`;case l.endsWith:return `${t} LIKE ${h(r,`%${Be(String(o))}`)}`;case l.matches:return `${t} ~ ${h(r,o)}`;case l.notMatches:return `${t} !~ ${h(r,o)}`;case l.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between operator requires an array of two values");let[s,f]=i[0]<=i[1]?i:[i[1],i[0]];return `${t} BETWEEN ${h(r,s)} AND ${h(r,f)}`}case l.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween operator requires an array of two values");let[s,f]=i[0]<=i[1]?i:[i[1],i[0]];return `${t} NOT BETWEEN ${h(r,s)} AND ${h(r,f)}`}case l.isEmpty:return `(${t} IS NULL OR ${t} = '')`;case l.notEmpty:return `(${t} IS NOT NULL AND ${t} <> '')`;case l.exists:return `${t} IS NOT NULL`;case l.notExists:return `${t} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},Rl=(e,r)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let t=e.path.substring(2);return {type:"column",sql:r.currentAlias?`${w(r.currentAlias)}.${w(t)}`:_(t)}}if(!r.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:A(r.context,e.path)}}return {type:"value",value:void 0}};var Te,lo=e=>{Te=e;},Tl=(e,r,t)=>{let a=e.split("."),o=t;for(let n=0;n<a.length;n++){let i=r[o];if(!i)return false;let s=i.fields[a[n]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},_l=(e,r,t)=>{let a=e.split("."),o=t;for(let n of a){let i=r[o]?.fields[n];if(!i||i.kind!=="object")return null;o=i.type;}return o},V=(e,r)=>{if(typeof e=="boolean"||!r.map||!r.currentModel)return false;if("all"in e)return e.all.some(t=>V(t,r));if("any"in e)return e.any.some(t=>V(t,r));if("if"in e)return V(e.if,r)||V(e.then,r)||e.else!==void 0&&V(e.else,r);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(Tl(e.field,r.map,r.currentModel))return true;if("condition"in e&&e.condition!==void 0){let t=_l(e.field,r.map,r.currentModel);if(t&&V(e.condition,{...r,currentModel:t}))return true}}return false},uo=(e,r)=>e.all.length===0?"TRUE":`(${e.all.map(a=>Te(a,r)).join(" AND ")})`,po=(e,r)=>e.any.length===0?"FALSE":`(${e.any.map(a=>Te(a,r)).join(" OR ")})`,mo=(e,r)=>{if(V(e.if,r)||V(e.then,r)||e.else!==void 0&&V(e.else,r))return "TRUE";let t=Te(e.if,r),a=Te(e.then,r);if(e.else!==void 0){let o=Te(e.else,r);return `((NOT(${t}) OR ${a}) AND (${t} OR ${o}))`}return `(NOT(${t}) OR ${a})`};var kl=(e,r,t)=>{let a=e.split("."),o=t;for(let n=0;n<a.length;n++){let i=r[o];if(!i)return false;let s=i.fields[a[n]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},Fr=(e,r)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&r.map&&r.currentModel&&kl(e.field,r.map,r.currentModel))return "TRUE";if("all"in e)return uo(e,r);if("any"in e)return po(e,r);if("if"in e)return mo(e,r);if("arrayOperator"in e)return oo(e,r);if("dateOperator"in e)return so(e,r);if("aggregate"in e)return ao(e,r);if("field"in e)return fo(e,r);throw new Error("Unknown condition type")};lo(Fr);var jx=(e,r)=>{let t=!!(r?.map&&r?.model),a=r?.alias??(t?"t0":void 0),o={params:[],paramIndex:0,context:r?.context,map:r?.map,currentModel:r?.model,currentAlias:a,joinCounter:t?{n:0}:void 0,joins:t?[]:void 0,joinRegistry:t?new Map:void 0};return {sql:Fr(e,o),params:o.params,joins:o.joins??[]}};var Ml=new Set(Object.keys(q)),Fl=new Set(Object.keys(X)),Cl=new Set(Object.keys(Y)),Pl=(e,r={})=>{let t={target:r.target??"check",errors:[]};return Z(e,"$",t),{ok:t.errors.length===0,errors:t.errors}},Gx=(e,r={})=>{let t=Pl(e,r);if(t.ok)return;let a=t.errors.map(o=>`${o.path}: ${o.message}`).join(`
|
|
1
|
+
'use strict';var W=require('dayjs'),Ql=require('dayjs/plugin/isSameOrAfter.js'),Yl=require('dayjs/plugin/isSameOrBefore.js'),Xl=require('dayjs/plugin/timezone.js'),Zl=require('dayjs/plugin/utc.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var W__default=/*#__PURE__*/_interopDefault(W);var Ql__default=/*#__PURE__*/_interopDefault(Ql);var Yl__default=/*#__PURE__*/_interopDefault(Yl);var Xl__default=/*#__PURE__*/_interopDefault(Xl);var Zl__default=/*#__PURE__*/_interopDefault(Zl);var Fo=typeof global=="object"&&global&&global.Object===Object&&global,Ie=Fo;var _o=typeof self=="object"&&self&&self.Object===Object&&self,Co=Ie||_o||Function("return this")(),T=Co;var Po=T.Symbol,C=Po;var Ut=Object.prototype,Do=Ut.hasOwnProperty,No=Ut.toString,Ce=C?C.toStringTag:void 0;function Bo(e){var t=Do.call(e,Ce),r=e[Ce];try{e[Ce]=void 0;var n=!0;}catch{}var o=No.call(e);return n&&(t?e[Ce]=r:delete e[Ce]),o}var Gt=Bo;var qo=Object.prototype,Lo=qo.toString;function Io(e){return Lo.call(e)}var Kt=Io;var jo="[object Null]",Vo="[object Undefined]",zt=C?C.toStringTag:void 0;function Wo(e){return e==null?e===void 0?Vo:jo:zt&&zt in Object(e)?Gt(e):Kt(e)}var P=Wo;function Uo(e){return e!=null&&typeof e=="object"}var D=Uo;var Go="[object Symbol]";function Ko(e){return typeof e=="symbol"||D(e)&&P(e)==Go}var pe=Ko;function zo(e,t){for(var r=-1,n=e==null?0:e.length,o=Array(n);++r<n;)o[r]=t(e[r],r,e);return o}var Ht=zo;var Ho=Array.isArray,M=Ho;var Jt=C?C.prototype:void 0,Qt=Jt?Jt.toString:void 0;function Yt(e){if(typeof e=="string")return e;if(M(e))return Ht(e,Yt)+"";if(pe(e))return Qt?Qt.call(e):"";var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var Xt=Yt;function Qo(e){var t=typeof e;return e!=null&&(t=="object"||t=="function")}var N=Qo;function Yo(e){return e}var Zt=Yo;var Xo="[object AsyncFunction]",Zo="[object Function]",ea="[object GeneratorFunction]",ta="[object Proxy]";function ra(e){if(!N(e))return false;var t=P(e);return t==Zo||t==ea||t==Xo||t==ta}var je=ra;var na=T["__core-js_shared__"],Ve=na;var er=(function(){var e=/[^.]+$/.exec(Ve&&Ve.keys&&Ve.keys.IE_PROTO||"");return e?"Symbol(src)_1."+e:""})();function oa(e){return !!er&&er in e}var tr=oa;var aa=Function.prototype,ia=aa.toString;function sa(e){if(e!=null){try{return ia.call(e)}catch{}try{return e+""}catch{}}return ""}var j=sa;var la=/[\\^$.*+?()[\]{}|]/g,fa=/^\[object .+?Constructor\]$/,ua=Function.prototype,pa=Object.prototype,da=ua.toString,ma=pa.hasOwnProperty,ca=RegExp("^"+da.call(ma).replace(la,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function ga(e){if(!N(e)||tr(e))return false;var t=je(e)?ca:fa;return t.test(j(e))}var rr=ga;function ya(e,t){return e?.[t]}var nr=ya;function ha(e,t){var r=nr(e,t);return rr(r)?r:void 0}var _=ha;var wa=_(T,"WeakMap"),We=wa;var xa=(function(){try{var e=_(Object,"defineProperty");return e({},"",{}),e}catch{}})(),yt=xa;var ba=9007199254740991,Oa=/^(?:0|[1-9]\d*)$/;function $a(e,t){var r=typeof e;return t=t??ba,!!t&&(r=="number"||r!="symbol"&&Oa.test(e))&&e>-1&&e%1==0&&e<t}var de=$a;function Aa(e,t,r){t=="__proto__"&&yt?yt(e,t,{configurable:true,enumerable:true,value:r,writable:true}):e[t]=r;}var or=Aa;function va(e,t){return e===t||e!==e&&t!==t}var me=va;var Ea=9007199254740991;function Ra(e){return typeof e=="number"&&e>-1&&e%1==0&&e<=Ea}var ce=Ra;function Sa(e){return e!=null&&ce(e.length)&&!je(e)}var z=Sa;function ka(e,t,r){if(!N(r))return false;var n=typeof t;return (n=="number"?z(r)&&de(t,r.length):n=="string"&&t in r)?me(r[t],e):false}var ar=ka;var Ma=Object.prototype;function Ta(e){var t=e&&e.constructor,r=typeof t=="function"&&t.prototype||Ma;return e===r}var Ue=Ta;function Fa(e,t){for(var r=-1,n=Array(e);++r<e;)n[r]=t(r);return n}var ir=Fa;var _a="[object Arguments]";function Ca(e){return D(e)&&P(e)==_a}var ht=Ca;var sr=Object.prototype,Pa=sr.hasOwnProperty,Da=sr.propertyIsEnumerable,Na=ht((function(){return arguments})())?ht:function(e){return D(e)&&Pa.call(e,"callee")&&!Da.call(e,"callee")},ge=Na;function Ba(){return false}var lr=Ba;var pr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,fr=pr&&typeof module=="object"&&module&&!module.nodeType&&module,qa=fr&&fr.exports===pr,ur=qa?T.Buffer:void 0,La=ur?ur.isBuffer:void 0,Ia=La||lr,ae=Ia;var ja="[object Arguments]",Va="[object Array]",Wa="[object Boolean]",Ua="[object Date]",Ga="[object Error]",Ka="[object Function]",za="[object Map]",Ha="[object Number]",Ja="[object Object]",Qa="[object RegExp]",Ya="[object Set]",Xa="[object String]",Za="[object WeakMap]",ei="[object ArrayBuffer]",ti="[object DataView]",ri="[object Float32Array]",ni="[object Float64Array]",oi="[object Int8Array]",ai="[object Int16Array]",ii="[object Int32Array]",si="[object Uint8Array]",li="[object Uint8ClampedArray]",fi="[object Uint16Array]",ui="[object Uint32Array]",S={};S[ri]=S[ni]=S[oi]=S[ai]=S[ii]=S[si]=S[li]=S[fi]=S[ui]=true;S[ja]=S[Va]=S[ei]=S[Wa]=S[ti]=S[Ua]=S[Ga]=S[Ka]=S[za]=S[Ha]=S[Ja]=S[Qa]=S[Ya]=S[Xa]=S[Za]=false;function pi(e){return D(e)&&ce(e.length)&&!!S[P(e)]}var dr=pi;function di(e){return function(t){return e(t)}}var mr=di;var cr=typeof exports=="object"&&exports&&!exports.nodeType&&exports,Pe=cr&&typeof module=="object"&&module&&!module.nodeType&&module,mi=Pe&&Pe.exports===cr,wt=mi&&Ie.process,ci=(function(){try{var e=Pe&&Pe.require&&Pe.require("util").types;return e||wt&&wt.binding&&wt.binding("util")}catch{}})(),xt=ci;var gr=xt&&xt.isTypedArray,gi=gr?mr(gr):dr,ye=gi;var yi=Object.prototype,hi=yi.hasOwnProperty;function wi(e,t){var r=M(e),n=!r&&ge(e),o=!r&&!n&&ae(e),a=!r&&!n&&!o&&ye(e),i=r||n||o||a,s=i?ir(e.length,String):[],l=s.length;for(var u in e)(t||hi.call(e,u))&&!(i&&(u=="length"||o&&(u=="offset"||u=="parent")||a&&(u=="buffer"||u=="byteLength"||u=="byteOffset")||de(u,l)))&&s.push(u);return s}var yr=wi;function xi(e,t){return function(r){return e(t(r))}}var hr=xi;var bi=hr(Object.keys,Object),wr=bi;var Oi=Object.prototype,$i=Oi.hasOwnProperty;function Ai(e){if(!Ue(e))return wr(e);var t=[];for(var r in Object(e))$i.call(e,r)&&r!="constructor"&&t.push(r);return t}var Ge=Ai;function vi(e){return z(e)?yr(e):Ge(e)}var he=vi;var Ei=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Ri=/^\w*$/;function Si(e,t){if(M(e))return false;var r=typeof e;return r=="number"||r=="symbol"||r=="boolean"||e==null||pe(e)?true:Ri.test(e)||!Ei.test(e)||t!=null&&e in Object(t)}var we=Si;var ki=_(Object,"create"),V=ki;function Mi(){this.__data__=V?V(null):{},this.size=0;}var xr=Mi;function Ti(e){var t=this.has(e)&&delete this.__data__[e];return this.size-=t?1:0,t}var br=Ti;var Fi="__lodash_hash_undefined__",_i=Object.prototype,Ci=_i.hasOwnProperty;function Pi(e){var t=this.__data__;if(V){var r=t[e];return r===Fi?void 0:r}return Ci.call(t,e)?t[e]:void 0}var Or=Pi;var Di=Object.prototype,Ni=Di.hasOwnProperty;function Bi(e){var t=this.__data__;return V?t[e]!==void 0:Ni.call(t,e)}var $r=Bi;var qi="__lodash_hash_undefined__";function Li(e,t){var r=this.__data__;return this.size+=this.has(e)?0:1,r[e]=V&&t===void 0?qi:t,this}var Ar=Li;function xe(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}xe.prototype.clear=xr;xe.prototype.delete=br;xe.prototype.get=Or;xe.prototype.has=$r;xe.prototype.set=Ar;var bt=xe;function Ii(){this.__data__=[],this.size=0;}var vr=Ii;function ji(e,t){for(var r=e.length;r--;)if(me(e[r][0],t))return r;return -1}var H=ji;var Vi=Array.prototype,Wi=Vi.splice;function Ui(e){var t=this.__data__,r=H(t,e);if(r<0)return false;var n=t.length-1;return r==n?t.pop():Wi.call(t,r,1),--this.size,true}var Er=Ui;function Gi(e){var t=this.__data__,r=H(t,e);return r<0?void 0:t[r][1]}var Rr=Gi;function Ki(e){return H(this.__data__,e)>-1}var Sr=Ki;function zi(e,t){var r=this.__data__,n=H(r,e);return n<0?(++this.size,r.push([e,t])):r[n][1]=t,this}var kr=zi;function be(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}be.prototype.clear=vr;be.prototype.delete=Er;be.prototype.get=Rr;be.prototype.has=Sr;be.prototype.set=kr;var J=be;var Hi=_(T,"Map"),Q=Hi;function Ji(){this.size=0,this.__data__={hash:new bt,map:new(Q||J),string:new bt};}var Mr=Ji;function Qi(e){var t=typeof e;return t=="string"||t=="number"||t=="symbol"||t=="boolean"?e!=="__proto__":e===null}var Tr=Qi;function Yi(e,t){var r=e.__data__;return Tr(t)?r[typeof t=="string"?"string":"hash"]:r.map}var Y=Yi;function Xi(e){var t=Y(this,e).delete(e);return this.size-=t?1:0,t}var Fr=Xi;function Zi(e){return Y(this,e).get(e)}var _r=Zi;function es(e){return Y(this,e).has(e)}var Cr=es;function ts(e,t){var r=Y(this,e),n=r.size;return r.set(e,t),this.size+=r.size==n?0:1,this}var Pr=ts;function Oe(e){var t=-1,r=e==null?0:e.length;for(this.clear();++t<r;){var n=e[t];this.set(n[0],n[1]);}}Oe.prototype.clear=Mr;Oe.prototype.delete=Fr;Oe.prototype.get=_r;Oe.prototype.has=Cr;Oe.prototype.set=Pr;var ie=Oe;var rs="Expected a function";function Ot(e,t){if(typeof e!="function"||t!=null&&typeof t!="function")throw new TypeError(rs);var r=function(){var n=arguments,o=t?t.apply(this,n):n[0],a=r.cache;if(a.has(o))return a.get(o);var i=e.apply(this,n);return r.cache=a.set(o,i)||a,i};return r.cache=new(Ot.Cache||ie),r}Ot.Cache=ie;var Dr=Ot;var ns=500;function os(e){var t=Dr(e,function(n){return r.size===ns&&r.clear(),n}),r=t.cache;return t}var Nr=os;var as=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,is=/\\(\\)?/g,ss=Nr(function(e){var t=[];return e.charCodeAt(0)===46&&t.push(""),e.replace(as,function(r,n,o,a){t.push(o?a.replace(is,"$1"):n||r);}),t}),Br=ss;function ls(e){return e==null?"":Xt(e)}var qr=ls;function fs(e,t){return M(e)?e:we(e,t)?[e]:Br(qr(e))}var Ke=fs;function ps(e){if(typeof e=="string"||pe(e))return e;var t=e+"";return t=="0"&&1/e==-Infinity?"-0":t}var X=ps;function ds(e,t){t=Ke(t,e);for(var r=0,n=t.length;e!=null&&r<n;)e=e[X(t[r++])];return r&&r==n?e:void 0}var ze=ds;function ms(e,t,r){var n=e==null?void 0:ze(e,t);return n===void 0?r:n}var E=ms;function cs(e,t){for(var r=-1,n=t.length,o=e.length;++r<n;)e[o+r]=t[r];return e}var Lr=cs;function gs(){this.__data__=new J,this.size=0;}var Ir=gs;function ys(e){var t=this.__data__,r=t.delete(e);return this.size=t.size,r}var jr=ys;function hs(e){return this.__data__.get(e)}var Vr=hs;function ws(e){return this.__data__.has(e)}var Wr=ws;var xs=200;function bs(e,t){var r=this.__data__;if(r instanceof J){var n=r.__data__;if(!Q||n.length<xs-1)return n.push([e,t]),this.size=++r.size,this;r=this.__data__=new ie(n);}return r.set(e,t),this.size=r.size,this}var Ur=bs;function $e(e){var t=this.__data__=new J(e);this.size=t.size;}$e.prototype.clear=Ir;$e.prototype.delete=jr;$e.prototype.get=Vr;$e.prototype.has=Wr;$e.prototype.set=Ur;var Ae=$e;function Os(e,t){for(var r=-1,n=e==null?0:e.length,o=0,a=[];++r<n;){var i=e[r];t(i,r,e)&&(a[o++]=i);}return a}var Gr=Os;function $s(){return []}var Kr=$s;var As=Object.prototype,vs=As.propertyIsEnumerable,zr=Object.getOwnPropertySymbols,Es=zr?function(e){return e==null?[]:(e=Object(e),Gr(zr(e),function(t){return vs.call(e,t)}))}:Kr,Hr=Es;function Rs(e,t,r){var n=t(e);return M(e)?n:Lr(n,r(e))}var Jr=Rs;function Ss(e){return Jr(e,he,Hr)}var $t=Ss;var ks=_(T,"DataView"),He=ks;var Ms=_(T,"Promise"),Je=Ms;var Ts=_(T,"Set"),Qe=Ts;var Qr="[object Map]",Fs="[object Object]",Yr="[object Promise]",Xr="[object Set]",Zr="[object WeakMap]",en="[object DataView]",_s=j(He),Cs=j(Q),Ps=j(Je),Ds=j(Qe),Ns=j(We),se=P;(He&&se(new He(new ArrayBuffer(1)))!=en||Q&&se(new Q)!=Qr||Je&&se(Je.resolve())!=Yr||Qe&&se(new Qe)!=Xr||We&&se(new We)!=Zr)&&(se=function(e){var t=P(e),r=t==Fs?e.constructor:void 0,n=r?j(r):"";if(n)switch(n){case _s:return en;case Cs:return Qr;case Ps:return Yr;case Ds:return Xr;case Ns:return Zr}return t});var De=se;var Bs=T.Uint8Array,At=Bs;var qs="__lodash_hash_undefined__";function Ls(e){return this.__data__.set(e,qs),this}var tn=Ls;function Is(e){return this.__data__.has(e)}var rn=Is;function Ye(e){var t=-1,r=e==null?0:e.length;for(this.__data__=new ie;++t<r;)this.add(e[t]);}Ye.prototype.add=Ye.prototype.push=tn;Ye.prototype.has=rn;var nn=Ye;function js(e,t){for(var r=-1,n=e==null?0:e.length;++r<n;)if(t(e[r],r,e))return true;return false}var Xe=js;function Vs(e,t){return e.has(t)}var on=Vs;var Ws=1,Us=2;function Gs(e,t,r,n,o,a){var i=r&Ws,s=e.length,l=t.length;if(s!=l&&!(i&&l>s))return false;var u=a.get(e),p=a.get(t);if(u&&p)return u==t&&p==e;var m=-1,d=true,c=r&Us?new nn:void 0;for(a.set(e,t),a.set(t,e);++m<s;){var y=e[m],g=t[m];if(n)var w=i?n(g,y,m,t,e,a):n(y,g,m,e,t,a);if(w!==void 0){if(w)continue;d=false;break}if(c){if(!Xe(t,function(b,k){if(!on(c,k)&&(y===b||o(y,b,r,n,a)))return c.push(k)})){d=false;break}}else if(!(y===g||o(y,g,r,n,a))){d=false;break}}return a.delete(e),a.delete(t),d}var Ze=Gs;function Ks(e){var t=-1,r=Array(e.size);return e.forEach(function(n,o){r[++t]=[o,n];}),r}var an=Ks;function zs(e){var t=-1,r=Array(e.size);return e.forEach(function(n){r[++t]=n;}),r}var sn=zs;var Hs=1,Js=2,Qs="[object Boolean]",Ys="[object Date]",Xs="[object Error]",Zs="[object Map]",el="[object Number]",tl="[object RegExp]",rl="[object Set]",nl="[object String]",ol="[object Symbol]",al="[object ArrayBuffer]",il="[object DataView]",ln=C?C.prototype:void 0,vt=ln?ln.valueOf:void 0;function sl(e,t,r,n,o,a,i){switch(r){case il:if(e.byteLength!=t.byteLength||e.byteOffset!=t.byteOffset)return false;e=e.buffer,t=t.buffer;case al:return !(e.byteLength!=t.byteLength||!a(new At(e),new At(t)));case Qs:case Ys:case el:return me(+e,+t);case Xs:return e.name==t.name&&e.message==t.message;case tl:case nl:return e==t+"";case Zs:var s=an;case rl:var l=n&Hs;if(s||(s=sn),e.size!=t.size&&!l)return false;var u=i.get(e);if(u)return u==t;n|=Js,i.set(e,t);var p=Ze(s(e),s(t),n,o,a,i);return i.delete(e),p;case ol:if(vt)return vt.call(e)==vt.call(t)}return false}var fn=sl;var ll=1,fl=Object.prototype,ul=fl.hasOwnProperty;function pl(e,t,r,n,o,a){var i=r&ll,s=$t(e),l=s.length,u=$t(t),p=u.length;if(l!=p&&!i)return false;for(var m=l;m--;){var d=s[m];if(!(i?d in t:ul.call(t,d)))return false}var c=a.get(e),y=a.get(t);if(c&&y)return c==t&&y==e;var g=true;a.set(e,t),a.set(t,e);for(var w=i;++m<l;){d=s[m];var b=e[d],k=t[d];if(n)var v=i?n(k,b,d,t,e,a):n(b,k,d,e,t,a);if(!(v===void 0?b===k||o(b,k,r,n,a):v)){g=false;break}w||(w=d=="constructor");}if(g&&!w){var L=e.constructor,I=t.constructor;L!=I&&"constructor"in e&&"constructor"in t&&!(typeof L=="function"&&L instanceof L&&typeof I=="function"&&I instanceof I)&&(g=false);}return a.delete(e),a.delete(t),g}var un=pl;var dl=1,pn="[object Arguments]",dn="[object Array]",et="[object Object]",ml=Object.prototype,mn=ml.hasOwnProperty;function cl(e,t,r,n,o,a){var i=M(e),s=M(t),l=i?dn:De(e),u=s?dn:De(t);l=l==pn?et:l,u=u==pn?et:u;var p=l==et,m=u==et,d=l==u;if(d&&ae(e)){if(!ae(t))return false;i=true,p=false;}if(d&&!p)return a||(a=new Ae),i||ye(e)?Ze(e,t,r,n,o,a):fn(e,t,l,r,n,o,a);if(!(r&dl)){var c=p&&mn.call(e,"__wrapped__"),y=m&&mn.call(t,"__wrapped__");if(c||y){var g=c?e.value():e,w=y?t.value():t;return a||(a=new Ae),o(g,w,r,n,a)}}return d?(a||(a=new Ae),un(e,t,r,n,o,a)):false}var cn=cl;function gn(e,t,r,n,o){return e===t?true:e==null||t==null||!D(e)&&!D(t)?e!==e&&t!==t:cn(e,t,r,n,gn,o)}var tt=gn;var gl=1,yl=2;function hl(e,t,r,n){var o=r.length,a=o,i=!n;if(e==null)return !a;for(e=Object(e);o--;){var s=r[o];if(i&&s[2]?s[1]!==e[s[0]]:!(s[0]in e))return false}for(;++o<a;){s=r[o];var l=s[0],u=e[l],p=s[1];if(i&&s[2]){if(u===void 0&&!(l in e))return false}else {var m=new Ae;if(n)var d=n(u,p,l,e,t,m);if(!(d===void 0?tt(p,u,gl|yl,n,m):d))return false}}return true}var yn=hl;function wl(e){return e===e&&!N(e)}var rt=wl;function xl(e){for(var t=he(e),r=t.length;r--;){var n=t[r],o=e[n];t[r]=[n,o,rt(o)];}return t}var hn=xl;function bl(e,t){return function(r){return r==null?false:r[e]===t&&(t!==void 0||e in Object(r))}}var nt=bl;function Ol(e){var t=hn(e);return t.length==1&&t[0][2]?nt(t[0][0],t[0][1]):function(r){return r===e||yn(r,e,t)}}var wn=Ol;function $l(e,t){return e!=null&&t in Object(e)}var xn=$l;function Al(e,t,r){t=Ke(t,e);for(var n=-1,o=t.length,a=false;++n<o;){var i=X(t[n]);if(!(a=e!=null&&r(e,i)))break;e=e[i];}return a||++n!=o?a:(o=e==null?0:e.length,!!o&&ce(o)&&de(i,o)&&(M(e)||ge(e)))}var bn=Al;function vl(e,t){return e!=null&&bn(e,t,xn)}var On=vl;var El=1,Rl=2;function Sl(e,t){return we(e)&&rt(t)?nt(X(e),t):function(r){var n=E(r,e);return n===void 0&&n===t?On(r,e):tt(t,n,El|Rl)}}var $n=Sl;function kl(e){return function(t){return t?.[e]}}var An=kl;function Ml(e){return function(t){return ze(t,e)}}var vn=Ml;function Tl(e){return we(e)?An(X(e)):vn(e)}var En=Tl;function Fl(e){return typeof e=="function"?e:e==null?Zt:typeof e=="object"?M(e)?$n(e[0],e[1]):wn(e):En(e)}var ot=Fl;function _l(e,t,r,n){for(var o=-1,a=e==null?0:e.length;++o<a;){var i=e[o];t(n,i,r(i),e);}return n}var Rn=_l;function Cl(e){return function(t,r,n){for(var o=-1,a=Object(t),i=n(t),s=i.length;s--;){var l=i[e?s:++o];if(r(a[l],l,a)===false)break}return t}}var Sn=Cl;var Pl=Sn(),kn=Pl;function Dl(e,t){return e&&kn(e,t,he)}var Mn=Dl;function Nl(e,t){return function(r,n){if(r==null)return r;if(!z(r))return e(r,n);for(var o=r.length,a=t?o:-1,i=Object(r);(t?a--:++a<o)&&n(i[a],a,i)!==false;);return r}}var Tn=Nl;var Bl=Tn(Mn),at=Bl;function ql(e,t,r,n){return at(e,function(o,a,i){t(n,o,r(o),i);}),n}var Fn=ql;function Ll(e,t){return function(r,n){var o=M(r)?Rn:Fn,a=t?t():{};return o(r,e,ot(n),a)}}var _n=Ll;var Il=Object.prototype,jl=Il.hasOwnProperty,Vl=_n(function(e,t,r){jl.call(e,r)?e[r].push(t):or(e,r,[t]);}),Et=Vl;var Wl="[object Map]",Ul="[object Set]",Gl=Object.prototype,Kl=Gl.hasOwnProperty;function zl(e){if(e==null)return true;if(z(e)&&(M(e)||typeof e=="string"||typeof e.splice=="function"||ae(e)||ye(e)||ge(e)))return !e.length;var t=De(e);if(t==Wl||t==Ul)return !e.size;if(Ue(e))return !Ge(e).length;for(var r in e)if(Kl.call(e,r))return false;return true}var it=zl;function Hl(e,t){var r;return at(e,function(n,o,a){return r=t(n,o,a),!r}),!!r}var Cn=Hl;function Jl(e,t,r){var n=M(e)?Xe:Cn;return r&&ar(e,t,r)&&(t=void 0),n(e,ot(t))}var Rt=Jl;var f={equals:"equals",notEquals:"notEquals",lessThan:"lessThan",lessThanEquals:"lessThanEquals",greaterThan:"greaterThan",greaterThanEquals:"greaterThanEquals",contains:"contains",notContains:"notContains",in:"in",notIn:"notIn",matches:"matches",notMatches:"notMatches",between:"between",notBetween:"notBetween",isEmpty:"isEmpty",notEmpty:"notEmpty",exists:"exists",notExists:"notExists",startsWith:"startsWith",endsWith:"endsWith"},h={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},x={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};W__default.default.extend(Zl__default.default);W__default.default.extend(Xl__default.default);W__default.default.extend(Yl__default.default);W__default.default.extend(Ql__default.default);var Pn=(e,t,r)=>{let n=E(t,e.field);if(!n)throw new Error(`${e.field} is null or undefined`);if(!kt(n))throw new Error(`${e.field} is not a valid date: ${String(n)}`);let o=W__default.default(n);if(!o.isValid())throw new Error(`${e.field} is not a valid date: ${n}`);let a=u=>e.error||`${e.field} ${u}`,i=ef(e,t,r,o,n),s=i[0],l=i[1];switch(e.dateOperator){case x.before:return o.isBefore(s)||a(`must be before ${s.format()}`);case x.after:return o.isAfter(s)||a(`must be after ${s.format()}`);case x.onOrBefore:return o.isSameOrBefore(s)||a(`must be on or before ${s.format()}`);case x.onOrAfter:return o.isSameOrAfter(s)||a(`must be on or after ${s.format()}`);case x.between:{if(!l)throw new Error("between operator requires an end date");return o.isSameOrAfter(s)&&o.isSameOrBefore(l)||a(`must be between ${s.format()} and ${l?.format()}`)}case x.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return o.isBefore(s)||o.isAfter(l)||a(`must not be between ${s.format()} and ${l?.format()}`)}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let u=o.format("dddd").toLowerCase(),p=e.value.map(m=>String(m).toLowerCase());return p.includes(u)||a(`must be on ${p.join(" or ")}`)}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let u=o.format("dddd").toLowerCase(),p=e.value.map(m=>String(m).toLowerCase());return !p.includes(u)||a(`must not be on ${p.join(" or ")}`)}default:throw new Error("Unknown date operator")}},ef=(e,t,r,n,o)=>{if([x.between,x.notBetween].includes(e.dateOperator)){if(!Array.isArray(e.value)||e.value.length!==2)throw new Error(`${e.dateOperator} operator requires an array of two dates`);let[s,l]=e.value,u=St(s,o),p=St(l,o);if(!u.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!p.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[m,d]=u.isBefore(p)||u.isSame(p)?[u,p]:[p,u];return [m,d]}if([x.before,x.after,x.onOrBefore,x.onOrAfter].includes(e.dateOperator)){let s;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);s=e.value;}else if(e.path)if(e.path.startsWith("$.")){let u=E(t,e.path.substring(2));s=kt(u)?u:void 0;}else {let u=E(r,e.path);s=kt(u)?u:void 0;}else throw new Error("No value or path specified for date comparison");let l=St(s,o);if(!l.isValid())throw new Error(`Invalid comparison date: ${s}`);return [l,void 0]}return [W__default.default(),void 0]},St=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return W__default.default(e);let o=String(t),a=0;if(o.includes("+")||o.includes("T")&&o.match(/T.*-\d{2}:/)){let s=o.match(/([+-])(\d{2}):(\d{2})/);s&&(a=(s[1]==="+"?1:-1)*(parseInt(s[2],10)*60+parseInt(s[3],10)));}else o.includes("Z")||(a=0);return r.match(/^\d{4}-\d{2}-\d{2}$/)?W__default.default(`${e}T00:00:00`).subtract(a,"minute"):W__default.default(e).subtract(a,"minute")},kt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var qn=(e,t,r)=>{let n=E(t,e.field),a=![f.isEmpty,f.notEmpty,f.exists,f.notExists].includes(e.operator),i=a?tf(e,t,r):void 0,s=l=>e.error||`${e.field} ${l}${a?` ${JSON.stringify(i)}`:""}`;switch(e.operator){case f.equals:return n===i||s("must equal");case f.notEquals:return n!==i||s("must not equal");case f.lessThan:return st(n,i,"lt")||s("must be less than");case f.lessThanEquals:return st(n,i,"lte")||s("must be less than or equal to");case f.greaterThan:return st(n,i,"gt")||s("must be greater than");case f.greaterThanEquals:return st(n,i,"gte")||s("must be greater than or equal to");case f.in:return Array.isArray(i)&&i.includes(n)||s("must be one of");case f.notIn:return !Array.isArray(i)||!i.includes(n)||s("must not be one of");case f.contains:return Bn(n,i)||s("must contain");case f.notContains:return !Bn(n,i)||s("must not contain");case f.matches:return Dn(n)&&(i instanceof RegExp||typeof i=="string")&&!!n.match(i)||s("must match pattern");case f.notMatches:return !Dn(n)||!(i instanceof RegExp||typeof i=="string")||!n.match(i)||s("must not match pattern");case f.between:{let l=Nn(i);if(!l)throw new Error("between operator requires an array of two values");if(!ve(n))return s("must be between");let u=Ee(n),[p,m]=l;return u>=p&&u<=m||s("must be between")}case f.notBetween:{let l=Nn(i);if(!l)throw new Error("notBetween operator requires an array of two values");if(!ve(n))return true;let u=Ee(n),[p,m]=l;return u<p||u>m||s("must not be between")}case f.isEmpty:return it(n)||s("must be empty");case f.notEmpty:return !it(n)||s("must not be empty");case f.exists:return n!==void 0||s("must exist");case f.notExists:return n===void 0||s("must not exist");case f.startsWith:return typeof n=="string"&&typeof i=="string"&&n.startsWith(i)||s("must start with");case f.endsWith:return typeof n=="string"&&typeof i=="string"&&n.endsWith(i)||s("must end with");default:throw new Error("Unknown operator")}},tf=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?E(t,e.path.substring(2)):E(r,e.path);throw new Error("No value or path specified")},ve=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Ee=e=>e instanceof Date?e.getTime():e,st=(e,t,r)=>{if(!ve(e)||!ve(t))return false;let n=Ee(e),o=Ee(t);switch(r){case "lt":return n<o;case "lte":return n<=o;case "gt":return n>o;case "gte":return n>=o}},Dn=e=>typeof e=="string",Nn=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!ve(t)||!ve(r))return null;let n=Ee(t),o=Ee(r);return n<=o?[n,o]:[o,n]},Bn=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var Mt=e=>{if(typeof e!="boolean"){if("all"in e){for(let t of e.all)Mt(t);return}if("any"in e){for(let t of e.any)Mt(t);return}if(!("arrayOperator"in e&&!("field"in e)))throw new Error("check: when data is an array, every leaf must be a fieldless arrayOperator (composable with all/any)")}},le=(e,t,r)=>{if(Array.isArray(t)&&Mt(e),typeof e=="boolean")return e;let n={...r,context:r?.context??t};return "all"in e?rf(e.all,t,n,e.error):"any"in e?nf(e.any,t,n,e.error):"arrayOperator"in e?sf(e,t,n):"dateOperator"in e?Pn(e,t,n.context):"aggregate"in e?af(e,t,n):"field"in e?qn(e,t,n.context):"if"in e?of(e,t,n):false},rf=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(a,t,r);i!==true&&(typeof i=="string"?o.push(i):o.push("false"));}return o.length?n||(o.length===1?o[0]:`All conditions must pass: ${o.join(" AND ")}`):true},nf=(e,t,r,n)=>{let o=[];for(let a of e){let i=le(a,t,r);if(i===true)return true;typeof i=="string"&&o.push(i);}return n||(o.length===1?o[0]:`At least one condition must pass: ${o.join(" OR ")}`)},of=(e,t,r)=>le(e.if,t,r)===true?le(e.then,t,r):e.else!==void 0?le(e.else,t,r):true,af=(e,t,r)=>{let n=E(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let{mode:o,field:a}=e.aggregate;if(o!=="sum"&&o!=="avg")return e.error||`${e.field} aggregate.mode must be 'sum' or 'avg'`;let i=e.condition,l=(i?n.filter(y=>le(i,y,r)===true):n).map((y,g)=>{let w=a?E(y,a):y;if(typeof w!="number"||!Number.isFinite(w)){let b=`${e.field}[${g}]${a?`.${a}`:""}`;throw new Error(`${b} must be a finite number`)}return w}),u=l.reduce((y,g)=>y+g,0),p=o==="sum"?u:l.length===0?0:u/l.length,m=r.context,d;if(e.value!==void 0)d=e.value;else if(e.path)d=e.path.startsWith("$.")?E(t,e.path.substring(2)):E(m,e.path);else throw new Error("Aggregate rule requires value or path");let c=y=>e.error||`${e.field} ${o} ${y} ${JSON.stringify(d)}`;switch(e.operator){case f.equals:return p===d||c("must equal");case f.notEquals:return p!==d||c("must not equal");case f.lessThan:return typeof d=="number"&&p<d||c("must be less than");case f.lessThanEquals:return typeof d=="number"&&p<=d||c("must be less than or equal to");case f.greaterThan:return typeof d=="number"&&p>d||c("must be greater than");case f.greaterThanEquals:return typeof d=="number"&&p>=d||c("must be greater than or equal to");case f.between:{if(!Array.isArray(d)||d.length!==2)throw new Error("between requires a two-element array");let[y,g]=d,[w,b]=y<=g?[y,g]:[g,y];return p>=w&&p<=b||c("must be between")}case f.notBetween:{if(!Array.isArray(d)||d.length!==2)throw new Error("notBetween requires a two-element array");let[y,g]=d,[w,b]=y<=g?[y,g]:[g,y];return p<w||p>b||c("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},sf=(e,t,r)=>{let n=e.field?E(t,e.field):t;if(!Array.isArray(n))throw new Error(`${e.field||"(root)"} must be an array`);let o=m=>e.error||`${e.field} ${m}`,a=[h.all,h.any,h.none,h.atLeast,h.atMost,h.exactly],i=[h.atLeast,h.atMost,h.exactly],s=e.condition;if(a.includes(e.arrayOperator)&&!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(i.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let u=0,p=0;if(a.includes(e.arrayOperator)){if(!s)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!Rt(n,N))return o("contains only primitive values; use 'in' or 'contains' instead of array operators on primitive arrays");let m=n.map(d=>le(s,d,r));u=m.filter(d=>d===true).length,p=m.filter(d=>typeof d=="string").length;}switch(e.arrayOperator){case h.empty:return !n.length||o("must be empty");case h.notEmpty:return !!n.length||o("must not be empty");case h.all:return u===n.length||o(`all elements must match (${p} failed)`);case h.any:return !!u||o("at least one element must match");case h.none:return !u||o(`no elements should match (${u} matched)`);case h.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u>=l||o(`at least ${l} elements must match (${u} matched)`);case h.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u<=l||o(`at most ${l} elements must match (${u} matched)`);case h.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return u===l||o(`exactly ${l} elements must match (${u} matched)`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var Ln=(e,t,r,n)=>{let o={};for(let a of e){let i=a[t];if(i==null)continue;let s=String(i);if(o[s]!==void 0){let l=n==="one"?`endpoint[0] must be the "one" side of a oneToMany bridge \u2014 swap endpoints if '${r}' is the "many" side`:`oneToOne bridges require unique '${t}' on both endpoints`;throw new Error(`buildBridgeDictionary: duplicate '${t}' value '${s}' on '${r}' \u2014 ${l}.`)}o[s]=a;}return o},lf=(e,t)=>{let r={};for(let n of e.bridges??[]){let[o,a]=n.endpoints,i=`${o.fieldMap}:${o.model}`,s=`${a.fieldMap}:${a.model}`,l=n.cardinality==="oneToMany"?"one":"oneToOne";if(t[i]&&(r[o.fieldMap]??={},r[o.fieldMap][o.model]??={},r[o.fieldMap][o.model][o.on]=Ln(t[i],o.on,i,l)),t[s])if(r[a.fieldMap]??={},r[a.fieldMap][a.model]??={},n.cardinality==="oneToMany"){let u=t[s].filter(p=>p[a.on]!==null&&p[a.on]!==void 0);r[a.fieldMap][a.model][a.on]=Et(u,a.on);}else r[a.fieldMap][a.model][a.on]=Ln(t[s],a.on,s,"oneToOne");}return r};var Tt=e=>{let t={maps:structuredClone(e.maps),bridges:e.bridges?structuredClone(e.bridges):void 0};for(let r of e.bridges??[]){let[n,o]=r.endpoints,a=t.maps[n.fieldMap]?.models[n.model],i=t.maps[o.fieldMap]?.models[o.model];if(!a)throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' not found`);if(!i)throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' not found`);if(n.fieldMap===o.fieldMap&&n.model===o.model)throw new Error(`stitchFieldMaps: self-bridge '${n.fieldMap}:${n.model}' to itself is not supported`);if(!a.fields[n.on])throw new Error(`stitchFieldMaps: endpoint '${n.fieldMap}:${n.model}' has no field '${n.on}' for join`);if(!i.fields[o.on])throw new Error(`stitchFieldMaps: endpoint '${o.fieldMap}:${o.model}' has no field '${o.on}' for join`);let s=`${n.fieldMap}:${n.model}`,l=`${o.fieldMap}:${o.model}`;if(a.fields[l])throw new Error(`stitchFieldMaps: bridge '${l}' already injected on '${s}'`);if(i.fields[s])throw new Error(`stitchFieldMaps: bridge '${s}' already injected on '${l}'`);let u=r.cardinality==="oneToMany";a.fields[l]={kind:"bridge",type:l,isList:u},i.fields[s]={kind:"bridge",type:s,isList:false};}return t};var ff=/[.:]/,In=e=>{let t=[];for(let[r,n]of Object.entries(e.maps))for(let[o,a]of Object.entries(n.models))for(let[i,s]of Object.entries(a.fields))s.kind!=="bridge"&&ff.test(i)&&t.push(`'${r}:${o}.${i}' contains forbidden character . or :`);if(t.length)throw new Error(`validateFieldMapSet:
|
|
2
|
+
${t.join(`
|
|
3
|
+
`)}`)},uf=(e,t="fieldMap")=>{In({maps:{[t]:e}});};var jn={[f.equals]:f.notEquals,[f.notEquals]:f.equals,[f.lessThan]:f.greaterThanEquals,[f.lessThanEquals]:f.greaterThan,[f.greaterThan]:f.lessThanEquals,[f.greaterThanEquals]:f.lessThan,[f.in]:f.notIn,[f.notIn]:f.in,[f.contains]:f.notContains,[f.notContains]:f.contains,[f.matches]:f.notMatches,[f.notMatches]:f.matches,[f.between]:f.notBetween,[f.notBetween]:f.between,[f.isEmpty]:f.notEmpty,[f.notEmpty]:f.isEmpty,[f.exists]:f.notExists,[f.notExists]:f.exists},pf={[x.before]:x.onOrAfter,[x.after]:x.onOrBefore,[x.onOrBefore]:x.after,[x.onOrAfter]:x.before,[x.between]:x.notBetween,[x.notBetween]:x.between,[x.dayIn]:x.dayNotIn,[x.dayNotIn]:x.dayIn},df=e=>{let t=jn[e.operator];if(!t)throw new Error(`negate: operator '${e.operator}' has no inverse in the DSL. Affects 'where' clauses used under arrayOperator: 'all'. Rewrite the where clause using an invertible operator, or add the inverse operator to the DSL.`);return {...e,operator:t}},mf=e=>{let t=pf[e.dateOperator];return {...e,dateOperator:t}},cf=e=>{let t=jn[e.operator];if(!t)throw new Error(`negate: aggregate operator '${e.operator}' has no inverse in the DSL.`);return {...e,operator:t}},gf=e=>{switch(e.arrayOperator){case h.any:return {...e,arrayOperator:h.none};case h.none:return {...e,arrayOperator:h.any};case h.all:if(!e.condition)throw new Error("negate: arrayRule 'all' missing condition");return {...e,arrayOperator:h.any,condition:Z(e.condition)};case h.empty:return {...e,arrayOperator:h.notEmpty};case h.notEmpty:return {...e,arrayOperator:h.empty};case h.atLeast:if(e.count===void 0)throw new Error("negate: 'atLeast' missing count");return {...e,arrayOperator:h.atMost,count:e.count-1};case h.atMost:if(e.count===void 0)throw new Error("negate: 'atMost' missing count");return {...e,arrayOperator:h.atLeast,count:e.count+1};case h.exactly:throw new Error("negate: arrayRule 'exactly' has no single-operator inverse. Rewrite as { any: [atMost n-1, atLeast n+1] } if needed.");default:throw new Error(`negate: unknown arrayOperator '${e.arrayOperator}'`)}},Z=e=>{if(typeof e=="boolean")return !e;if("all"in e)return {any:e.all.map(Z)};if("any"in e)return {all:e.any.map(Z)};if("if"in e)return e.else!==void 0?{if:e.if,then:Z(e.then),else:Z(e.else)}:{all:[e.if,Z(e.then)]};if("arrayOperator"in e)return gf(e);if("dateOperator"in e)return mf(e);if("aggregate"in e)return cf(e);if("field"in e&&"operator"in e)return df(e);throw new Error("negate: unknown condition shape")};var Vn=e=>"model"in e,Re=e=>{let t=new Set,r=e;for(;!Vn(r);){if(t.has(r))throw new Error("cycle detected in narrowing parent chain");t.add(r),r=r.parent;}return r},Se=e=>{let t=[],r=new Set,n=e;for(;!Vn(n);){if(r.has(n))throw new Error("cycle detected in narrowing parent chain");r.add(n),t.unshift(n),n=n.parent;}return t},U=(e,t)=>{if(e.kind==="object")return {mapName:t,modelName:e.type};if(e.kind==="bridge"){let[r,n]=e.type.includes(":")?e.type.split(":"):[t,e.type];return {mapName:r,modelName:n}}return null};var lt=e=>{let t=Re(e),r=e.maps===t.maps?[]:Se(e);return {lens:t,chain:r}},ft=(e,t)=>e===null?new Set(t):new Set(t.filter(r=>e.has(r))),_t=e=>{if(!e.picks)return;if(!("relations"in e)||!e.relations)return e.picks;let t=[...e.picks];for(let r of Object.keys(e.relations))t.includes(r)||t.push(r);return t},Ft=(e,t)=>{let r=_t(t);if(r&&(e.visibleFields=ft(e.visibleFields,r)),t.omits)for(let n of t.omits)e.hiddenFields.add(n);t.where!==void 0&&e.whereClauses.push(t.where);},ke=(e,t,r,n)=>{let o={visibleFields:null,hiddenFields:new Set,enumValuesByField:new Map,whereClauses:[],relations:new Map},a=e.lens.maps[t],i=a?.models[r];if(!i)return o;let s=new Map,l=new Map,u=new Map,p=new Map,m=d=>{if(d.enumPicks)for(let[c,y]of Object.entries(d.enumPicks)){let g=s.get(c)??null;s.set(c,g===null?new Set(y):new Set(y.filter(w=>g.has(w))));}if(d.enumOmits)for(let[c,y]of Object.entries(d.enumOmits)){let g=l.get(c)??new Set;for(let w of y)g.add(w);l.set(c,g);}};for(let d of e.chain){let c=d.maps[t];if(c){let g=c.defaults?.models?.[r];g&&(Ft(o,g),m(g));for(let[w,b]of Object.entries(c.defaults?.enums??{})){if(b.picks){let k=u.get(w)??null;u.set(w,k===null?new Set(b.picks):new Set(b.picks.filter(v=>k.has(v))));}if(b.omits){let k=p.get(w)??new Set;for(let v of b.omits)k.add(v);p.set(w,k);}}}let y=d.maps[e.lens.mapName];if(y){let g=y.models[e.lens.model];if(n.length===0){if(t===e.lens.mapName&&r===e.lens.model&&g){Ft(o,g),m(g);for(let[w,b]of Object.entries(g.relations??{}))o.relations.set(w,b);}}else {for(let w of n)if(g=g?.relations?.[w],!g)break;if(g){Ft(o,g),m(g);for(let[w,b]of Object.entries(g.relations??{}))o.relations.set(w,b);}}}}if(n.length===0&&t===e.lens.mapName&&r===e.lens.model)for(let d of e.chain)d.where!==void 0&&o.whereClauses.push(d.where);for(let[d,c]of Object.entries(i.fields)){if(c.kind!=="enum")continue;let y=c.type,g=a?.enums?.[y],w=c.values??g;if(!w)continue;let b=w,k=u.get(y),v=p.get(y);k&&(b=b.filter(oe=>k.has(oe))),v&&(b=b.filter(oe=>!v.has(oe)));let L=s.get(d),I=l.get(d);L&&(b=b.filter(oe=>L.has(oe))),I&&(b=b.filter(oe=>!I.has(oe))),o.enumValuesByField.set(d,b);}return o},yf=(e,t)=>!(e.hiddenFields.has(t)||e.visibleFields!==null&&!e.visibleFields.has(t)),Wn=(e,t)=>e.enumValuesByField.get(t)??null,Ct=(e,t,r,n,o)=>{let a=o.split("."),i=t,s=r,l=[...n],u=[];for(let p=0;p<a.length;p++){let d=e.lens.maps[i]?.models[s];if(!d)return null;let c=ke(e,i,s,l),y=a[p];if(!yf(c,y))return null;let g=d.fields[y];if(!g)return null;if(p===a.length-1)return {mapName:i,modelName:s,relPath:l,entry:g,hopEffects:u,terminalEffect:c,terminalFieldName:y};u.push(c);let w=U(g,i);if(!w)return null;l=[...l,y],i=w.mapName,s=w.modelName;}return null};var hf=(e,t)=>t.length===0?e:{all:[...t,e]},wf=(e,t,r)=>r===h.all?{any:[Z(t),e]}:{all:[t,e]},fe=(e,t,r,n,o)=>{if(typeof e=="boolean")return e;if("all"in e)return {...e,all:e.all.map(a=>fe(a,t,r,n,o))};if("any"in e)return {...e,any:e.any.map(a=>fe(a,t,r,n,o))};if("if"in e)return {...e,if:fe(e.if,t,r,n,o),then:fe(e.then,t,r,n,o),else:e.else!==void 0?fe(e.else,t,r,n,o):e.else};if("field"in e&&typeof e.field=="string"&&e.field!==""){if(!t.lens.maps[r]?.models[n])return e;let s=e.field.split("."),l=r,u=n,p=[...o],d=false;for(let c=0;c<s.length;c++){let y=t.lens.maps[l]?.models[u];if(!y)break;let g=y.fields[s[c]];if(!g)break;if(c===s.length-1){if(g.kind==="object"||g.kind==="bridge"){let w=U(g,l);w&&(p=[...p,s[c]],l=w.mapName,u=w.modelName,d=true);}break}if(g.kind==="object"||g.kind==="bridge"){let w=U(g,l);if(w)p=[...p,s[c]],l=w.mapName,u=w.modelName;else break}else break}if("condition"in e&&e.condition!==void 0&&d){let c=ke(t,l,u,p),y=fe(e.condition,t,l,u,p),g="arrayOperator"in e?e.arrayOperator:void 0;for(let w of c.whereClauses)g?y=wf(y,w,g):y={all:[w,y]};return {...e,condition:y}}return e}return e},xf=(e,t)=>{let r=lt(t),n=ke(r,r.lens.mapName,r.lens.model,[]),o=fe(e,r,r.lens.mapName,r.lens.model,[]);return hf(o,n.whereClauses)};var bf=e=>{if(e.path!==void 0)return null;let t=e.value;return t===void 0?null:Array.isArray(t)?t:[t]},ue=(e,t,r,n,o,a)=>{if(typeof e=="boolean")return;if("all"in e){for(let c of e.all)ue(c,t,r,n,o,a);return}if("any"in e){for(let c of e.any)ue(c,t,r,n,o,a);return}if("if"in e){ue(e.if,t,r,n,o,a),ue(e.then,t,r,n,o,a),e.else!==void 0&&ue(e.else,t,r,n,o,a);return}let i=r,s=n,l=o,u=null,p=false,m=null,d=null;if("field"in e&&typeof e.field=="string"&&e.field!==""){let c=Ct(t,r,n,o,e.field);if(!c){a.push({path:e.field,reason:"path does not resolve through the narrowed lens"});return}if(u=c.terminalFieldName,p=c.entry.kind==="enum",m=c.entry.type,d=Wn(c.terminalEffect,u),c.entry.kind==="object"||c.entry.kind==="bridge"){let y=c.entry.kind==="object"?{mapName:c.mapName,modelName:c.entry.type}:{mapName:c.entry.type.split(":")[0]??c.mapName,modelName:c.entry.type.split(":")[1]??c.entry.type};i=y.mapName,s=y.modelName,l=[...c.relPath,u];}}if(p&&"operator"in e&&u){let c=bf(e);if(c&&d){let y=new Set(d);for(let g of c)typeof g=="string"&&!y.has(g)&&a.push({path:u,reason:`value '${g}' is not in the allowed set for enum '${m}' (allowed: ${[...y].join(", ")})`});}}if("aggregate"in e&&typeof e.aggregate=="object"&&e.aggregate!==null&&typeof e.aggregate.field=="string"&&e.aggregate.field!==""){let c=e.aggregate.field;Ct(t,i,s,l,c)||a.push({path:c,reason:"aggregate.field does not resolve through the narrowed lens"});}"condition"in e&&e.condition!==void 0&&ue(e.condition,t,i,s,l,a);},Pt=(e,t)=>{let r=lt(t),n=[];return ue(e,r,r.lens.mapName,r.lens.model,[],n),ke(r,r.lens.mapName,r.lens.model,[]),{ok:n.length===0,violations:n}};var Of=e=>({...Tt({maps:e.maps,bridges:e.bridges}),mapName:e.mapName,model:e.model});var Un=(e,t,r,n,o,a,i,s,l=false)=>{e.picks&&e.omits&&s.push(`${i}: cannot specify both picks and omits`),l&&"relations"in e&&e.relations&&s.push(`${i}: defaults cannot declare 'relations' \u2014 relations are path-specific only`);for(let p of e.picks??[]){if(!n[p]){s.push(`${i}.picks: field '${p}' not on model`);continue}let m=false;for(let d of t){if(d.picks&&!d.picks.includes(p)){s.push(`${i}.picks: '${p}' not in ancestor's picks`),m=true;break}if(d.omits?.includes(p)){s.push(`${i}.picks: '${p}' was omitted by ancestor`),m=true;break}}m||!l&&r&&(r.picks&&!r.picks.includes(p)?s.push(`${i}.picks: '${p}' not visible from defaults.picks`):r.omits?.includes(p)&&s.push(`${i}.picks: '${p}' not visible (already excluded by defaults.omits)`));}for(let p of e.omits??[]){if(!n[p]){s.push(`${i}.omits: field '${p}' not on model`);continue}let m=false;for(let d of t){if(d.picks&&!d.picks.includes(p)){s.push(`${i}.omits: '${p}' not in ancestor's picks (already invisible)`),m=true;break}if(d.omits?.includes(p)){s.push(`${i}.omits: '${p}' already excluded by ancestor`),m=true;break}}m||!l&&r&&(r.picks&&!r.picks.includes(p)?s.push(`${i}.omits: '${p}' not visible from defaults.picks`):r.omits?.includes(p)&&s.push(`${i}.omits: '${p}' already excluded by defaults`));}let u=(p,m,d)=>{let c=n[m];if(!c){s.push(`${i}.${p}: field '${m}' not on model`);return}if(c.kind!=="enum"){s.push(`${i}.${p}: field '${m}' is not an enum field`);return}let y=c.values??a?.[c.type];for(let g of d)y&&!y.includes(g)&&s.push(`${i}.${p}.${m}: '${g}' is not a known value of enum '${c.type}'`);};for(let[p,m]of Object.entries(e.enumPicks??{}))u("enumPicks",p,m);for(let[p,m]of Object.entries(e.enumOmits??{}))u("enumOmits",p,m);if(e.where!==void 0&&e.where!==true&&e.where!==false){let p=$f(e.where,n,o);for(let m of p)s.push(`${i}.where: ${m}`);}},$f=(e,t,r)=>{let n=[],o=a=>{if(a===null||typeof a!="object")return;if(Array.isArray(a)){for(let s of a)o(s);return}let i=a;if("all"in i&&Array.isArray(i.all)){for(let s of i.all)o(s);return}if("any"in i&&Array.isArray(i.any)){for(let s of i.any)o(s);return}if("if"in i){o(i.if),o(i.then),i.else!==void 0&&o(i.else);return}if("field"in i&&typeof i.field=="string"&&i.field!==""){let s=i.field.split(".")[0];t[s]||n.push(`'${i.field}' not on model ${r}`);}"condition"in i&&i.condition!==void 0&&o(i.condition);};return o(e),n},Af=(e,t,r,n,o)=>{for(let[a,i]of Object.entries(t)){let s=r?.[a];if(!s){o.push(`maps.${e}.defaults.enums.${a}: enum not in registry`);continue}let l=null,u=new Set;for(let m of n){let d=m[a];if(d&&(d.picks&&(l=l===null?new Set(d.picks):new Set(d.picks.filter(c=>l?.has(c)))),d.omits))for(let c of d.omits)u.add(c);}let p=m=>!(u.has(m)||l&&!l.has(m));for(let m of i.picks??[])s.includes(m)?p(m)||o.push(`maps.${e}.defaults.enums.${a}.picks: '${m}' not visible from ancestors`):o.push(`maps.${e}.defaults.enums.${a}.picks: '${m}' not a known value`);for(let m of i.omits??[])s.includes(m)?p(m)||o.push(`maps.${e}.defaults.enums.${a}.omits: '${m}' already excluded by ancestors`):o.push(`maps.${e}.defaults.enums.${a}.omits: '${m}' not a known value`);}},Gn=(e,t,r,n,o,a)=>{let i=(s,l,u)=>{let p=e[l];if(!p||p.kind!=="enum")return;let m=p.type,d=null,c=new Set,y=[...n];r&&y.push(r);for(let g of y){let w=g[m];if(w&&(w.picks&&(d=d===null?new Set(w.picks):new Set(w.picks.filter(b=>d?.has(b)))),w.omits))for(let b of w.omits)c.add(b);}for(let g of u)c.has(g)?a.push(`${o}.${s}.${l}: '${g}' already excluded by defaults.enums`):d&&!d.has(g)&&a.push(`${o}.${s}.${l}: '${g}' not allowed by defaults.enums`);};for(let[s,l]of Object.entries(t.enumPicks??{}))i("enumPicks",s,l);for(let[s,l]of Object.entries(t.enumOmits??{}))i("enumOmits",s,l);},Kn=(e,t,r,n,o,a,i,s,l,u,p)=>{let m=i[s],d=m?.models[l];if(!d)return;let c=[...r.map(y=>y),...t];Un(e,c,n,d.fields,l,m?.enums,u,p,false),Gn(d.fields,e,a,o,u,p);for(let[y,g]of Object.entries(e.relations??{})){let w=d.fields[y];if(!w){p.push(`${u}.relations: '${y}' not on model`);continue}if(w.kind!=="object"&&w.kind!=="bridge"){p.push(`${u}.relations: '${y}' is not a relation (kind=${w.kind})`);continue}let b=U(w,s);if(!b)continue;if(!i[b.mapName]?.models[b.modelName]){p.push(`${u}.relations.${y}: target model not found in lens`);continue}let k=t.map(v=>v.relations?.[y]).filter(v=>v!==void 0);Kn(g,k,r,n,o,a,i,b.mapName,b.modelName,`${u}.relations.${y}`,p);}},vf=e=>{let t=[],r=Re(e),n=Se(e.parent);for(let[o,a]of Object.entries(e.maps)){let i=r.maps[o];if(!i){t.push(`maps.${o}: not in lens`);continue}let s=n.map(u=>u.maps[o]?.defaults?.enums).filter(u=>u!==void 0);for(let[u,p]of Object.entries(a.defaults?.models??{})){let m=i.models[u];if(!m){t.push(`maps.${o}.defaults.models.${u}: not in fieldMap`);continue}let d=n.map(c=>c.maps[o]?.defaults?.models?.[u]).filter(c=>c!==void 0);Un(p,d,void 0,m.fields,u,i.enums,`maps.${o}.defaults.models.${u}`,t,true),Gn(m.fields,p,void 0,s,`maps.${o}.defaults.models.${u}`,t);}a.defaults?.enums&&Af(o,a.defaults.enums,i.enums,s,t);let l=a.defaults?.enums;for(let[u,p]of Object.entries(a.models)){if(!i.models[u]){t.push(`maps.${o}.models.${u}: not in fieldMap`);continue}p.where!==void 0&&t.push(`maps.${o}.models.${u}.where: not allowed at top-level. Use LensNarrowing.where for root scoping, or defaults.models.${u}.where for model-intrinsic scoping. (where on relations[R] still works for descent scoping.)`);let d=n.map(g=>g.maps[o]?.models[u]).filter(g=>g!==void 0),c=n.map(g=>g.maps[o]?.defaults?.models?.[u]).filter(g=>g!==void 0),y=a.defaults?.models?.[u];Kn(p,d,c,y,s,l,r.maps,o,u,`maps.${o}.models.${u}`,t);}}if(e.where!==void 0){let o=Pt(e.where,e);for(let a of o.violations)t.push(`where: '${a.path}' ${a.reason}`);}if(t.length)throw new Error(`validateNarrowing:
|
|
4
|
+
${t.join(`
|
|
5
|
+
`)}`)};var Hn=()=>({picks:null,omits:new Set,enumPicks:new Map,enumOmits:new Map}),Jn=(e,t)=>{let r=_t(t);if(r&&(e.picks=ft(e.picks,r)),t.omits)for(let n of t.omits)e.omits.add(n);if(t.enumPicks)for(let[n,o]of Object.entries(t.enumPicks))e.enumPicks.set(n,ft(e.enumPicks.get(n)??null,o));if(t.enumOmits)for(let[n,o]of Object.entries(t.enumOmits)){let a=e.enumOmits.get(n)??new Set;for(let i of o)a.add(i);e.enumOmits.set(n,a);}},Qn=(e,t,r,n,o)=>{let a=`${t}::${r}`,i=o.get(a);i||(i=Hn(),o.set(a,i)),Jn(i,n);let s=e.maps[t]?.models[r];if(s)for(let[l,u]of Object.entries(n.relations??{})){let p=s.fields[l];if(!p)continue;let m=U(p,t);m&&Qn(e,m.mapName,m.modelName,u,o);}},zn=(e,t,r)=>{let n=e;if(t){let o=new Set(t);n=n.filter(a=>o.has(a));}if(r){let o=new Set(r);n=n.filter(a=>!o.has(a));}return n},Ef=e=>{let t=Re(e),r={maps:structuredClone(t.maps),bridges:t.bridges?structuredClone(t.bridges):void 0},n=Se(e),o=new Map;for(let a of n)for(let[i,s]of Object.entries(a.maps)){if(!r.maps[i])continue;let u=s.defaults?.models??{};for(let[p,m]of Object.entries(u)){let d=`${i}::${p}`,c=o.get(d);c||(c=Hn(),o.set(d,c)),Jn(c,m);}for(let[p,m]of Object.entries(s.models))Qn(r,i,p,m,o);}for(let a of n)for(let[i,s]of Object.entries(a.maps)){let l=r.maps[i];if(l?.enums)for(let[u,p]of Object.entries(s.defaults?.enums??{})){let m=l.enums[u];m&&(l.enums={...l.enums,[u]:zn(m,p.picks,p.omits)});}}for(let[a,i]of o){let[s,l]=a.split("::"),u=r.maps[s]?.models[l];if(!u)continue;let p=u.fields,m=i.picks;for(let d of Object.keys(p)){let c=m===null||m.has(d),y=i.omits.has(d);(!c||y)&&delete p[d];}for(let[d,c]of Object.entries(p)){if(c.kind!=="enum")continue;let y=r.maps[s]?.enums?.[c.type],g=c.values??y,w=i.enumPicks.get(d),b=i.enumOmits.get(d);if(!g&&!w&&!b)continue;let v=zn(g??[],w?Array.from(w):void 0,b?Array.from(b):void 0);c.values=v;}}return r.bridges&&(r.bridges=r.bridges.filter(a=>{let[i,s]=a.endpoints,l=`${s.fieldMap}:${s.model}`,u=`${i.fieldMap}:${i.model}`,p=r.maps[i.fieldMap]?.models[i.model]?.fields[l]!==void 0,m=r.maps[s.fieldMap]?.models[s.model]?.fields[u]!==void 0;return p&&m})),r};var Rf={String:"String",Boolean:"Boolean",Int:"Int",BigInt:"BigInt",Float:"Float",Decimal:"Decimal",DateTime:"DateTime",Json:"Json",Bytes:"Bytes",Enum:"Enum"},Sf=["Int","Float","Decimal","BigInt"],Me=["String",...Sf,"DateTime"],ee=["String"],ut=["String","Boolean","Int","BigInt","Float","Decimal","DateTime","Enum"],Yn=Object.values(Rf),Kh={check:"check",toPrisma:"toPrisma",toSql:"toSql"},R=["check","toPrisma","toSql"],Te=["check","toPrisma"],pt=["check","toSql"],zh={none:"none",scalar:"scalar",ordered:"ordered",array:"array",string:"string",pattern:"pattern",range:"range",dateValue:"dateValue",dateRange:"dateRange",dayList:"dayList",count:"count",predicate:"predicate"},B={[f.equals]:{kinds:ut,targets:R,valueShape:"scalar"},[f.notEquals]:{kinds:ut,targets:R,valueShape:"scalar"},[f.lessThan]:{kinds:Me,targets:R,valueShape:"ordered"},[f.lessThanEquals]:{kinds:Me,targets:R,valueShape:"ordered"},[f.greaterThan]:{kinds:Me,targets:R,valueShape:"ordered"},[f.greaterThanEquals]:{kinds:Me,targets:R,valueShape:"ordered"},[f.in]:{kinds:ut,targets:R,valueShape:"array"},[f.notIn]:{kinds:ut,targets:R,valueShape:"array"},[f.contains]:{kinds:ee,targets:R,valueShape:"string"},[f.notContains]:{kinds:ee,targets:R,valueShape:"string"},[f.startsWith]:{kinds:ee,targets:R,valueShape:"string"},[f.endsWith]:{kinds:ee,targets:R,valueShape:"string"},[f.matches]:{kinds:ee,targets:pt,valueShape:"pattern"},[f.notMatches]:{kinds:ee,targets:pt,valueShape:"pattern"},[f.between]:{kinds:Me,targets:R,valueShape:"range"},[f.notBetween]:{kinds:Me,targets:R,valueShape:"range"},[f.isEmpty]:{kinds:ee,targets:R,valueShape:"none"},[f.notEmpty]:{kinds:ee,targets:R,valueShape:"none"},[f.exists]:{kinds:Yn,targets:R,valueShape:"none"},[f.notExists]:{kinds:Yn,targets:R,valueShape:"none"}},te={[x.before]:{kinds:["DateTime"],targets:R,valueShape:"dateValue"},[x.after]:{kinds:["DateTime"],targets:R,valueShape:"dateValue"},[x.onOrBefore]:{kinds:["DateTime"],targets:R,valueShape:"dateValue"},[x.onOrAfter]:{kinds:["DateTime"],targets:R,valueShape:"dateValue"},[x.between]:{kinds:["DateTime"],targets:R,valueShape:"dateRange"},[x.notBetween]:{kinds:["DateTime"],targets:R,valueShape:"dateRange"},[x.dayIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"},[x.dayNotIn]:{kinds:["DateTime"],targets:pt,valueShape:"dayList"}},re={[h.all]:{targets:Te,valueShape:"predicate"},[h.any]:{targets:Te,valueShape:"predicate"},[h.none]:{targets:Te,valueShape:"predicate"},[h.atLeast]:{targets:Te,valueShape:"count"},[h.atMost]:{targets:Te,valueShape:"count"},[h.exactly]:{targets:Te,valueShape:"count"},[h.empty]:{targets:R,valueShape:"none"},[h.notEmpty]:{targets:R,valueShape:"none"}},kf=new Set(["scalar","ordered"]),Mf=new Set(["range"]),Hh=[f.equals,f.notEquals,f.lessThan,f.lessThanEquals,f.greaterThan,f.greaterThanEquals,f.between,f.notBetween],Xn=e=>{let t=B[e];return t?kf.has(t.valueShape):false},Zn=e=>{let t=B[e];return t?Mf.has(t.valueShape):false},Dt=e=>{if(Object.hasOwn(B,e))return B[e].valueShape;if(Object.hasOwn(te,e))return te[e].valueShape;if(Object.hasOwn(re,e))return re[e].valueShape;throw new Error(`Unknown operator: ${e}`)},dt=(e,t)=>Object.hasOwn(B,e)?B[e].targets.includes(t):Object.hasOwn(te,e)?te[e].targets.includes(t):Object.hasOwn(re,e)?re[e].targets.includes(t):false,Jh=(e,t)=>{let r=Object.keys(B).filter(o=>{let a=B[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))}),n=Object.keys(te).filter(o=>{let a=te[o];return !(!a.kinds.includes(e)||t&&!a.targets.includes(t))});return {field:r,date:n}},Qh=e=>Object.keys(re).filter(t=>e?re[t].targets.includes(e):true);var mt=(e,t,r,n)=>{let o=e.models[t];if(!o)return null;for(let a of Object.values(o.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(n===void 0||a.relationName===n))return a;return null};var q=(e,t)=>{let r=e.split("."),n=t;for(let o=r.length-1;o>=0;o--)n={[r[o]]:n};return n};var eo,to=e=>{eo=e;},ro=(e,t,r)=>{if(!t?.map||!t?.model||!r)throw new Error("Aggregate rules require a FieldMap and model to generate a Prisma plan. Pass { map, model } options to toPrisma().");if(!e.aggregate.field)throw new Error("Prisma aggregate rules require aggregate.field to specify the numeric field on the related model.");if(e.path)throw new Error("path is not supported for Prisma aggregate rules; use value instead.");return Ff(e,t,r)},Tf=(e,t,r)=>{let n=e.split("."),o=[],a=r;for(let i=0;i<n.length;i++){let s=n[i],l=t.models[a]?.fields[s];if(!l||l.kind!=="object")throw new Error(`Field '${s}' is not a relation in model '${a}'. Prisma aggregate rules only support relation fields.`);if(i===n.length-1){if(!l.isList)throw new Error(`Field '${s}' is not a list relation in model '${a}'.`);return {segments:n,intermediateRelations:o,terminalModel:a,terminalEntry:l}}if(l.isList)throw new Error(`Intermediate field '${s}' in path '${e}' is a list relation. Only the final segment can be a list relation for aggregate rules.`);o.push({fieldName:s,entry:l,onModel:a}),a=l.type;}throw new Error(`Field path '${e}' did not terminate at a list relation.`)},Ff=(e,t,r)=>{let{map:n,model:o}=t,{intermediateRelations:a,terminalModel:i,terminalEntry:s}=Tf(e.field,n,o),l=s.type,u=e.aggregate.field??"",p=n.models[l]?.fields[u];if(!p)throw new Error(`aggregate.field '${u}' does not exist on model '${l}'.`);if(p.kind!=="scalar")throw new Error(`aggregate.field '${u}' on model '${l}' must be a scalar field, got '${p.kind}'.`);if(p.type==="Json")throw new Error(`aggregate.field '${u}' on model '${l}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let m,d;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");m=s.toFields?.[0]??"id",d=s.fromFields[0];}else {let v=mt(n,l,i,s.relationName);if(!v)throw new Error(`Cannot determine FK relationship between '${i}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((v.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");m=v.fromFields?.[0]??"",d=v.toFields?.[0]??"";}let c=e.condition?eo(e.condition,{...t,model:l},r):{},y=e.aggregate.mode==="sum"?"_sum":"_avg",g={[u]:{[y]:_f(e)}},w={operation:"groupBy",model:l,args:{by:[m],where:c,having:g},extract:m},b=r.steps.length;r.steps.push(w);let k={__step:b};if(a.length>0){let v={[d]:{in:k}},L=a.map(I=>I.fieldName).join(".");return q(L,v)}return {[d]:{in:k}}},_f=e=>{let t=e.value;switch(e.operator){case f.equals:return {equals:t};case f.notEquals:return {not:t};case f.lessThan:return {lt:t};case f.lessThanEquals:return {lte:t};case f.greaterThan:return {gt:t};case f.greaterThanEquals:return {gte:t};case f.between:{if(!Array.isArray(t)||t.length!==2)throw new Error("between requires two values");let[r,n]=t,[o,a]=r<=n?[r,n]:[n,r];return {gte:o,lte:a}}case f.notBetween:throw new Error("Operator 'notBetween' is not supported for Prisma aggregate rules.");default:throw new Error(`Operator '${e.operator}' is not supported for Prisma aggregate rules.`)}};var no=(e,t,r,n)=>{let{map:o,model:a}=t;if(!e.field)throw new Error("toPrisma: count-based ArrayRule requires a field path");let i=o.models[a]?.fields[e.field];if(!i||i.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${a}'. Count operators require a relation field.`);if(!i.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${a}'. Count operators only apply to one-to-many or many-to-many relations.`);let s=i.type,l,u;if(i.fromFields&&i.fromFields.length>0){if(i.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=i.toFields?.[0]??"id",u=i.fromFields[0];}else {let w=mt(o,s,a,i.relationName);if(!w){let k=Object.values(o.models[s]?.fields??{}).some(v=>v.kind==="object"&&v.type===a&&v.isList&&!v.fromFields?.length);throw new Error(k?`'${a}.${e.field}' is an implicit many-to-many relation. Count operators require an explicit join model with a FK \u2014 convert to an explicit @relation or use prisma.$queryRaw.`:`Cannot determine FK relationship between '${a}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`)}if((w.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${a}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=w.fromFields?.[0]??"",u=w.toFields?.[0]??"";}let p=e.condition?n(e.condition,{...t,model:s},r):{},m=e.count??1,d=Cf(e.arrayOperator,m,l),c={operation:"groupBy",model:s,args:{by:[l],where:p,having:d},extract:l},y=r.steps.length;r.steps.push(c);let g={__step:y};return {[u]:{in:g}}},Cf=(e,t,r)=>{switch(e){case h.atLeast:return {[r]:{_count:{gte:t}}};case h.atMost:return {[r]:{_count:{lte:t}}};case h.exactly:return {[r]:{_count:{equals:t}}};default:throw new Error("unreachable")}};var Ne,oo=e=>{Ne=e;},ao=(e,t,r)=>{if(e.arrayOperator===h.atLeast||e.arrayOperator===h.atMost||e.arrayOperator===h.exactly){if(t?.map&&t?.model&&r)return no(e,t,r,Ne);throw new Error(`ArrayOperator '${e.arrayOperator}' requires a FieldMap and model to generate a multi-step plan. Pass { map, model } options to toPrisma(). Without them, use prisma.$queryRaw for count-based relation filtering.`)}if(!e.field)throw new Error("toPrisma: ArrayRule.field is required (fieldless arrayOps are check-only)");let n=Nf(e,t,r);return q(e.field,n)},Pf=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},Df=(e,t)=>{if(!t?.map||!t?.model||!e.field)return t;let r=Pf(e.field,t.map,t.model);return r?{...t,model:r}:t},Nf=(e,t,r)=>{let n=Df(e,t);switch(e.arrayOperator){case h.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:Ne(e.condition,n,r)};case h.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:Ne(e.condition,n,r)};case h.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:Ne(e.condition,n,r)};case h.empty:return {none:{}};case h.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var lo=(e,t)=>{let r=qf(e,t);return q(e.field,r)},Bf=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column date comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve date path '${e.path}'. Pass context when calling toPrisma().`);return E(t.context,e.path)}},qf=(e,t)=>{let r=()=>Bf(e,t);switch(e.dateOperator){case x.before:return {lt:r()};case x.after:return {gt:r()};case x.onOrBefore:return {lte:r()};case x.onOrAfter:return {gte:r()};case x.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between date operator requires an array of two values");let[o,a]=io(n);return {gte:o,lte:a}}case x.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween date operator requires an array of two values");let[o,a]=io(n);return {NOT:{gte:o,lte:a}}}case x.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case x.dayNotIn:throw new Error("DateOperator 'dayNotIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},io=e=>{let[t,r]=e;return Lf(t,r)<=0?[t,r]:[r,t]},Lf=(e,t)=>{let r=so(e),n=so(t);return r<n?-1:r>n?1:0},so=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var ct=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return {kind:"fallback"};let s=i.fields[n[a]];if(!s)return {kind:"fallback"};if(s.kind==="bridge")return {kind:"bridge"};if(s.kind==="scalar"&&s.type==="Json"&&a<n.length-1)return {kind:"json-path",stopIndex:a+1,jsonPath:n.slice(a+1)};if(s.kind==="object"){if(!t.models[s.type])return {kind:"fallback"};o=s.type;continue}return {kind:"direct"}}return {kind:"direct"}};var fo=(e,t)=>{if(e.operator===f.isEmpty)return {OR:[Be(e.field,{equals:null},t),Be(e.field,{equals:""},t)]};if(e.operator===f.notEmpty)return {AND:[Be(e.field,{not:null},t),Be(e.field,{not:""},t)]};let r=jf(e,t);return Be(e.field,r,t)},If=(e,t)=>{if(e.value!==void 0)return e.value;if(e.path){if(e.path.startsWith("$."))throw new Error(`Prisma WHERE has no column-to-column comparison for path '${e.path}'. Use prisma.$queryRaw for field-to-field filtering.`);if(!t?.context)throw new Error(`options.context is required to resolve path '${e.path}'. Pass context when calling toPrisma().`);return E(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},jf=(e,t)=>{let r=()=>If(e,t);switch(e.operator){case f.equals:return {equals:r()??null};case f.notEquals:return {not:r()??null};case f.lessThan:return {lt:r()};case f.lessThanEquals:return {lte:r()};case f.greaterThan:return {gt:r()};case f.greaterThanEquals:return {gte:r()};case f.in:return {in:r()};case f.notIn:return {notIn:r()};case f.contains:return {contains:r()};case f.notContains:return {not:{contains:r()}};case f.startsWith:return {startsWith:r()};case f.endsWith:return {endsWith:r()};case f.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case f.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between operator requires an array of two values");let[o,a]=n[0]<=n[1]?n:[n[1],n[0]];return {gte:o,lte:a}}case f.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween operator requires an array of two values");let[o,a]=n[0]<=n[1]?n:[n[1],n[0]];return {NOT:{gte:o,lte:a}}}case f.isEmpty:case f.notEmpty:throw new Error("isEmpty/notEmpty handled at buildFieldRule level");case f.exists:return {not:null};case f.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},Be=(e,t,r)=>{if(!r?.map||!r?.model)return q(e,t);let n=ct(e,r.map,r.model),o=e.split(".");switch(n.kind){case "fallback":case "direct":return q(e,t);case "bridge":return {};case "json-path":{let a={path:n.jsonPath,...t},i=o.slice(0,n.stopIndex).join(".");return q(i,a)}}};var Fe,po=e=>{Fe=e;},Vf=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},G=(e,t)=>{if(typeof e=="boolean"||!t?.map||!t?.model)return false;if("all"in e)return e.all.some(r=>G(r,t));if("any"in e)return e.any.some(r=>G(r,t));if("if"in e)return G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(ct(e.field,t.map,t.model).kind==="bridge")return true;if("condition"in e&&e.condition!==void 0){let n=Vf(e.field,t.map,t.model);if(n&&G(e.condition,{...t,model:n}))return true}}return false},mo=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(n=>Fe(n,t,r))},co=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>Fe(n,t,r))},go=(e,t,r)=>{if(G(e.if,t)||G(e.then,t)||e.else!==void 0&&G(e.else,t))return {};let n=Fe(e.if,t,r),o={NOT:n},a=e.then===false?uo:Fe(e.then,t,r);if(e.else!==void 0){let i=e.else===false?uo:Fe(e.else,t,r);return {AND:[{OR:[o,a]},{OR:[n,i]}]}}return {OR:[o,a]}},uo={AND:[{id:null},{id:{not:null}}]};var qe=(e,t,r)=>{if(typeof e=="boolean"){if(e)return {};throw new Error("Boolean 'false' has no direct Prisma WHERE equivalent. toPrisma is designed for structured Rule conditions.")}if("all"in e)return mo(e,t,r);if("any"in e)return co(e,t,r);if("if"in e)return go(e,t,r);if("arrayOperator"in e)return ao(e,t,r);if("dateOperator"in e)return lo(e,t);if("aggregate"in e)return ro(e,t,r);if("field"in e)return fo(e,t);throw new Error("Unknown condition type")};po(qe);oo(qe);to(qe);var Wf=async(e,t)=>{let r=e.steps.filter(a=>a.operation==="groupBy"),n=e.steps.find(a=>a.operation==="where");if(!n)throw new Error("executePrismaQueryPlan: result has no where step");let o=[];for(let a of r){let i=a.model.charAt(0).toLowerCase()+a.model.slice(1),s=t[i];if(!s)throw new Error(`executePrismaQueryPlan: no delegate for model '${a.model}'. Ensure prismaDelegate has a key '${i}'.`);let l=await s[a.operation](a.args);o.push(l.map(u=>u[a.extract]));}return Nt(n.where,o)},Nt=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>Nt(r,t));if(typeof e=="object"){let r=e;if("__step"in r&&typeof r.__step=="number"){let o=r.__step;if(o>=t.length)throw new Error(`Step ref __step: ${o} out of range (${t.length} steps executed)`);return t[o]}let n={};for(let[o,a]of Object.entries(r))n[o]=Nt(a,t);return n}return e};var Uf=e=>{if(!e?.map)return e;let t="maps"in e.map;if(t&&!e.mapName)throw new Error("toPrisma: 'map' is a FieldMapSet \u2014 'mapName' is required to resolve which map to use.");if(!t||!e.mapName)return e;let r=e.map.maps[e.mapName];if(!r)throw new Error(`toPrisma: fieldMap set has no entry for '${e.mapName}'`);return {...e,map:r}},Fw=(e,t)=>{let r={steps:[]},n=qe(e,Uf(t),r);return {steps:[...r.steps,{operation:"where",where:n}]}};var A=e=>`"${e.replace(/"/g,'""')}"`;var $=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var Le=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),F=e=>{let t=e.split(".");if(t.length===1)return A(e);let[r,...n]=t;return n.length===0?A(r):ho(A(r),n)},yo=(e,t)=>{let r=e.split(".");if(r.length===1)return `${A(t)}.${A(e)}`;let[n,...o]=r;return ho(`${A(t)}.${A(n)}`,o)},Bt=e=>`'${e.replace(/'/g,"''")}'`,ho=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(Bt).join("->"),n=Bt(t[t.length-1]);return r?`${e}->${r}->>${n}`:`${e}->>${n}`},wo=e=>{let t=e.split(".");if(t.length===1)return A(e);let[r,...n]=t;return n.length===0?A(r):Gf(A(r),n)},Gf=(e,t)=>{let r=t.map(Bt).join("->");return `${e}->${r}`};var xo=(e,t)=>{if(e.condition)throw new Error("Aggregate condition filtering is not yet supported by toSql(). Use check() for in-memory evaluation or toPrisma() for database queries.");let r=Kf(e,t);return Hf(r,e,t)},Kf=(e,t)=>{let r=wo(e.field),{mode:n,field:o}=e.aggregate,a=n==="sum"?"SUM":"AVG",i=t.map?.models[t.currentModel??""]?.fields[e.field];if(i?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(o?.includes("."))throw new Error(`aggregate.field '${o}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(i?.kind==="scalar"&&i?.isList===true){if(o)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${a==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${r}) AS elem)`}if(o){let p=`(elem->>'${o}')::numeric`;return `(SELECT ${a==="SUM"?`COALESCE(SUM(${p}), 0)`:`AVG(${p})`} FROM jsonb_array_elements(${r}) AS elem)`}let l="elem::numeric";return `(SELECT ${a==="SUM"?`COALESCE(SUM(${l}), 0)`:`AVG(${l})`} FROM jsonb_array_elements_text(${r}) AS elem)`},zf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:E(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},Hf=(e,t,r)=>{let n=zf(t,r),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(t.operator){case f.equals:return a?`${e} = ${a}`:o===null?`${e} IS NULL`:`${e} = ${$(r,o)}`;case f.notEquals:return a?`${e} <> ${a}`:o===null?`${e} IS NOT NULL`:`${e} <> ${$(r,o)}`;case f.lessThan:return a?`${e} < ${a}`:`${e} < ${$(r,o)}`;case f.lessThanEquals:return a?`${e} <= ${a}`:`${e} <= ${$(r,o)}`;case f.greaterThan:return a?`${e} > ${a}`:`${e} > ${$(r,o)}`;case f.greaterThanEquals:return a?`${e} >= ${a}`:`${e} >= ${$(r,o)}`;case f.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} BETWEEN ${$(r,s)} AND ${$(r,l)}`}case f.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween requires two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${e} NOT BETWEEN ${$(r,s)} AND ${$(r,l)}`}default:throw new Error(`Operator '${t.operator}' is not supported for aggregate rules`)}};var bo=(e,t)=>{if(!e.field)throw new Error("toSql: ArrayRule.field is required (fieldless arrayOps are check-only)");let r=F(e.field),n=t.map?.models[t.currentModel??""]?.fields[e.field],o=n?.kind==="scalar"&&n?.isList===true,a=o?`array_length(${r}, 1)`:`jsonb_array_length(${r})`;switch(e.arrayOperator){case h.empty:return o?`(${r} IS NULL OR ${a} IS NULL)`:`(${r} IS NULL OR ${a} = 0)`;case h.notEmpty:return o?`(${r} IS NOT NULL AND ${a} IS NOT NULL)`:`(${r} IS NOT NULL AND ${a} > 0)`;case h.all:case h.any:case h.none:case h.atLeast:case h.atMost:case h.exactly:throw new Error(`Array operator '${e.arrayOperator}' with conditions is not supported in SQL. Use application-level filtering for complex array operations.`);default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var qt=e=>{let t={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};return e.map(r=>{let n=t[r.toLowerCase()];if(n===void 0)throw new Error(`Unknown day name: ${r}`);return n})};var gt=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return F(e);let r=e.split("."),n=t.currentModel,o=t.currentAlias;for(let a=0;a<r.length;a++){let i=t.map.models[n];if(!i)return F(e);let s=i.fields[r[a]];if(!s)return F(e);if(s.kind==="object"){let u=`${o}.${r[a]}`,p=t.joinRegistry?.get(u),m;if(p)m=p;else {let d=t.joinCounter;if(!d)return F(e);m=`t${++d.n}`;let c=Jf(t.map,n,o,s,m);if(!c)return F(e);t.joins?.push(c),t.joinRegistry?.set(u,m);}n=s.type,o=m;continue}let l=r.slice(a);return yo(l.join("."),o)}return F(e)},Jf=(e,t,r,n,o)=>{let a=n.type,i=e.models[a]?.dbName??a,s;if(n.fromFields&&n.fromFields.length>0&&n.toFields&&n.toFields.length>0)s=n.fromFields.map((l,u)=>`${A(o)}.${A(n.toFields?.[u]??"")} = ${A(r)}.${A(l)}`).join(" AND ");else {let l=Qf(e,a,t,n.relationName);if(!l)return null;s=(l.fromFields??[]).map((u,p)=>`${A(o)}.${A(u)} = ${A(r)}.${A(l.toFields?.[p]??"")}`).join(" AND ");}return `LEFT JOIN ${A(i)} AS ${A(o)} ON ${s}`},Qf=(e,t,r,n)=>{let o=e.models[t];if(!o)return null;for(let a of Object.values(o.fields))if(a.kind==="object"&&a.type===r&&(a.fromFields?.length??0)>0&&(a.toFields?.length??0)>0&&(n===void 0||a.relationName===n))return a;return null};var Ao=(e,t)=>{let r=gt(e.field,t),n=Xf(e,t),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(e.dateOperator){case x.before:return a!==void 0?`${r} < ${a}`:`${r} < ${$(t,o)}`;case x.after:return a!==void 0?`${r} > ${a}`:`${r} > ${$(t,o)}`;case x.onOrBefore:return a!==void 0?`${r} <= ${a}`:`${r} <= ${$(t,o)}`;case x.onOrAfter:return a!==void 0?`${r} >= ${a}`:`${r} >= ${$(t,o)}`;case x.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between date operator requires an array of two values");let[s,l]=Oo(i);return `${r} BETWEEN ${$(t,s)} AND ${$(t,l)}`}case x.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween date operator requires an array of two values");let[s,l]=Oo(i);return `${r} NOT BETWEEN ${$(t,s)} AND ${$(t,l)}`}case x.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let i=qt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) = ANY(${$(t,i)})`}case x.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let i=qt(e.value.map(s=>String(s)));return `EXTRACT(DOW FROM ${r}) <> ALL(${$(t,i)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Oo=e=>{let[t,r]=e;return Yf(t,r)<=0?[t,r]:[r,t]},Yf=(e,t)=>{let r=$o(e),n=$o(t);return r<n?-1:r>n?1:0},$o=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),Xf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve date path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:E(t.context,e.path)}}return {type:"value",value:void 0}};var vo=(e,t)=>{let r=gt(e.field,t),n=Zf(e,t),o=n.type==="value"?n.value:void 0,a=n.type==="column"?n.sql:void 0;switch(e.operator){case f.equals:return a!==void 0?`${r} = ${a}`:o===null?`${r} IS NULL`:`${r} = ${$(t,o)}`;case f.notEquals:return a!==void 0?`${r} <> ${a}`:o===null?`${r} IS NOT NULL`:`${r} <> ${$(t,o)}`;case f.lessThan:return a!==void 0?`${r} < ${a}`:`${r} < ${$(t,o)}`;case f.lessThanEquals:return a!==void 0?`${r} <= ${a}`:`${r} <= ${$(t,o)}`;case f.greaterThan:return a!==void 0?`${r} > ${a}`:`${r} > ${$(t,o)}`;case f.greaterThanEquals:return a!==void 0?`${r} >= ${a}`:`${r} >= ${$(t,o)}`;case f.in:return !Array.isArray(o)||o.length===0?"FALSE":`${r} = ANY(${$(t,o)})`;case f.notIn:return !Array.isArray(o)||o.length===0?"TRUE":`${r} <> ALL(${$(t,o)})`;case f.contains:return `${r} LIKE ${$(t,`%${Le(String(o))}%`)}`;case f.notContains:return `${r} NOT LIKE ${$(t,`%${Le(String(o))}%`)}`;case f.startsWith:return `${r} LIKE ${$(t,`${Le(String(o))}%`)}`;case f.endsWith:return `${r} LIKE ${$(t,`%${Le(String(o))}`)}`;case f.matches:return `${r} ~ ${$(t,o)}`;case f.notMatches:return `${r} !~ ${$(t,o)}`;case f.between:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("between operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} BETWEEN ${$(t,s)} AND ${$(t,l)}`}case f.notBetween:{let i=o;if(!Array.isArray(i)||i.length!==2)throw new Error("notBetween operator requires an array of two values");let[s,l]=i[0]<=i[1]?i:[i[1],i[0]];return `${r} NOT BETWEEN ${$(t,s)} AND ${$(t,l)}`}case f.isEmpty:return `(${r} IS NULL OR ${r} = '')`;case f.notEmpty:return `(${r} IS NOT NULL AND ${r} <> '')`;case f.exists:return `${r} IS NOT NULL`;case f.notExists:return `${r} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},Zf=(e,t)=>{if(e.value!==void 0)return {type:"value",value:e.value};if(e.path){if(e.path.startsWith("$.")){let r=e.path.substring(2);return {type:"column",sql:t.currentAlias?`${A(t.currentAlias)}.${A(r)}`:F(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options when calling toSql().`);return {type:"value",value:E(t.context,e.path)}}return {type:"value",value:void 0}};var _e,Eo=e=>{_e=e;},eu=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return false;let s=i.fields[n[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},tu=(e,t,r)=>{let n=e.split("."),o=r;for(let a of n){let i=t.models[o]?.fields[a];if(!i||i.kind!=="object")return null;o=i.type;}return o},K=(e,t)=>{if(typeof e=="boolean"||!t.map||!t.currentModel)return false;if("all"in e)return e.all.some(r=>K(r,t));if("any"in e)return e.any.some(r=>K(r,t));if("if"in e)return K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t);if("field"in e&&typeof e.field=="string"&&e.field!==""){if(eu(e.field,t.map,t.currentModel))return true;if("condition"in e&&e.condition!==void 0){let r=tu(e.field,t.map,t.currentModel);if(r&&K(e.condition,{...t,currentModel:r}))return true}}return false},Ro=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(n=>_e(n,t)).join(" AND ")})`,So=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(n=>_e(n,t)).join(" OR ")})`,ko=(e,t)=>{if(K(e.if,t)||K(e.then,t)||e.else!==void 0&&K(e.else,t))return "TRUE";let r=_e(e.if,t),n=_e(e.then,t);if(e.else!==void 0){let o=_e(e.else,t);return `((NOT(${r}) OR ${n}) AND (${r} OR ${o}))`}return `(NOT(${r}) OR ${n})`};var ru=(e,t,r)=>{let n=e.split("."),o=r;for(let a=0;a<n.length;a++){let i=t.models[o];if(!i)return false;let s=i.fields[n[a]];if(!s)return false;if(s.kind==="bridge")return true;if(s.kind==="object"){o=s.type;continue}return false}return false},Lt=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("field"in e&&typeof e.field=="string"&&t.map&&t.currentModel&&ru(e.field,t.map,t.currentModel))return "TRUE";if("all"in e)return Ro(e,t);if("any"in e)return So(e,t);if("if"in e)return ko(e,t);if("arrayOperator"in e)return bo(e,t);if("dateOperator"in e)return Ao(e,t);if("aggregate"in e)return xo(e,t);if("field"in e)return vo(e,t);throw new Error("Unknown condition type")};Eo(Lt);var bx=(e,t)=>{let r=!!(t?.map&&t?.model),n=t?.alias??(r?"t0":void 0),o={params:[],paramIndex:0,context:t?.context,map:t?.map,currentModel:t?.model,currentAlias:n,joinCounter:r?{n:0}:void 0,joins:r?[]:void 0,joinRegistry:r?new Map:void 0};return {sql:Lt(e,o),params:o.params,joins:o.joins??[]}};var nu=new Set(Object.keys(B)),ou=new Set(Object.keys(re)),au=new Set(Object.keys(te)),iu=(e,t={})=>{let r={target:t.target??"check",errors:[]};return ne(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},vx=(e,t={})=>{let r=iu(e,t);if(r.ok)return;let n=r.errors.map(o=>`${o.path}: ${o.message}`).join(`
|
|
6
6
|
`);throw new Error(`Invalid rule:
|
|
7
|
-
${
|
|
7
|
+
${n}`)},ne=(e,t,r)=>{if(typeof e=="boolean"){r.target==="toPrisma"&&e===false&&O(r,t,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!To(e)){O(r,t,"invalid_condition","Condition must be a boolean or object");return}let n=su(e);if(!n){O(r,t,"ambiguous_condition","Condition must be exactly one of: field rule, array rule, date rule, all, any, or if/then[/else]");return}switch(n){case "all":Mo(e.all,`${t}.all`,r);break;case "any":Mo(e.any,`${t}.any`,r);break;case "if":ne(e.if,`${t}.if`,r),ne(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&ne(e.else,`${t}.else`,r);break;case "field":lu(e,t,r);break;case "aggregate":uu(e,t,r);break;case "array":pu(e,t,r);break;case "date":du(e,t,r);break}},su=e=>{let t=[];"all"in e&&t.push("all"),"any"in e&&t.push("any"),("if"in e||"then"in e||"else"in e)&&t.push("if"),"arrayOperator"in e&&t.push("array"),"dateOperator"in e&&t.push("date"),"aggregate"in e?t.push("aggregate"):"operator"in e&&t.push("field");let r=Array.from(new Set(t));return r.length!==1?null:r[0]},Mo=(e,t,r)=>{if(!Array.isArray(e)){O(r,t,"logical_array_required","Logical operator requires an array of conditions");return}e.forEach((n,o)=>{ne(n,`${t}[${o}]`,r);});},lu=(e,t,r)=>{if(typeof e.field!="string"&&O(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!nu.has(e.operator)){O(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;dt(n,r.target)||O(r,`${t}.operator`,`unsupported_${Wt(r.target)}_operator`,`Operator '${n}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&O(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let o=Dt(n);if(o==="none"){mu(e,t,r);return}Vt(e,t,r)&&("path"in e&&typeof e.path=="string"||fu(o,e.value,n,`${t}.value`,r));},fu=(e,t,r,n,o)=>{switch(e){case "scalar":case "string":e==="string"&&typeof t!="string"&&O(o,n,"invalid_string_value",`Operator '${r}' requires a string value`);return;case "ordered":It(t)||O(o,n,"invalid_ordered_value",`Operator '${r}' requires a string, number, or Date value`);return;case "array":Array.isArray(t)||O(o,n,"invalid_membership_value",`Operator '${r}' requires an array value`);return;case "pattern":typeof t=="string"||t instanceof RegExp||O(o,n,"invalid_pattern_value",`Operator '${r}' requires a string or RegExp value`);return;case "range":cu(t)||O(o,n,"invalid_range_value",`Operator '${r}' requires a two-item range`);return}},uu=(e,t,r)=>{if(typeof e.field!="string"&&O(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!To(e.aggregate)){O(r,`${t}.aggregate`,"invalid_aggregate","aggregate must be an object");return}let n=e.aggregate;n.mode!=="sum"&&n.mode!=="avg"&&O(r,`${t}.aggregate.mode`,"invalid_aggregate_mode","aggregate.mode must be 'sum' or 'avg'"),"field"in n&&n.field!==void 0&&typeof n.field!="string"&&O(r,`${t}.aggregate.field`,"invalid_aggregate_field","aggregate.field must be a string");let o=typeof e.operator=="string"&&Xn(e.operator),a=typeof e.operator=="string"&&Zn(e.operator);if(!o&&!a){O(r,`${t}.operator`,"invalid_aggregate_operator","Aggregate rules only support: equals, notEquals, lessThan, lessThanEquals, greaterThan, greaterThanEquals, between, notBetween");return}if(r.target==="toPrisma"&&e.operator===f.notBetween&&O(r,`${t}.operator`,"unsupported_prisma_aggregate_operator","Operator 'notBetween' is not supported by toPrisma() for aggregate rules"),r.target==="toPrisma"&&typeof e.path=="string"&&O(r,`${t}.path`,"unsupported_prisma_aggregate_path","path is not supported by toPrisma() for aggregate rules; use value instead"),"condition"in e&&e.condition!==void 0&&(r.target==="toSql"&&O(r,`${t}.condition`,"unsupported_sql_aggregate_condition","Aggregate condition filtering is not supported by toSql(); use check() or toPrisma()"),ne(e.condition,`${t}.condition`,r)),!Vt(e,t,r)||"path"in e&&typeof e.path=="string")return;let i=e.value;a?gu(i)||O(r,`${t}.value`,"invalid_range_value",`Operator '${e.operator}' requires a two-item numeric range`):typeof i!="number"&&O(r,`${t}.value`,"invalid_aggregate_value","Aggregate rule value must be a number");},pu=(e,t,r)=>{if(typeof e.field!="string"&&r.target!=="check"&&O(r,`${t}.field`,"field_required","Array rule requires a string field for this target"),typeof e.arrayOperator!="string"||!ou.has(e.arrayOperator)){O(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(dt(n,r.target)||O(r,`${t}.arrayOperator`,`unsupported_${Wt(r.target)}_array_operator`,`Array operator '${n}' is not supported by ${r.target}()`),n){case h.empty:case h.notEmpty:"condition"in e&&e.condition!==void 0&&O(r,`${t}.condition`,"unexpected_condition",`Array operator '${n}' does not accept condition`),"count"in e&&e.count!==void 0&&O(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case h.all:case h.any:case h.none:!("condition"in e)||e.condition===void 0?O(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition`):ne(e.condition,`${t}.condition`,r),"count"in e&&e.count!==void 0&&O(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case h.atLeast:case h.atMost:case h.exactly:r.target!=="toPrisma"&&typeof e.count!="number"?O(r,`${t}.count`,"missing_count",`Array operator '${n}' requires count`):"count"in e&&e.count!==void 0&&typeof e.count!="number"&&O(r,`${t}.count`,"invalid_count","count must be a number"),r.target==="check"&&(!("condition"in e)||e.condition===void 0)?O(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition for check()`):"condition"in e&&e.condition!==void 0&&ne(e.condition,`${t}.condition`,r);break}},du=(e,t,r)=>{if(typeof e.field!="string"&&O(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!au.has(e.dateOperator)){O(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;dt(n,r.target)||O(r,`${t}.dateOperator`,`unsupported_${Wt(r.target)}_date_operator`,`Date operator '${n}' is not supported by ${r.target}()`),r.target==="toPrisma"&&typeof e.path=="string"&&e.path.startsWith("$.")&&O(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`);let o=Dt(n);if(o==="dayList"){(!Array.isArray(e.value)||!e.value.every(a=>typeof a=="string"))&&O(r,`${t}.value`,"invalid_day_list",`Date operator '${n}' requires an array of day names`),"path"in e&&e.path!==void 0&&O(r,`${t}.path`,"unexpected_path",`Date operator '${n}' does not accept path`);return}if(Vt(e,t,r)&&!("path"in e&&typeof e.path=="string")){if(o==="dateRange"){yu(e.value)||O(r,`${t}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return}jt(e.value)||O(r,`${t}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},Vt=(e,t,r)=>{let n="value"in e&&e.value!==void 0,o=typeof e.path=="string";return n&&o?(O(r,t,"ambiguous_value_source","Rule cannot define both value and path"),false):!n&&!o?(O(r,t,"missing_value_source","Rule requires either value or path"),false):true},mu=(e,t,r)=>{"value"in e&&e.value!==void 0&&O(r,`${t}.value`,"unexpected_value","Rule does not accept value"),"path"in e&&e.path!==void 0&&O(r,`${t}.path`,"unexpected_path","Rule does not accept path");},Wt=e=>e==="toPrisma"?"prisma":e==="toSql"?"sql":"check",To=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),It=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,cu=e=>Array.isArray(e)&&e.length===2&&It(e[0])&&It(e[1]),gu=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",jt=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,yu=e=>Array.isArray(e)&&e.length===2&&jt(e[0])&&jt(e[1]),O=(e,t,r,n)=>{e.errors.push({path:t,code:r,message:n});};/*! Bundled license information:
|
|
8
8
|
|
|
9
9
|
lodash-es/lodash.js:
|
|
10
10
|
(**
|
|
@@ -16,5 +16,5 @@ lodash-es/lodash.js:
|
|
|
16
16
|
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>
|
|
17
17
|
* Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
|
|
18
18
|
*)
|
|
19
|
-
*/exports.AGGREGATE_OPERATORS=
|
|
19
|
+
*/exports.AGGREGATE_OPERATORS=Hh;exports.ALL_KINDS=Yn;exports.ARRAY_OPERATOR_CATALOG=re;exports.ArrayOperator=h;exports.DATE_OPERATOR_CATALOG=te;exports.DateOperator=x;exports.EQUATABLE_KINDS=ut;exports.FIELD_OPERATOR_CATALOG=B;exports.FieldKind=Rf;exports.NUMERIC_KINDS=Sf;exports.ORDERABLE_KINDS=Me;exports.Operator=f;exports.RuleTarget=Kh;exports.STRINGY_KINDS=ee;exports.ValueShape=zh;exports.applyLens=xf;exports.assertValidRule=vx;exports.buildBridgeDictionary=lf;exports.check=le;exports.checkRuleAgainstLens=Pt;exports.createLens=Of;exports.executePrismaQueryPlan=Wf;exports.getArrayOperators=Qh;exports.getOperatorsForKind=Jh;exports.getValueShape=Dt;exports.isAggregateRangeOperator=Zn;exports.isAggregateSingleOperator=Xn;exports.isOperatorSupportedForTarget=dt;exports.projectNarrowing=Ef;exports.stitchFieldMaps=Tt;exports.toPrisma=Fw;exports.toSql=bx;exports.validateFieldMap=uf;exports.validateFieldMapSet=In;exports.validateNarrowing=vf;exports.validateRule=iu;//# sourceMappingURL=index.cjs.map
|
|
20
20
|
//# sourceMappingURL=index.cjs.map
|