@inixiative/json-rules 1.3.1 → 1.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.d.cts CHANGED
@@ -128,27 +128,29 @@ type StrictDateDayRule = (DateRuleBase<DateOperatorValues['dayIn']> & {
128
128
  path?: never;
129
129
  });
130
130
  type StrictDateRule = StrictDateComparisonRule | StrictDateRangeRule | StrictDateDayRule;
131
- type AggregateRuleBase = {
131
+ type AggregateRuleBase<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
132
132
  field: string;
133
133
  aggregate: {
134
134
  mode: AggregateMode;
135
135
  field?: string;
136
136
  };
137
+ condition?: StrictCondition<TRuleValue, TDateValue>;
137
138
  error?: string;
138
139
  };
139
140
  type AggregateSingleOperator = OperatorValues['equals'] | OperatorValues['notEquals'] | OperatorValues['lessThan'] | OperatorValues['lessThanEquals'] | OperatorValues['greaterThan'] | OperatorValues['greaterThanEquals'];
140
141
  type AggregateRangeOperator = OperatorValues['between'] | OperatorValues['notBetween'];
141
- type StrictAggregateRule = (AggregateRuleBase & {
142
+ type StrictAggregateRule<TRuleValue = RuleValue, TDateValue = DateRuleValue> = (AggregateRuleBase<TRuleValue, TDateValue> & {
142
143
  operator: AggregateSingleOperator;
143
- } & ValueSource<number>) | (AggregateRuleBase & {
144
+ } & ValueSource<number>) | (AggregateRuleBase<TRuleValue, TDateValue> & {
144
145
  operator: AggregateRangeOperator;
145
146
  } & ValueSource<[number, number]>);
146
- type AggregateRule = {
147
+ type AggregateRule<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
147
148
  field: string;
148
149
  aggregate: {
149
150
  mode: AggregateMode;
150
151
  field?: string;
151
152
  };
153
+ condition?: Condition<TRuleValue, TDateValue>;
152
154
  operator: Operator;
153
155
  value?: number | [number, number];
154
156
  path?: string;
@@ -189,7 +191,7 @@ type IfThenElse<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
189
191
  else?: Condition<TRuleValue, TDateValue>;
190
192
  error?: string;
191
193
  };
192
- type Condition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = Rule<TRuleValue> | AggregateRule | ArrayRule<TRuleValue, TDateValue> | DateRule<TDateValue> | All<TRuleValue, TDateValue> | Any<TRuleValue, TDateValue> | IfThenElse<TRuleValue, TDateValue> | boolean;
194
+ type Condition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = Rule<TRuleValue> | AggregateRule<TRuleValue, TDateValue> | ArrayRule<TRuleValue, TDateValue> | DateRule<TDateValue> | All<TRuleValue, TDateValue> | Any<TRuleValue, TDateValue> | IfThenElse<TRuleValue, TDateValue> | boolean;
193
195
  type StrictAll<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
194
196
  all: StrictCondition<TRuleValue, TDateValue>[];
195
197
  error?: string;
@@ -204,7 +206,7 @@ type StrictIfThenElse<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
204
206
  else?: StrictCondition<TRuleValue, TDateValue>;
205
207
  error?: string;
206
208
  };
207
- type StrictCondition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = StrictRule<TRuleValue> | StrictAggregateRule | StrictArrayRule<TRuleValue, TDateValue> | StrictDateRule | StrictAll<TRuleValue, TDateValue> | StrictAny<TRuleValue, TDateValue> | StrictIfThenElse<TRuleValue, TDateValue> | boolean;
209
+ type StrictCondition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = StrictRule<TRuleValue> | StrictAggregateRule<TRuleValue, TDateValue> | StrictArrayRule<TRuleValue, TDateValue> | StrictDateRule | StrictAll<TRuleValue, TDateValue> | StrictAny<TRuleValue, TDateValue> | StrictIfThenElse<TRuleValue, TDateValue> | boolean;
208
210
 
209
211
  declare const check: <TData extends Record<string, unknown>>(conditions: Condition, data: TData, context?: TData) => boolean | string;
210
212
 
package/dist/index.d.ts CHANGED
@@ -128,27 +128,29 @@ type StrictDateDayRule = (DateRuleBase<DateOperatorValues['dayIn']> & {
128
128
  path?: never;
129
129
  });
130
130
  type StrictDateRule = StrictDateComparisonRule | StrictDateRangeRule | StrictDateDayRule;
131
- type AggregateRuleBase = {
131
+ type AggregateRuleBase<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
132
132
  field: string;
133
133
  aggregate: {
134
134
  mode: AggregateMode;
135
135
  field?: string;
136
136
  };
137
+ condition?: StrictCondition<TRuleValue, TDateValue>;
137
138
  error?: string;
138
139
  };
139
140
  type AggregateSingleOperator = OperatorValues['equals'] | OperatorValues['notEquals'] | OperatorValues['lessThan'] | OperatorValues['lessThanEquals'] | OperatorValues['greaterThan'] | OperatorValues['greaterThanEquals'];
140
141
  type AggregateRangeOperator = OperatorValues['between'] | OperatorValues['notBetween'];
141
- type StrictAggregateRule = (AggregateRuleBase & {
142
+ type StrictAggregateRule<TRuleValue = RuleValue, TDateValue = DateRuleValue> = (AggregateRuleBase<TRuleValue, TDateValue> & {
142
143
  operator: AggregateSingleOperator;
143
- } & ValueSource<number>) | (AggregateRuleBase & {
144
+ } & ValueSource<number>) | (AggregateRuleBase<TRuleValue, TDateValue> & {
144
145
  operator: AggregateRangeOperator;
145
146
  } & ValueSource<[number, number]>);
146
- type AggregateRule = {
147
+ type AggregateRule<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
147
148
  field: string;
148
149
  aggregate: {
149
150
  mode: AggregateMode;
150
151
  field?: string;
151
152
  };
153
+ condition?: Condition<TRuleValue, TDateValue>;
152
154
  operator: Operator;
153
155
  value?: number | [number, number];
154
156
  path?: string;
@@ -189,7 +191,7 @@ type IfThenElse<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
189
191
  else?: Condition<TRuleValue, TDateValue>;
190
192
  error?: string;
191
193
  };
192
- type Condition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = Rule<TRuleValue> | AggregateRule | ArrayRule<TRuleValue, TDateValue> | DateRule<TDateValue> | All<TRuleValue, TDateValue> | Any<TRuleValue, TDateValue> | IfThenElse<TRuleValue, TDateValue> | boolean;
194
+ type Condition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = Rule<TRuleValue> | AggregateRule<TRuleValue, TDateValue> | ArrayRule<TRuleValue, TDateValue> | DateRule<TDateValue> | All<TRuleValue, TDateValue> | Any<TRuleValue, TDateValue> | IfThenElse<TRuleValue, TDateValue> | boolean;
193
195
  type StrictAll<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
194
196
  all: StrictCondition<TRuleValue, TDateValue>[];
195
197
  error?: string;
@@ -204,7 +206,7 @@ type StrictIfThenElse<TRuleValue = RuleValue, TDateValue = DateRuleValue> = {
204
206
  else?: StrictCondition<TRuleValue, TDateValue>;
205
207
  error?: string;
206
208
  };
207
- type StrictCondition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = StrictRule<TRuleValue> | StrictAggregateRule | StrictArrayRule<TRuleValue, TDateValue> | StrictDateRule | StrictAll<TRuleValue, TDateValue> | StrictAny<TRuleValue, TDateValue> | StrictIfThenElse<TRuleValue, TDateValue> | boolean;
209
+ type StrictCondition<TRuleValue = RuleValue, TDateValue = DateRuleValue> = StrictRule<TRuleValue> | StrictAggregateRule<TRuleValue, TDateValue> | StrictArrayRule<TRuleValue, TDateValue> | StrictDateRule | StrictAll<TRuleValue, TDateValue> | StrictAny<TRuleValue, TDateValue> | StrictIfThenElse<TRuleValue, TDateValue> | boolean;
208
210
 
209
211
  declare const check: <TData extends Record<string, unknown>>(conditions: Condition, data: TData, context?: TData) => boolean | string;
210
212
 
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import {get,some,isObject,isEmpty}from'lodash';import A from'dayjs';import _e from'dayjs/plugin/isSameOrAfter';import Ie from'dayjs/plugin/isSameOrBefore';import Ne from'dayjs/plugin/timezone';import Me from'dayjs/plugin/utc';import {escapeIdentifier}from'pg';var i={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"},d={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},c={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};A.extend(Me);A.extend(Ne);A.extend(Ie);A.extend(_e);var Y=(e,r,t)=>{let n=get(r,e.field);if(!n)throw new Error(`${e.field} is null or undefined`);if(!U(n))throw new Error(`${e.field} is not a valid date: ${String(n)}`);let a=A(n);if(!a.isValid())throw new Error(`${e.field} is not a valid date: ${n}`);let o=p=>e.error||`${e.field} ${p}`,s=Le(e,r,t,a,n),u=s[0],l=s[1];switch(e.dateOperator){case c.before:return a.isBefore(u)||o(`must be before ${u.format()}`);case c.after:return a.isAfter(u)||o(`must be after ${u.format()}`);case c.onOrBefore:return a.isSameOrBefore(u)||o(`must be on or before ${u.format()}`);case c.onOrAfter:return a.isSameOrAfter(u)||o(`must be on or after ${u.format()}`);case c.between:{if(!l)throw new Error("between operator requires an end date");return a.isSameOrAfter(u)&&a.isSameOrBefore(l)||o(`must be between ${u.format()} and ${l?.format()}`)}case c.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return a.isBefore(u)||a.isAfter(l)||o(`must not be between ${u.format()} and ${l?.format()}`)}case c.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let p=a.format("dddd").toLowerCase(),f=e.value.map(y=>String(y).toLowerCase());return f.includes(p)||o(`must be on ${f.join(" or ")}`)}case c.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let p=a.format("dddd").toLowerCase(),f=e.value.map(y=>String(y).toLowerCase());return !f.includes(p)||o(`must not be on ${f.join(" or ")}`)}default:throw new Error("Unknown date operator")}},Le=(e,r,t,n,a)=>{if([c.between,c.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[u,l]=e.value,p=W(u,a),f=W(l,a);if(!p.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!f.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[y,h]=p.isBefore(f)||p.isSame(f)?[p,f]:[f,p];return [y,h]}if([c.before,c.after,c.onOrBefore,c.onOrAfter].includes(e.dateOperator)){let u;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);u=e.value;}else if(e.path)if(e.path.startsWith("$.")){let p=get(r,e.path.substring(2));u=U(p)?p:void 0;}else {let p=get(t,e.path);u=U(p)?p:void 0;}else throw new Error("No value or path specified for date comparison");let l=W(u,a);if(!l.isValid())throw new Error(`Invalid comparison date: ${u}`);return [l,void 0]}return [A(),void 0]},W=(e,r)=>{let t=String(e);if(t.includes("Z")||t.includes("T")&&(t.includes("+")||t.match(/T.*-\d{2}:/)))return A(e);let a=String(r),o=0;if(a.includes("+")||a.includes("T")&&a.match(/T.*-\d{2}:/)){let u=a.match(/([+-])(\d{2}):(\d{2})/);u&&(o=(u[1]==="+"?1:-1)*(parseInt(u[2],10)*60+parseInt(u[3],10)));}else a.includes("Z")||(o=0);return t.match(/^\d{4}-\d{2}-\d{2}$/)?A(`${e}T00:00:00`).subtract(o,"minute"):A(e).subtract(o,"minute")},U=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var ne=(e,r,t)=>{let n=get(r,e.field),o=![i.isEmpty,i.notEmpty,i.exists,i.notExists].includes(e.operator),s=o?Ve(e,r,t):void 0,u=l=>e.error||`${e.field} ${l}${o?` ${JSON.stringify(s)}`:""}`;switch(e.operator){case i.equals:return n===s||u("must equal");case i.notEquals:return n!==s||u("must not equal");case i.lessThan:return x(n,s,"lt")||u("must be less than");case i.lessThanEquals:return x(n,s,"lte")||u("must be less than or equal to");case i.greaterThan:return x(n,s,"gt")||u("must be greater than");case i.greaterThanEquals:return x(n,s,"gte")||u("must be greater than or equal to");case i.in:return Array.isArray(s)&&s.includes(n)||u("must be one of");case i.notIn:return !Array.isArray(s)||!s.includes(n)||u("must not be one of");case i.contains:return te(n,s)||u("must contain");case i.notContains:return !te(n,s)||u("must not contain");case i.matches:return ee(n)&&(s instanceof RegExp||typeof s=="string")&&!!n.match(s)||u("must match pattern");case i.notMatches:return !ee(n)||!(s instanceof RegExp||typeof s=="string")||!n.match(s)||u("must not match pattern");case i.between:{let l=re(s);if(!l)throw new Error("between operator requires an array of two values");if(!q(n))return u("must be between");let p=k(n),[f,y]=l;return p>=f&&p<=y||u("must be between")}case i.notBetween:{let l=re(s);if(!l)throw new Error("notBetween operator requires an array of two values");if(!q(n))return true;let p=k(n),[f,y]=l;return p<f||p>y||u("must not be between")}case i.isEmpty:return isEmpty(n)||u("must be empty");case i.notEmpty:return !isEmpty(n)||u("must not be empty");case i.exists:return n!==void 0||u("must exist");case i.notExists:return n===void 0||u("must not exist");case i.startsWith:return typeof n=="string"&&typeof s=="string"&&n.startsWith(s)||u("must start with");case i.endsWith:return typeof n=="string"&&typeof s=="string"&&n.endsWith(s)||u("must end with");default:throw new Error("Unknown operator")}},Ve=(e,r,t)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?get(r,e.path.substring(2)):get(t,e.path);throw new Error("No value or path specified")},q=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,k=e=>e instanceof Date?e.getTime():e,x=(e,r,t)=>{if(!q(e)||!q(r))return false;let n=k(e),a=k(r);switch(t){case "lt":return n<a;case "lte":return n<=a;case "gt":return n>a;case "gte":return n>=a}},ee=e=>typeof e=="string",re=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[r,t]=e;if(!q(r)||!q(t))return null;let n=k(r),a=k(t);return n<=a?[n,a]:[a,n]},te=(e,r)=>typeof e=="string"?typeof r=="string"&&e.includes(r):Array.isArray(e)?e.includes(r):false;var S=(e,r,t=r)=>typeof e=="boolean"?e:"all"in e?Ue(e.all,r,t,e.error):"any"in e?Ge(e.any,r,t,e.error):"arrayOperator"in e?ze(e,r,t):"dateOperator"in e?Y(e,r,t):"aggregate"in e?Je(e,r,t):"field"in e?ne(e,r,t):"if"in e?Ke(e,r,t):false,Ue=(e,r,t,n)=>{let a=[];for(let o of e){let s=S(o,r,t);s!==true&&(typeof s=="string"?a.push(s):a.push("false"));}return a.length?n||(a.length===1?a[0]:`All conditions must pass: ${a.join(" AND ")}`):true},Ge=(e,r,t,n)=>{let a=[];for(let o of e){let s=S(o,r,t);if(s===true)return true;typeof s=="string"&&a.push(s);}return n||(a.length===1?a[0]:`At least one condition must pass: ${a.join(" OR ")}`)},Ke=(e,r,t)=>S(e.if,r,t)===true?S(e.then,r,t):e.else?S(e.else,r,t):true,Je=(e,r,t)=>{let n=get(r,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let{mode:a,field:o}=e.aggregate,s=n.map((f,y)=>{let h=o?get(f,o):f;if(typeof h!="number"||!isFinite(h)){let $=`${e.field}[${y}]${o?`.${o}`:""}`;throw new Error(`${$} must be a finite number`)}return h}),u;if(a==="sum"?u=s.reduce((f,y)=>f+y,0):u=s.length===0?null:s.reduce((f,y)=>f+y,0)/s.length,u===null)return e.error||`${e.field} ${a} comparison failed (empty array)`;let l;if(e.value!==void 0)l=e.value;else if(e.path)l=e.path.startsWith("$.")?get(r,e.path.substring(2)):get(t,e.path);else throw new Error("Aggregate rule requires value or path");let p=f=>e.error||`${e.field} ${a} ${f} ${JSON.stringify(l)}`;switch(e.operator){case i.equals:return u===l||p("must equal");case i.notEquals:return u!==l||p("must not equal");case i.lessThan:return typeof l=="number"&&u<l||p("must be less than");case i.lessThanEquals:return typeof l=="number"&&u<=l||p("must be less than or equal to");case i.greaterThan:return typeof l=="number"&&u>l||p("must be greater than");case i.greaterThanEquals:return typeof l=="number"&&u>=l||p("must be greater than or equal to");case i.between:{if(!Array.isArray(l)||l.length!==2)throw new Error("between requires a two-element array");let[f,y]=l,[h,$]=f<=y?[f,y]:[y,f];return u>=h&&u<=$||p("must be between")}case i.notBetween:{if(!Array.isArray(l)||l.length!==2)throw new Error("notBetween requires a two-element array");let[f,y]=l,[h,$]=f<=y?[f,y]:[y,f];return u<h||u>$||p("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},ze=(e,r,t)=>{let n=get(r,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let a=y=>e.error||`${e.field} ${y}`,o=[d.all,d.any,d.none,d.atLeast,d.atMost,d.exactly],s=[d.atLeast,d.atMost,d.exactly],u=e.condition;if(o.includes(e.arrayOperator)&&!u)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(s.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let p=0,f=0;if(o.includes(e.arrayOperator)){if(!u)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!some(n,isObject))throw new Error(`${e.field} contains only primitive values. Use 'in' or 'contains' operators instead of array operators for primitive arrays`);let y=n.map(h=>S(u,h,t));p=y.filter(h=>h===true).length,f=y.filter(h=>typeof h=="string").length;}switch(e.arrayOperator){case d.empty:return !n.length||a("must be empty");case d.notEmpty:return !!n.length||a("must not be empty");case d.all:return p===n.length||a(`all elements must match (${f} failed)`);case d.any:return !!p||a("at least one element must match");case d.none:return !p||a(`no elements should match (${p} matched)`);case d.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p>=l||a(`at least ${l} elements must match (${p} matched)`);case d.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p<=l||a(`at most ${l} elements must match (${p} matched)`);case d.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p===l||a(`exactly ${l} elements must match (${p} matched)`);default:throw new Error("Unknown array operator")}};var _=(e,r,t,n)=>{let a=e[r];if(!a)return null;for(let o of Object.values(a.fields))if(o.kind==="object"&&o.type===t&&(o.fromFields?.length??0)>0&&(o.toFields?.length??0)>0&&(n===void 0||o.relationName===n))return o;return null};var ae=(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 Qe(e,r,t)},Qe=(e,r,t)=>{let{map:n,model:a}=r,o=n[a]?.fields[e.field];if(!o||o.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${a}'. Prisma aggregate rules only support relation fields.`);if(!o.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${a}'.`);let s=o.type,u=e.aggregate.field,l=n[s]?.fields[u];if(!l)throw new Error(`aggregate.field '${u}' does not exist on model '${s}'.`);if(l.kind!=="scalar")throw new Error(`aggregate.field '${u}' on model '${s}' must be a scalar field, got '${l.kind}'.`);if(l.type==="Json")throw new Error(`aggregate.field '${u}' on model '${s}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let p,f;if(o.fromFields&&o.fromFields.length>0){if(o.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");p=o.toFields?.[0]??"id",f=o.fromFields[0];}else {let O=_(n,s,a,o.relationName);if(!O)throw new Error(`Cannot determine FK relationship between '${a}' and '${s}'. Ensure the FieldMap contains both sides of the relation.`);if((O.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");p=O.fromFields?.[0]??"",f=O.toFields?.[0]??"";}let h={[e.aggregate.mode==="sum"?"_sum":"_avg"]:{[u]:He(e)}},$={operation:"groupBy",model:s,args:{by:[p],where:{},having:h},extract:p},L=t.steps.length;t.steps.push($);let V={__step:L};return {[f]:{in:V}}},He=e=>{let r=e.value;switch(e.operator){case i.equals:return {equals:r};case i.notEquals:return {not:r};case i.lessThan:return {lt:r};case i.lessThanEquals:return {lte:r};case i.greaterThan:return {gt:r};case i.greaterThanEquals:return {gte:r};case i.between:{if(!Array.isArray(r)||r.length!==2)throw new Error("between requires two values");let[t,n]=r,[a,o]=t<=n?[t,n]:[n,t];return {gte:a,lte:o}}case i.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 oe=(e,r,t,n)=>{let{map:a,model:o}=r,s=a[o]?.fields[e.field];if(!s||s.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${o}'. Count operators require a relation field.`);if(!s.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${o}'. Count operators only apply to one-to-many or many-to-many relations.`);let u=s.type,l,p;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${o}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=s.toFields?.[0]??"id",p=s.fromFields[0];}else {let O=_(a,u,o,s.relationName);if(!O){let xe=Object.values(a[u]?.fields??{}).some(C=>C.kind==="object"&&C.type===o&&C.isList&&!C.fromFields?.length);throw new Error(xe?`'${o}.${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 '${o}' and '${u}'. Ensure the FieldMap contains both sides of the relation.`)}if((O.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${o}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=O.fromFields?.[0]??"",p=O.toFields?.[0]??"";}let f=e.condition?n(e.condition,{...r,model:u},t):{},y=e.count??1,h=Xe(e.arrayOperator,y),$={operation:"groupBy",model:u,args:{by:[l],where:f,having:h},extract:l},L=t.steps.length;t.steps.push($);let V={__step:L};return {[p]:{in:V}}},Xe=(e,r)=>{switch(e){case d.atLeast:return {_count:{_all:{gte:r}}};case d.atMost:return {_count:{_all:{lte:r}}};case d.exactly:return {_count:{_all:{equals:r}}};default:throw new Error("unreachable")}};var R=(e,r)=>{let t=e.split("."),n=r;for(let a=t.length-1;a>=0;a--)n={[t[a]]:n};return n};var F,se=e=>{F=e;},ie=(e,r,t)=>{if(e.arrayOperator===d.atLeast||e.arrayOperator===d.atMost||e.arrayOperator===d.exactly){if(r?.map&&r?.model&&t)return oe(e,r,t,F);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.`)}let n=Ye(e,r,t);return R(e.field,n)},Ye=(e,r,t)=>{switch(e.arrayOperator){case d.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:F(e.condition,r,t)};case d.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:F(e.condition,r,t)};case d.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:F(e.condition,r,t)};case d.empty:return {none:{}};case d.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var pe=(e,r)=>{let t=rr(e,r);return R(e.field,t)},er=(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 get(r.context,e.path)}},rr=(e,r)=>{let t=()=>er(e,r);switch(e.dateOperator){case c.before:return {lt:t()};case c.after:return {gt:t()};case c.onOrBefore:return {lte:t()};case c.onOrAfter:return {gte:t()};case c.between:{let n=t();if(!Array.isArray(n)||n.length!==2)throw new Error("between date operator requires an array of two values");let[a,o]=ue(n);return {gte:a,lte:o}}case c.notBetween:{let n=t();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween date operator requires an array of two values");let[a,o]=ue(n);return {NOT:{gte:a,lte:o}}}case c.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case c.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}`)}},ue=e=>{let[r,t]=e;return tr(r,t)<=0?[r,t]:[t,r]},tr=(e,r)=>{let t=le(e),n=le(r);return t<n?-1:t>n?1:0},le=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var de=(e,r,t)=>{let n=e.split("."),a=t;for(let o=0;o<n.length;o++){let s=r[a];if(!s)return {kind:"fallback"};let u=s.fields[n[o]];if(!u)return {kind:"fallback"};if(u.kind==="scalar"&&u.type==="Json"&&o<n.length-1)return {kind:"json-path",stopIndex:o+1,jsonPath:n.slice(o+1)};if(u.kind==="object"){if(!r[u.type])return {kind:"fallback"};a=u.type;continue}return {kind:"direct"}}return {kind:"direct"}};var fe=(e,r)=>{let t=or(e,r);return sr(e.field,t,r)},ar=(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 get(r.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},or=(e,r)=>{let t=()=>ar(e,r);switch(e.operator){case i.equals:return {equals:t()??null};case i.notEquals:return {not:t()??null};case i.lessThan:return {lt:t()};case i.lessThanEquals:return {lte:t()};case i.greaterThan:return {gt:t()};case i.greaterThanEquals:return {gte:t()};case i.in:return {in:t()};case i.notIn:return {notIn:t()};case i.contains:return {contains:t()};case i.notContains:return {not:{contains:t()}};case i.startsWith:return {startsWith:t()};case i.endsWith:return {endsWith:t()};case i.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case i.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case i.between:{let n=t();if(!Array.isArray(n)||n.length!==2)throw new Error("between operator requires an array of two values");let[a,o]=n[0]<=n[1]?n:[n[1],n[0]];return {gte:a,lte:o}}case i.notBetween:{let n=t();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween operator requires an array of two values");let[a,o]=n[0]<=n[1]?n:[n[1],n[0]];return {NOT:{gte:a,lte:o}}}case i.isEmpty:return {in:[null,""]};case i.notEmpty:return {notIn:[null,""]};case i.exists:return {not:null};case i.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},sr=(e,r,t)=>{if(!t?.map||!t?.model)return R(e,r);let n=de(e,t.map,t.model),a=e.split(".");switch(n.kind){case "fallback":case "direct":return R(e,r);case "json-path":{let o={path:n.jsonPath,...r},s=a.slice(0,n.stopIndex).join(".");return R(s,o)}}};var B,me=e=>{B=e;},ce=(e,r,t)=>e.all.length===0?{}:{AND:e.all.map(n=>B(n,r,t))},ge=(e,r,t)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>B(n,r,t))},ye=(e,r,t)=>{let n=B(e.if,r,t),a={NOT:n},o=B(e.then,r,t);if(e.else){let s=B(e.else,r,t);return {AND:[{OR:[a,o]},{OR:[n,s]}]}}return {OR:[a,o]}};var I=(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 ce(e,r,t);if("any"in e)return ge(e,r,t);if("if"in e)return ye(e,r,t);if("arrayOperator"in e)return ie(e,r,t);if("dateOperator"in e)return pe(e,r);if("aggregate"in e)return ae(e,r,t);if("field"in e)return fe(e,r);throw new Error("Unknown condition type")};me(I);se(I);var ir=async(e,r)=>{let t=e.steps.filter(o=>o.operation==="groupBy"),n=e.steps.find(o=>o.operation==="where");if(!n)throw new Error("executePrismaQueryPlan: result has no where step");let a=[];for(let o of t){let s=o.model.charAt(0).toLowerCase()+o.model.slice(1),u=r[s];if(!u)throw new Error(`executePrismaQueryPlan: no delegate for model '${o.model}'. Ensure prismaDelegate has a key '${s}'.`);let l=await u[o.operation](o.args);a.push(l.map(p=>p[o.extract]));}return K(n.where,a)},K=(e,r)=>{if(e==null)return e;if(Array.isArray(e))return e.map(t=>K(t,r));if(typeof e=="object"){let t=e;if("__step"in t&&typeof t.__step=="number"){let a=t.__step;if(a>=r.length)throw new Error(`Step ref __step: ${a} out of range (${r.length} steps executed)`);return r[a]}let n={};for(let[a,o]of Object.entries(t))n[a]=K(o,r);return n}return e};var Ft=(e,r)=>{let t={steps:[]},n=I(e,r,t);return {steps:[...t.steps,{operation:"where",where:n}]}};var g=(e,r)=>(e.params.push(r),`$${++e.paramIndex}`);var P=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),w=e=>{let r=e.split(".");if(r.length===1)return escapeIdentifier(e);let[t,...n]=r;return n.length===0?escapeIdentifier(t):we(escapeIdentifier(t),n)},he=(e,r)=>{let t=e.split(".");if(t.length===1)return `${escapeIdentifier(r)}.${escapeIdentifier(e)}`;let[n,...a]=t;return we(`${escapeIdentifier(r)}.${escapeIdentifier(n)}`,a)},J=e=>`'${e.replace(/'/g,"''")}'`,we=(e,r)=>{if(r.length===0)return e;let t=r.slice(0,-1).map(J).join("->"),n=J(r[r.length-1]);return t?`${e}->${t}->>${n}`:`${e}->>${n}`},$e=e=>{let r=e.split(".");if(r.length===1)return escapeIdentifier(e);let[t,...n]=r;return n.length===0?escapeIdentifier(t):ur(escapeIdentifier(t),n)},ur=(e,r)=>{let t=r.map(J).join("->");return `${e}->${t}`};var Ee=(e,r)=>{let t=pr(e,r);return fr(t,e,r)},pr=(e,r)=>{let t=$e(e.field),{mode:n,field:a}=e.aggregate,o=n==="sum"?"SUM":"AVG",s=r.map?.[r.currentModel??""]?.fields[e.field];if(s?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(a?.includes("."))throw new Error(`aggregate.field '${a}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(s?.kind==="scalar"&&s?.isList===true){if(a)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${o==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${t}) AS elem)`}if(a){let f=`(elem->>'${a}')::numeric`;return `(SELECT ${o==="SUM"?`COALESCE(SUM(${f}), 0)`:`AVG(${f})`} FROM jsonb_array_elements(${t}) AS elem)`}let l="elem::numeric";return `(SELECT ${o==="SUM"?`COALESCE(SUM(${l}), 0)`:`AVG(${l})`} FROM jsonb_array_elements_text(${t}) AS elem)`},dr=(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?`${escapeIdentifier(r.currentAlias)}.${escapeIdentifier(t)}`:w(t)}}if(!r.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:get(r.context,e.path)}}throw new Error("Aggregate rule requires value or path")},fr=(e,r,t)=>{let n=dr(r,t),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(r.operator){case i.equals:return o?`${e} = ${o}`:a===null?`${e} IS NULL`:`${e} = ${g(t,a)}`;case i.notEquals:return o?`${e} <> ${o}`:a===null?`${e} IS NOT NULL`:`${e} <> ${g(t,a)}`;case i.lessThan:return o?`${e} < ${o}`:`${e} < ${g(t,a)}`;case i.lessThanEquals:return o?`${e} <= ${o}`:`${e} <= ${g(t,a)}`;case i.greaterThan:return o?`${e} > ${o}`:`${e} > ${g(t,a)}`;case i.greaterThanEquals:return o?`${e} >= ${o}`:`${e} >= ${g(t,a)}`;case i.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between requires two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${e} BETWEEN ${g(t,u)} AND ${g(t,l)}`}case i.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween requires two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${e} NOT BETWEEN ${g(t,u)} AND ${g(t,l)}`}default:throw new Error(`Operator '${r.operator}' is not supported for aggregate rules`)}};var Oe=(e,r)=>{let t=w(e.field),n=r.map?.[r.currentModel??""]?.fields[e.field],a=n?.kind==="scalar"&&n?.isList===true,o=a?`array_length(${t}, 1)`:`jsonb_array_length(${t})`;switch(e.arrayOperator){case d.empty:return a?`(${t} IS NULL OR ${o} IS NULL)`:`(${t} IS NULL OR ${o} = 0)`;case d.notEmpty:return a?`(${t} IS NOT NULL AND ${o} IS NOT NULL)`:`(${t} IS NOT NULL AND ${o} > 0)`;case d.all:case d.any:case d.none:case d.atLeast:case d.atMost:case d.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 z=e=>{let r={sunday:0,monday:1,tuesday:2,wednesday:3,thursday:4,friday:5,saturday:6};return e.map(t=>{let n=r[t.toLowerCase()];if(n===void 0)throw new Error(`Unknown day name: ${t}`);return n})};var N=(e,r)=>{if(!r.map||!r.currentModel||!r.currentAlias)return w(e);let t=e.split("."),n=r.currentModel,a=r.currentAlias;for(let o=0;o<t.length;o++){let s=r.map[n];if(!s)return w(e);let u=s.fields[t[o]];if(!u)return w(e);if(u.kind==="object"){let p=`${a}.${t[o]}`,f=r.joinRegistry?.get(p),y;if(f)y=f;else {let h=r.joinCounter;if(!h)return w(e);y=`t${++h.n}`;let $=mr(r.map,n,a,u,y);if(!$)return w(e);r.joins?.push($),r.joinRegistry?.set(p,y);}n=u.type,a=y;continue}let l=t.slice(o);return he(l.join("."),a)}return w(e)},mr=(e,r,t,n,a)=>{let o=n.type,s=e[o]?.dbName??o,u;if(n.fromFields&&n.fromFields.length>0&&n.toFields&&n.toFields.length>0)u=n.fromFields.map((l,p)=>`${escapeIdentifier(a)}.${escapeIdentifier(n.toFields?.[p]??"")} = ${escapeIdentifier(t)}.${escapeIdentifier(l)}`).join(" AND ");else {let l=cr(e,o,r,n.relationName);if(!l)return null;u=(l.fromFields??[]).map((p,f)=>`${escapeIdentifier(a)}.${escapeIdentifier(p)} = ${escapeIdentifier(t)}.${escapeIdentifier(l.toFields?.[f]??"")}`).join(" AND ");}return `LEFT JOIN ${escapeIdentifier(s)} AS ${escapeIdentifier(a)} ON ${u}`},cr=(e,r,t,n)=>{let a=e[r];if(!a)return null;for(let o of Object.values(a.fields))if(o.kind==="object"&&o.type===t&&(o.fromFields?.length??0)>0&&(o.toFields?.length??0)>0&&(n===void 0||o.relationName===n))return o;return null};var qe=(e,r)=>{let t=N(e.field,r),n=hr(e,r),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(e.dateOperator){case c.before:return o!==void 0?`${t} < ${o}`:`${t} < ${g(r,a)}`;case c.after:return o!==void 0?`${t} > ${o}`:`${t} > ${g(r,a)}`;case c.onOrBefore:return o!==void 0?`${t} <= ${o}`:`${t} <= ${g(r,a)}`;case c.onOrAfter:return o!==void 0?`${t} >= ${o}`:`${t} >= ${g(r,a)}`;case c.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between date operator requires an array of two values");let[u,l]=Re(s);return `${t} BETWEEN ${g(r,u)} AND ${g(r,l)}`}case c.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween date operator requires an array of two values");let[u,l]=Re(s);return `${t} NOT BETWEEN ${g(r,u)} AND ${g(r,l)}`}case c.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let s=z(e.value.map(u=>String(u)));return `EXTRACT(DOW FROM ${t}) = ANY(${g(r,s)})`}case c.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let s=z(e.value.map(u=>String(u)));return `EXTRACT(DOW FROM ${t}) <> ALL(${g(r,s)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Re=e=>{let[r,t]=e;return yr(r,t)<=0?[r,t]:[t,r]},yr=(e,r)=>{let t=ve(e),n=ve(r);return t<n?-1:t>n?1:0},ve=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),hr=(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?`${escapeIdentifier(r.currentAlias)}.${escapeIdentifier(t)}`:w(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:get(r.context,e.path)}}return {type:"value",value:void 0}};var Se=(e,r)=>{let t=N(e.field,r),n=$r(e,r),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(e.operator){case i.equals:return o!==void 0?`${t} = ${o}`:a===null?`${t} IS NULL`:`${t} = ${g(r,a)}`;case i.notEquals:return o!==void 0?`${t} <> ${o}`:a===null?`${t} IS NOT NULL`:`${t} <> ${g(r,a)}`;case i.lessThan:return o!==void 0?`${t} < ${o}`:`${t} < ${g(r,a)}`;case i.lessThanEquals:return o!==void 0?`${t} <= ${o}`:`${t} <= ${g(r,a)}`;case i.greaterThan:return o!==void 0?`${t} > ${o}`:`${t} > ${g(r,a)}`;case i.greaterThanEquals:return o!==void 0?`${t} >= ${o}`:`${t} >= ${g(r,a)}`;case i.in:return !Array.isArray(a)||a.length===0?"FALSE":`${t} = ANY(${g(r,a)})`;case i.notIn:return !Array.isArray(a)||a.length===0?"TRUE":`${t} <> ALL(${g(r,a)})`;case i.contains:return `${t} LIKE ${g(r,`%${P(String(a))}%`)}`;case i.notContains:return `${t} NOT LIKE ${g(r,`%${P(String(a))}%`)}`;case i.startsWith:return `${t} LIKE ${g(r,`${P(String(a))}%`)}`;case i.endsWith:return `${t} LIKE ${g(r,`%${P(String(a))}`)}`;case i.matches:return `${t} ~ ${g(r,a)}`;case i.notMatches:return `${t} !~ ${g(r,a)}`;case i.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between operator requires an array of two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${t} BETWEEN ${g(r,u)} AND ${g(r,l)}`}case i.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween operator requires an array of two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${t} NOT BETWEEN ${g(r,u)} AND ${g(r,l)}`}case i.isEmpty:return `(${t} IS NULL OR ${t} = '')`;case i.notEmpty:return `(${t} IS NOT NULL AND ${t} <> '')`;case i.exists:return `${t} IS NOT NULL`;case i.notExists:return `${t} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},$r=(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?`${escapeIdentifier(r.currentAlias)}.${escapeIdentifier(t)}`:w(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:get(r.context,e.path)}}return {type:"value",value:void 0}};var T,Be=e=>{T=e;},Te=(e,r)=>e.all.length===0?"TRUE":`(${e.all.map(n=>T(n,r)).join(" AND ")})`,De=(e,r)=>e.any.length===0?"FALSE":`(${e.any.map(n=>T(n,r)).join(" OR ")})`,Fe=(e,r)=>{let t=T(e.if,r),n=T(e.then,r),a=e.else?T(e.else,r):"TRUE";return e.else?`((NOT(${t}) OR ${n}) AND (${t} OR ${a}))`:`(NOT(${t}) OR ${n})`};var Q=(e,r)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("all"in e)return Te(e,r);if("any"in e)return De(e,r);if("if"in e)return Fe(e,r);if("arrayOperator"in e)return Oe(e,r);if("dateOperator"in e)return qe(e,r);if("aggregate"in e)return Ee(e,r);if("field"in e)return Se(e,r);throw new Error("Unknown condition type")};Be(Q);var En=(e,r)=>{let t=!!(r?.map&&r?.model),n=r?.alias??(t?"t0":void 0),a={params:[],paramIndex:0,context:r?.context,map:r?.map,currentModel:r?.model,currentAlias:n,joinCounter:t?{n:0}:void 0,joins:t?[]:void 0,joinRegistry:t?new Map:void 0};return {sql:Q(e,a),params:a.params,joins:a.joins??[]}};var br=new Set(Object.values(i)),Er=new Set(Object.values(d)),Or=new Set(Object.values(c)),Ar=(e,r={})=>{let t={target:r.target??"check",errors:[]};return v(e,"$",t),{ok:t.errors.length===0,errors:t.errors}},Rn=(e,r={})=>{let t=Ar(e,r);if(t.ok)return;let n=t.errors.map(a=>`${a.path}: ${a.message}`).join(`
1
+ import {get,some,isObject,isEmpty}from'lodash';import v from'dayjs';import We from'dayjs/plugin/isSameOrAfter';import je from'dayjs/plugin/isSameOrBefore';import Ue from'dayjs/plugin/timezone';import Ge from'dayjs/plugin/utc';import {escapeIdentifier}from'pg';var i={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"},d={all:"all",any:"any",none:"none",atLeast:"atLeast",atMost:"atMost",exactly:"exactly",empty:"empty",notEmpty:"notEmpty"},g={before:"before",after:"after",onOrBefore:"onOrBefore",onOrAfter:"onOrAfter",between:"between",notBetween:"notBetween",dayIn:"dayIn",dayNotIn:"dayNotIn"};v.extend(Ge);v.extend(Ue);v.extend(je);v.extend(We);var re=(e,t,r)=>{let n=get(t,e.field);if(!n)throw new Error(`${e.field} is null or undefined`);if(!K(n))throw new Error(`${e.field} is not a valid date: ${String(n)}`);let a=v(n);if(!a.isValid())throw new Error(`${e.field} is not a valid date: ${n}`);let o=p=>e.error||`${e.field} ${p}`,s=Ke(e,t,r,a,n),u=s[0],l=s[1];switch(e.dateOperator){case g.before:return a.isBefore(u)||o(`must be before ${u.format()}`);case g.after:return a.isAfter(u)||o(`must be after ${u.format()}`);case g.onOrBefore:return a.isSameOrBefore(u)||o(`must be on or before ${u.format()}`);case g.onOrAfter:return a.isSameOrAfter(u)||o(`must be on or after ${u.format()}`);case g.between:{if(!l)throw new Error("between operator requires an end date");return a.isSameOrAfter(u)&&a.isSameOrBefore(l)||o(`must be between ${u.format()} and ${l?.format()}`)}case g.notBetween:{if(!l)throw new Error("notBetween operator requires an end date");return a.isBefore(u)||a.isAfter(l)||o(`must not be between ${u.format()} and ${l?.format()}`)}case g.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let p=a.format("dddd").toLowerCase(),c=e.value.map(f=>String(f).toLowerCase());return c.includes(p)||o(`must be on ${c.join(" or ")}`)}case g.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let p=a.format("dddd").toLowerCase(),c=e.value.map(f=>String(f).toLowerCase());return !c.includes(p)||o(`must not be on ${c.join(" or ")}`)}default:throw new Error("Unknown date operator")}},Ke=(e,t,r,n,a)=>{if([g.between,g.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[u,l]=e.value,p=U(u,a),c=U(l,a);if(!p.isValid())throw new Error(`Invalid start date: ${e.value[0]}`);if(!c.isValid())throw new Error(`Invalid end date: ${e.value[1]}`);let[f,h]=p.isBefore(c)||p.isSame(c)?[p,c]:[c,p];return [f,h]}if([g.before,g.after,g.onOrBefore,g.onOrAfter].includes(e.dateOperator)){let u;if(e.value!==void 0){if(Array.isArray(e.value))throw new Error(`${e.dateOperator} operator requires a single date value`);u=e.value;}else if(e.path)if(e.path.startsWith("$.")){let p=get(t,e.path.substring(2));u=K(p)?p:void 0;}else {let p=get(r,e.path);u=K(p)?p:void 0;}else throw new Error("No value or path specified for date comparison");let l=U(u,a);if(!l.isValid())throw new Error(`Invalid comparison date: ${u}`);return [l,void 0]}return [v(),void 0]},U=(e,t)=>{let r=String(e);if(r.includes("Z")||r.includes("T")&&(r.includes("+")||r.match(/T.*-\d{2}:/)))return v(e);let a=String(t),o=0;if(a.includes("+")||a.includes("T")&&a.match(/T.*-\d{2}:/)){let u=a.match(/([+-])(\d{2}):(\d{2})/);u&&(o=(u[1]==="+"?1:-1)*(parseInt(u[2],10)*60+parseInt(u[3],10)));}else a.includes("Z")||(o=0);return r.match(/^\d{4}-\d{2}-\d{2}$/)?v(`${e}T00:00:00`).subtract(o,"minute"):v(e).subtract(o,"minute")},K=e=>typeof e=="string"||typeof e=="number"||e instanceof Date;var se=(e,t,r)=>{let n=get(t,e.field),o=![i.isEmpty,i.notEmpty,i.exists,i.notExists].includes(e.operator),s=o?Je(e,t,r):void 0,u=l=>e.error||`${e.field} ${l}${o?` ${JSON.stringify(s)}`:""}`;switch(e.operator){case i.equals:return n===s||u("must equal");case i.notEquals:return n!==s||u("must not equal");case i.lessThan:return M(n,s,"lt")||u("must be less than");case i.lessThanEquals:return M(n,s,"lte")||u("must be less than or equal to");case i.greaterThan:return M(n,s,"gt")||u("must be greater than");case i.greaterThanEquals:return M(n,s,"gte")||u("must be greater than or equal to");case i.in:return Array.isArray(s)&&s.includes(n)||u("must be one of");case i.notIn:return !Array.isArray(s)||!s.includes(n)||u("must not be one of");case i.contains:return oe(n,s)||u("must contain");case i.notContains:return !oe(n,s)||u("must not contain");case i.matches:return ne(n)&&(s instanceof RegExp||typeof s=="string")&&!!n.match(s)||u("must match pattern");case i.notMatches:return !ne(n)||!(s instanceof RegExp||typeof s=="string")||!n.match(s)||u("must not match pattern");case i.between:{let l=ae(s);if(!l)throw new Error("between operator requires an array of two values");if(!B(n))return u("must be between");let p=T(n),[c,f]=l;return p>=c&&p<=f||u("must be between")}case i.notBetween:{let l=ae(s);if(!l)throw new Error("notBetween operator requires an array of two values");if(!B(n))return true;let p=T(n),[c,f]=l;return p<c||p>f||u("must not be between")}case i.isEmpty:return isEmpty(n)||u("must be empty");case i.notEmpty:return !isEmpty(n)||u("must not be empty");case i.exists:return n!==void 0||u("must exist");case i.notExists:return n===void 0||u("must not exist");case i.startsWith:return typeof n=="string"&&typeof s=="string"&&n.startsWith(s)||u("must start with");case i.endsWith:return typeof n=="string"&&typeof s=="string"&&n.endsWith(s)||u("must end with");default:throw new Error("Unknown operator")}},Je=(e,t,r)=>{if(e.value!==void 0)return e.value;if(e.path)return e.path.startsWith("$.")?get(t,e.path.substring(2)):get(r,e.path);throw new Error("No value or path specified")},B=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,T=e=>e instanceof Date?e.getTime():e,M=(e,t,r)=>{if(!B(e)||!B(t))return false;let n=T(e),a=T(t);switch(r){case "lt":return n<a;case "lte":return n<=a;case "gt":return n>a;case "gte":return n>=a}},ne=e=>typeof e=="string",ae=e=>{if(!Array.isArray(e)||e.length!==2)return null;let[t,r]=e;if(!B(t)||!B(r))return null;let n=T(t),a=T(r);return n<=a?[n,a]:[a,n]},oe=(e,t)=>typeof e=="string"?typeof t=="string"&&e.includes(t):Array.isArray(e)?e.includes(t):false;var k=(e,t,r=t)=>typeof e=="boolean"?e:"all"in e?He(e.all,t,r,e.error):"any"in e?Xe(e.any,t,r,e.error):"arrayOperator"in e?er(e,t,r):"dateOperator"in e?re(e,t,r):"aggregate"in e?Ze(e,t,r):"field"in e?se(e,t,r):"if"in e?Ye(e,t,r):false,He=(e,t,r,n)=>{let a=[];for(let o of e){let s=k(o,t,r);s!==true&&(typeof s=="string"?a.push(s):a.push("false"));}return a.length?n||(a.length===1?a[0]:`All conditions must pass: ${a.join(" AND ")}`):true},Xe=(e,t,r,n)=>{let a=[];for(let o of e){let s=k(o,t,r);if(s===true)return true;typeof s=="string"&&a.push(s);}return n||(a.length===1?a[0]:`At least one condition must pass: ${a.join(" OR ")}`)},Ye=(e,t,r)=>k(e.if,t,r)===true?k(e.then,t,r):e.else?k(e.else,t,r):true,Ze=(e,t,r)=>{let n=get(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let a=e.condition?n.filter(f=>k(e.condition,f,r)===true):n,{mode:o,field:s}=e.aggregate,u=a.map((f,h)=>{let $=s?get(f,s):f;if(typeof $!="number"||!Number.isFinite($)){let R=`${e.field}[${h}]${s?`.${s}`:""}`;throw new Error(`${R} must be a finite number`)}return $}),l;if(o==="sum"?l=u.reduce((f,h)=>f+h,0):l=u.length===0?null:u.reduce((f,h)=>f+h,0)/u.length,l===null)return e.error||`${e.field} ${o} comparison failed (empty array)`;let p;if(e.value!==void 0)p=e.value;else if(e.path)p=e.path.startsWith("$.")?get(t,e.path.substring(2)):get(r,e.path);else throw new Error("Aggregate rule requires value or path");let c=f=>e.error||`${e.field} ${o} ${f} ${JSON.stringify(p)}`;switch(e.operator){case i.equals:return l===p||c("must equal");case i.notEquals:return l!==p||c("must not equal");case i.lessThan:return typeof p=="number"&&l<p||c("must be less than");case i.lessThanEquals:return typeof p=="number"&&l<=p||c("must be less than or equal to");case i.greaterThan:return typeof p=="number"&&l>p||c("must be greater than");case i.greaterThanEquals:return typeof p=="number"&&l>=p||c("must be greater than or equal to");case i.between:{if(!Array.isArray(p)||p.length!==2)throw new Error("between requires a two-element array");let[f,h]=p,[$,R]=f<=h?[f,h]:[h,f];return l>=$&&l<=R||c("must be between")}case i.notBetween:{if(!Array.isArray(p)||p.length!==2)throw new Error("notBetween requires a two-element array");let[f,h]=p,[$,R]=f<=h?[f,h]:[h,f];return l<$||l>R||c("must not be between")}default:throw new Error(`Operator '${e.operator}' is not supported for aggregate rules`)}},er=(e,t,r)=>{let n=get(t,e.field);if(!Array.isArray(n))throw new Error(`${e.field} must be an array`);let a=f=>e.error||`${e.field} ${f}`,o=[d.all,d.any,d.none,d.atLeast,d.atMost,d.exactly],s=[d.atLeast,d.atMost,d.exactly],u=e.condition;if(o.includes(e.arrayOperator)&&!u)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);let l=e.count;if(s.includes(e.arrayOperator)&&l===void 0)throw new Error(`${e.arrayOperator} requires a count`);let p=0,c=0;if(o.includes(e.arrayOperator)){if(!u)throw new Error(`${e.arrayOperator} requires a condition to check against array elements`);if(!some(n,isObject))throw new Error(`${e.field} contains only primitive values. Use 'in' or 'contains' operators instead of array operators for primitive arrays`);let f=n.map(h=>k(u,h,r));p=f.filter(h=>h===true).length,c=f.filter(h=>typeof h=="string").length;}switch(e.arrayOperator){case d.empty:return !n.length||a("must be empty");case d.notEmpty:return !!n.length||a("must not be empty");case d.all:return p===n.length||a(`all elements must match (${c} failed)`);case d.any:return !!p||a("at least one element must match");case d.none:return !p||a(`no elements should match (${p} matched)`);case d.atLeast:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p>=l||a(`at least ${l} elements must match (${p} matched)`);case d.atMost:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p<=l||a(`at most ${l} elements must match (${p} matched)`);case d.exactly:if(l===void 0)throw new Error(`${e.arrayOperator} requires a count`);return p===l||a(`exactly ${l} elements must match (${p} matched)`);default:throw new Error("Unknown array operator")}};var L=(e,t,r,n)=>{let a=e[t];if(!a)return null;for(let o of Object.values(a.fields))if(o.kind==="object"&&o.type===r&&(o.fromFields?.length??0)>0&&(o.toFields?.length??0)>0&&(n===void 0||o.relationName===n))return o;return null};var E=(e,t)=>{let r=e.split("."),n=t;for(let a=r.length-1;a>=0;a--)n={[r[a]]:n};return n};var ie,ue=e=>{ie=e;},le=(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 tr(e,t,r)},rr=(e,t,r)=>{let n=e.split("."),a=[],o=r;for(let s=0;s<n.length;s++){let u=n[s],l=t[o]?.fields[u];if(!l||l.kind!=="object")throw new Error(`Field '${u}' is not a relation in model '${o}'. Prisma aggregate rules only support relation fields.`);if(s===n.length-1){if(!l.isList)throw new Error(`Field '${u}' is not a list relation in model '${o}'.`);return {segments:n,intermediateRelations:a,terminalModel:o,terminalEntry:l}}if(l.isList)throw new Error(`Intermediate field '${u}' in path '${e}' is a list relation. Only the final segment can be a list relation for aggregate rules.`);a.push({fieldName:u,entry:l,onModel:o}),o=l.type;}throw new Error(`Field path '${e}' did not terminate at a list relation.`)},tr=(e,t,r)=>{let{map:n,model:a}=t,{intermediateRelations:o,terminalModel:s,terminalEntry:u}=rr(e.field,n,a),l=u.type,p=e.aggregate.field??"",c=n[l]?.fields[p];if(!c)throw new Error(`aggregate.field '${p}' does not exist on model '${l}'.`);if(c.kind!=="scalar")throw new Error(`aggregate.field '${p}' on model '${l}' must be a scalar field, got '${c.kind}'.`);if(c.type==="Json")throw new Error(`aggregate.field '${p}' on model '${l}' is a Json field \u2014 aggregate rules require a numeric scalar.`);let f,h;if(u.fromFields&&u.fromFields.length>0){if(u.fromFields.length>1)throw new Error("Aggregate rules do not support composite FK relations.");f=u.toFields?.[0]??"id",h=u.fromFields[0];}else {let b=L(n,l,s,u.relationName);if(!b)throw new Error(`Cannot determine FK relationship between '${s}' and '${l}'. Ensure the FieldMap contains both sides of the relation.`);if((b.fromFields?.length??0)>1)throw new Error("Aggregate rules do not support composite FK relations.");f=b.fromFields?.[0]??"",h=b.toFields?.[0]??"";}let $=e.condition?ie(e.condition,{...t,model:l},r):{},R=e.aggregate.mode==="sum"?"_sum":"_avg",j={[p]:{[R]:nr(e)}},S={operation:"groupBy",model:l,args:{by:[f],where:$,having:j},extract:f},ee=r.steps.length;r.steps.push(S);let I={__step:ee};if(o.length>0){let b={[h]:{in:I}},Le=o.map(Ve=>Ve.fieldName).join(".");return E(Le,b)}return {[h]:{in:I}}},nr=e=>{let t=e.value;switch(e.operator){case i.equals:return {equals:t};case i.notEquals:return {not:t};case i.lessThan:return {lt:t};case i.lessThanEquals:return {lte:t};case i.greaterThan:return {gt:t};case i.greaterThanEquals:return {gte:t};case i.between:{if(!Array.isArray(t)||t.length!==2)throw new Error("between requires two values");let[r,n]=t,[a,o]=r<=n?[r,n]:[n,r];return {gte:a,lte:o}}case i.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 pe=(e,t,r,n)=>{let{map:a,model:o}=t,s=a[o]?.fields[e.field];if(!s||s.kind!=="object")throw new Error(`Field '${e.field}' is not a relation in model '${o}'. Count operators require a relation field.`);if(!s.isList)throw new Error(`Field '${e.field}' is not a list relation in model '${o}'. Count operators only apply to one-to-many or many-to-many relations.`);let u=s.type,l,p;if(s.fromFields&&s.fromFields.length>0){if(s.fromFields.length>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${o}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=s.toFields?.[0]??"id",p=s.fromFields[0];}else {let S=L(a,u,o,s.relationName);if(!S){let I=Object.values(a[u]?.fields??{}).some(b=>b.kind==="object"&&b.type===o&&b.isList&&!b.fromFields?.length);throw new Error(I?`'${o}.${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 '${o}' and '${u}'. Ensure the FieldMap contains both sides of the relation.`)}if((S.fromFields?.length??0)>1)throw new Error(`Count operators (atLeast/atMost/exactly) do not support composite FK relations ('${o}.${e.field}'). Use prisma.$queryRaw for composite FK count filtering.`);l=S.fromFields?.[0]??"",p=S.toFields?.[0]??"";}let c=e.condition?n(e.condition,{...t,model:u},r):{},f=e.count??1,h=ar(e.arrayOperator,f,l),$={operation:"groupBy",model:u,args:{by:[l],where:c,having:h},extract:l},R=r.steps.length;r.steps.push($);let j={__step:R};return {[p]:{in:j}}},ar=(e,t,r)=>{switch(e){case d.atLeast:return {[r]:{_count:{gte:t}}};case d.atMost:return {[r]:{_count:{lte:t}}};case d.exactly:return {[r]:{_count:{equals:t}}};default:throw new Error("unreachable")}};var C,de=e=>{C=e;},fe=(e,t,r)=>{if(e.arrayOperator===d.atLeast||e.arrayOperator===d.atMost||e.arrayOperator===d.exactly){if(t?.map&&t?.model&&r)return pe(e,t,r,C);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.`)}let n=or(e,t,r);return E(e.field,n)},or=(e,t,r)=>{switch(e.arrayOperator){case d.all:if(!e.condition)throw new Error("ArrayOperator 'all' requires a condition");return {every:C(e.condition,t,r)};case d.any:if(!e.condition)throw new Error("ArrayOperator 'any' requires a condition");return {some:C(e.condition,t,r)};case d.none:if(!e.condition)throw new Error("ArrayOperator 'none' requires a condition");return {none:C(e.condition,t,r)};case d.empty:return {none:{}};case d.notEmpty:return {some:{}};default:throw new Error(`Unknown array operator: ${e.arrayOperator}`)}};var ge=(e,t)=>{let r=ur(e,t);return E(e.field,r)},ir=(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 get(t.context,e.path)}},ur=(e,t)=>{let r=()=>ir(e,t);switch(e.dateOperator){case g.before:return {lt:r()};case g.after:return {gt:r()};case g.onOrBefore:return {lte:r()};case g.onOrAfter:return {gte:r()};case g.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between date operator requires an array of two values");let[a,o]=me(n);return {gte:a,lte:o}}case g.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween date operator requires an array of two values");let[a,o]=me(n);return {NOT:{gte:a,lte:o}}}case g.dayIn:throw new Error("DateOperator 'dayIn' has no Prisma equivalent. Use prisma.$queryRaw with EXTRACT(DOW FROM ...) for day-of-week filtering.");case g.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}`)}},me=e=>{let[t,r]=e;return lr(t,r)<=0?[t,r]:[r,t]},lr=(e,t)=>{let r=ce(e),n=ce(t);return r<n?-1:r>n?1:0},ce=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e);var ye=(e,t,r)=>{let n=e.split("."),a=r;for(let o=0;o<n.length;o++){let s=t[a];if(!s)return {kind:"fallback"};let u=s.fields[n[o]];if(!u)return {kind:"fallback"};if(u.kind==="scalar"&&u.type==="Json"&&o<n.length-1)return {kind:"json-path",stopIndex:o+1,jsonPath:n.slice(o+1)};if(u.kind==="object"){if(!t[u.type])return {kind:"fallback"};a=u.type;continue}return {kind:"direct"}}return {kind:"direct"}};var he=(e,t)=>{if(e.operator===i.isEmpty)return {OR:[x(e.field,{equals:null},t),x(e.field,{equals:""},t)]};if(e.operator===i.notEmpty)return {AND:[x(e.field,{not:null},t),x(e.field,{not:""},t)]};let r=fr(e,t);return x(e.field,r,t)},dr=(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 get(t.context,e.path)}throw new Error(`Rule for field '${e.field}' has neither value nor path set`)},fr=(e,t)=>{let r=()=>dr(e,t);switch(e.operator){case i.equals:return {equals:r()??null};case i.notEquals:return {not:r()??null};case i.lessThan:return {lt:r()};case i.lessThanEquals:return {lte:r()};case i.greaterThan:return {gt:r()};case i.greaterThanEquals:return {gte:r()};case i.in:return {in:r()};case i.notIn:return {notIn:r()};case i.contains:return {contains:r()};case i.notContains:return {not:{contains:r()}};case i.startsWith:return {startsWith:r()};case i.endsWith:return {endsWith:r()};case i.matches:throw new Error("Operator 'matches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case i.notMatches:throw new Error("Operator 'notMatches' has no Prisma equivalent. Use prisma.$queryRaw for regex filtering.");case i.between:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("between operator requires an array of two values");let[a,o]=n[0]<=n[1]?n:[n[1],n[0]];return {gte:a,lte:o}}case i.notBetween:{let n=r();if(!Array.isArray(n)||n.length!==2)throw new Error("notBetween operator requires an array of two values");let[a,o]=n[0]<=n[1]?n:[n[1],n[0]];return {NOT:{gte:a,lte:o}}}case i.isEmpty:case i.notEmpty:throw new Error("isEmpty/notEmpty handled at buildFieldRule level");case i.exists:return {not:null};case i.notExists:return {equals:null};default:throw new Error(`Unknown operator: ${e.operator}`)}},x=(e,t,r)=>{if(!r?.map||!r?.model)return E(e,t);let n=ye(e,r.map,r.model),a=e.split(".");switch(n.kind){case "fallback":case "direct":return E(e,t);case "json-path":{let o={path:n.jsonPath,...t},s=a.slice(0,n.stopIndex).join(".");return E(s,o)}}};var F,we=e=>{F=e;},$e=(e,t,r)=>e.all.length===0?{}:{AND:e.all.map(n=>F(n,t,r))},be=(e,t,r)=>e.any.length===0?{AND:[{id:null},{id:{not:null}}]}:{OR:e.any.map(n=>F(n,t,r))},Ee=(e,t,r)=>{let n=F(e.if,t,r),a={NOT:n},o=F(e.then,t,r);if(e.else){let s=F(e.else,t,r);return {AND:[{OR:[a,o]},{OR:[n,s]}]}}return {OR:[a,o]}};var _=(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 $e(e,t,r);if("any"in e)return be(e,t,r);if("if"in e)return Ee(e,t,r);if("arrayOperator"in e)return fe(e,t,r);if("dateOperator"in e)return ge(e,t);if("aggregate"in e)return le(e,t,r);if("field"in e)return he(e,t);throw new Error("Unknown condition type")};we(_);de(_);ue(_);var mr=async(e,t)=>{let r=e.steps.filter(o=>o.operation==="groupBy"),n=e.steps.find(o=>o.operation==="where");if(!n)throw new Error("executePrismaQueryPlan: result has no where step");let a=[];for(let o of r){let s=o.model.charAt(0).toLowerCase()+o.model.slice(1),u=t[s];if(!u)throw new Error(`executePrismaQueryPlan: no delegate for model '${o.model}'. Ensure prismaDelegate has a key '${s}'.`);let l=await u[o.operation](o.args);a.push(l.map(p=>p[o.extract]));}return z(n.where,a)},z=(e,t)=>{if(e==null)return e;if(Array.isArray(e))return e.map(r=>z(r,t));if(typeof e=="object"){let r=e;if("__step"in r&&typeof r.__step=="number"){let a=r.__step;if(a>=t.length)throw new Error(`Step ref __step: ${a} out of range (${t.length} steps executed)`);return t[a]}let n={};for(let[a,o]of Object.entries(r))n[a]=z(o,t);return n}return e};var It=(e,t)=>{let r={steps:[]},n=_(e,t,r);return {steps:[...r.steps,{operation:"where",where:n}]}};var y=(e,t)=>(e.params.push(t),`$${++e.paramIndex}`);var N=e=>e.replace(/\\/g,"\\\\").replace(/%/g,"\\%").replace(/_/g,"\\_"),w=e=>{let t=e.split(".");if(t.length===1)return escapeIdentifier(e);let[r,...n]=t;return n.length===0?escapeIdentifier(r):Oe(escapeIdentifier(r),n)},Ae=(e,t)=>{let r=e.split(".");if(r.length===1)return `${escapeIdentifier(t)}.${escapeIdentifier(e)}`;let[n,...a]=r;return Oe(`${escapeIdentifier(t)}.${escapeIdentifier(n)}`,a)},Q=e=>`'${e.replace(/'/g,"''")}'`,Oe=(e,t)=>{if(t.length===0)return e;let r=t.slice(0,-1).map(Q).join("->"),n=Q(t[t.length-1]);return r?`${e}->${r}->>${n}`:`${e}->>${n}`},Re=e=>{let t=e.split(".");if(t.length===1)return escapeIdentifier(e);let[r,...n]=t;return n.length===0?escapeIdentifier(r):cr(escapeIdentifier(r),n)},cr=(e,t)=>{let r=t.map(Q).join("->");return `${e}->${r}`};var qe=(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=yr(e,t);return wr(r,e,t)},yr=(e,t)=>{let r=Re(e.field),{mode:n,field:a}=e.aggregate,o=n==="sum"?"SUM":"AVG",s=t.map?.[t.currentModel??""]?.fields[e.field];if(s?.kind==="object")throw new Error(`Field '${e.field}' is a relation \u2014 toSql() cannot aggregate relation lists. Use toPrisma() instead.`);if(a?.includes("."))throw new Error(`aggregate.field '${a}' contains a nested path \u2014 toSql() only supports flat field names. Use check() for nested paths.`);if(s?.kind==="scalar"&&s?.isList===true){if(a)throw new Error("aggregate.field is not supported for native array types. Use a JSONB column for object arrays.");return `(SELECT ${o==="SUM"?"COALESCE(SUM(elem), 0)":"AVG(elem)"} FROM unnest(${r}) AS elem)`}if(a){let c=`(elem->>'${a}')::numeric`;return `(SELECT ${o==="SUM"?`COALESCE(SUM(${c}), 0)`:`AVG(${c})`} FROM jsonb_array_elements(${r}) AS elem)`}let l="elem::numeric";return `(SELECT ${o==="SUM"?`COALESCE(SUM(${l}), 0)`:`AVG(${l})`} FROM jsonb_array_elements_text(${r}) AS elem)`},hr=(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?`${escapeIdentifier(t.currentAlias)}.${escapeIdentifier(r)}`:w(r)}}if(!t.context)throw new Error(`BuilderState.context is required to resolve path '${e.path}'. Pass context in options.`);return {type:"value",value:get(t.context,e.path)}}throw new Error("Aggregate rule requires value or path")},wr=(e,t,r)=>{let n=hr(t,r),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(t.operator){case i.equals:return o?`${e} = ${o}`:a===null?`${e} IS NULL`:`${e} = ${y(r,a)}`;case i.notEquals:return o?`${e} <> ${o}`:a===null?`${e} IS NOT NULL`:`${e} <> ${y(r,a)}`;case i.lessThan:return o?`${e} < ${o}`:`${e} < ${y(r,a)}`;case i.lessThanEquals:return o?`${e} <= ${o}`:`${e} <= ${y(r,a)}`;case i.greaterThan:return o?`${e} > ${o}`:`${e} > ${y(r,a)}`;case i.greaterThanEquals:return o?`${e} >= ${o}`:`${e} >= ${y(r,a)}`;case i.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between requires two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${e} BETWEEN ${y(r,u)} AND ${y(r,l)}`}case i.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween requires two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${e} NOT BETWEEN ${y(r,u)} AND ${y(r,l)}`}default:throw new Error(`Operator '${t.operator}' is not supported for aggregate rules`)}};var ke=(e,t)=>{let r=w(e.field),n=t.map?.[t.currentModel??""]?.fields[e.field],a=n?.kind==="scalar"&&n?.isList===true,o=a?`array_length(${r}, 1)`:`jsonb_array_length(${r})`;switch(e.arrayOperator){case d.empty:return a?`(${r} IS NULL OR ${o} IS NULL)`:`(${r} IS NULL OR ${o} = 0)`;case d.notEmpty:return a?`(${r} IS NOT NULL AND ${o} IS NOT NULL)`:`(${r} IS NOT NULL AND ${o} > 0)`;case d.all:case d.any:case d.none:case d.atLeast:case d.atMost:case d.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 H=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 V=(e,t)=>{if(!t.map||!t.currentModel||!t.currentAlias)return w(e);let r=e.split("."),n=t.currentModel,a=t.currentAlias;for(let o=0;o<r.length;o++){let s=t.map[n];if(!s)return w(e);let u=s.fields[r[o]];if(!u)return w(e);if(u.kind==="object"){let p=`${a}.${r[o]}`,c=t.joinRegistry?.get(p),f;if(c)f=c;else {let h=t.joinCounter;if(!h)return w(e);f=`t${++h.n}`;let $=$r(t.map,n,a,u,f);if(!$)return w(e);t.joins?.push($),t.joinRegistry?.set(p,f);}n=u.type,a=f;continue}let l=r.slice(o);return Ae(l.join("."),a)}return w(e)},$r=(e,t,r,n,a)=>{let o=n.type,s=e[o]?.dbName??o,u;if(n.fromFields&&n.fromFields.length>0&&n.toFields&&n.toFields.length>0)u=n.fromFields.map((l,p)=>`${escapeIdentifier(a)}.${escapeIdentifier(n.toFields?.[p]??"")} = ${escapeIdentifier(r)}.${escapeIdentifier(l)}`).join(" AND ");else {let l=br(e,o,t,n.relationName);if(!l)return null;u=(l.fromFields??[]).map((p,c)=>`${escapeIdentifier(a)}.${escapeIdentifier(p)} = ${escapeIdentifier(r)}.${escapeIdentifier(l.toFields?.[c]??"")}`).join(" AND ");}return `LEFT JOIN ${escapeIdentifier(s)} AS ${escapeIdentifier(a)} ON ${u}`},br=(e,t,r,n)=>{let a=e[t];if(!a)return null;for(let o of Object.values(a.fields))if(o.kind==="object"&&o.type===r&&(o.fromFields?.length??0)>0&&(o.toFields?.length??0)>0&&(n===void 0||o.relationName===n))return o;return null};var Fe=(e,t)=>{let r=V(e.field,t),n=Or(e,t),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(e.dateOperator){case g.before:return o!==void 0?`${r} < ${o}`:`${r} < ${y(t,a)}`;case g.after:return o!==void 0?`${r} > ${o}`:`${r} > ${y(t,a)}`;case g.onOrBefore:return o!==void 0?`${r} <= ${o}`:`${r} <= ${y(t,a)}`;case g.onOrAfter:return o!==void 0?`${r} >= ${o}`:`${r} >= ${y(t,a)}`;case g.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between date operator requires an array of two values");let[u,l]=Be(s);return `${r} BETWEEN ${y(t,u)} AND ${y(t,l)}`}case g.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween date operator requires an array of two values");let[u,l]=Be(s);return `${r} NOT BETWEEN ${y(t,u)} AND ${y(t,l)}`}case g.dayIn:{if(!Array.isArray(e.value))throw new Error("dayIn operator requires an array of day names");let s=H(e.value.map(u=>String(u)));return `EXTRACT(DOW FROM ${r}) = ANY(${y(t,s)})`}case g.dayNotIn:{if(!Array.isArray(e.value))throw new Error("dayNotIn operator requires an array of day names");let s=H(e.value.map(u=>String(u)));return `EXTRACT(DOW FROM ${r}) <> ALL(${y(t,s)})`}default:throw new Error(`Unknown date operator: ${e.dateOperator}`)}},Be=e=>{let[t,r]=e;return Ar(t,r)<=0?[t,r]:[r,t]},Ar=(e,t)=>{let r=Te(e),n=Te(t);return r<n?-1:r>n?1:0},Te=e=>e instanceof Date?e.getTime():typeof e=="number"||typeof e=="string"?e:String(e),Or=(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?`${escapeIdentifier(t.currentAlias)}.${escapeIdentifier(r)}`:w(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:get(t.context,e.path)}}return {type:"value",value:void 0}};var Pe=(e,t)=>{let r=V(e.field,t),n=vr(e,t),a=n.type==="value"?n.value:void 0,o=n.type==="column"?n.sql:void 0;switch(e.operator){case i.equals:return o!==void 0?`${r} = ${o}`:a===null?`${r} IS NULL`:`${r} = ${y(t,a)}`;case i.notEquals:return o!==void 0?`${r} <> ${o}`:a===null?`${r} IS NOT NULL`:`${r} <> ${y(t,a)}`;case i.lessThan:return o!==void 0?`${r} < ${o}`:`${r} < ${y(t,a)}`;case i.lessThanEquals:return o!==void 0?`${r} <= ${o}`:`${r} <= ${y(t,a)}`;case i.greaterThan:return o!==void 0?`${r} > ${o}`:`${r} > ${y(t,a)}`;case i.greaterThanEquals:return o!==void 0?`${r} >= ${o}`:`${r} >= ${y(t,a)}`;case i.in:return !Array.isArray(a)||a.length===0?"FALSE":`${r} = ANY(${y(t,a)})`;case i.notIn:return !Array.isArray(a)||a.length===0?"TRUE":`${r} <> ALL(${y(t,a)})`;case i.contains:return `${r} LIKE ${y(t,`%${N(String(a))}%`)}`;case i.notContains:return `${r} NOT LIKE ${y(t,`%${N(String(a))}%`)}`;case i.startsWith:return `${r} LIKE ${y(t,`${N(String(a))}%`)}`;case i.endsWith:return `${r} LIKE ${y(t,`%${N(String(a))}`)}`;case i.matches:return `${r} ~ ${y(t,a)}`;case i.notMatches:return `${r} !~ ${y(t,a)}`;case i.between:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("between operator requires an array of two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${r} BETWEEN ${y(t,u)} AND ${y(t,l)}`}case i.notBetween:{let s=a;if(!Array.isArray(s)||s.length!==2)throw new Error("notBetween operator requires an array of two values");let[u,l]=s[0]<=s[1]?s:[s[1],s[0]];return `${r} NOT BETWEEN ${y(t,u)} AND ${y(t,l)}`}case i.isEmpty:return `(${r} IS NULL OR ${r} = '')`;case i.notEmpty:return `(${r} IS NOT NULL AND ${r} <> '')`;case i.exists:return `${r} IS NOT NULL`;case i.notExists:return `${r} IS NULL`;default:throw new Error(`Unknown operator: ${e.operator}`)}},vr=(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?`${escapeIdentifier(t.currentAlias)}.${escapeIdentifier(r)}`:w(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:get(t.context,e.path)}}return {type:"value",value:void 0}};var D,Ce=e=>{D=e;},xe=(e,t)=>e.all.length===0?"TRUE":`(${e.all.map(n=>D(n,t)).join(" AND ")})`,_e=(e,t)=>e.any.length===0?"FALSE":`(${e.any.map(n=>D(n,t)).join(" OR ")})`,Ne=(e,t)=>{let r=D(e.if,t),n=D(e.then,t),a=e.else?D(e.else,t):"TRUE";return e.else?`((NOT(${r}) OR ${n}) AND (${r} OR ${a}))`:`(NOT(${r}) OR ${n})`};var X=(e,t)=>{if(typeof e=="boolean")return e?"TRUE":"FALSE";if("all"in e)return xe(e,t);if("any"in e)return _e(e,t);if("if"in e)return Ne(e,t);if("arrayOperator"in e)return ke(e,t);if("dateOperator"in e)return Fe(e,t);if("aggregate"in e)return qe(e,t);if("field"in e)return Pe(e,t);throw new Error("Unknown condition type")};Ce(X);var kn=(e,t)=>{let r=!!(t?.map&&t?.model),n=t?.alias??(r?"t0":void 0),a={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:X(e,a),params:a.params,joins:a.joins??[]}};var qr=new Set(Object.values(i)),kr=new Set(Object.values(d)),Sr=new Set(Object.values(g)),Br=(e,t={})=>{let r={target:t.target??"check",errors:[]};return q(e,"$",r),{ok:r.errors.length===0,errors:r.errors}},Tn=(e,t={})=>{let r=Br(e,t);if(r.ok)return;let n=r.errors.map(a=>`${a.path}: ${a.message}`).join(`
2
2
  `);throw new Error(`Invalid rule:
3
- ${n}`)},v=(e,r,t)=>{if(typeof e=="boolean"){t.target==="toPrisma"&&e===false&&m(t,r,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!Ce(e)){m(t,r,"invalid_condition","Condition must be a boolean or object");return}let n=Rr(e);if(!n){m(t,r,"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":Pe(e.all,`${r}.all`,t);break;case "any":Pe(e.any,`${r}.any`,t);break;case "if":v(e.if,`${r}.if`,t),v(e.then,`${r}.then`,t),"else"in e&&e.else!==void 0&&v(e.else,`${r}.else`,t);break;case "field":vr(e,r,t);break;case "aggregate":Sr(e,r,t);break;case "array":Br(e,r,t);break;case "date":Tr(e,r,t);break}},Rr=e=>{let r=[];"all"in e&&r.push("all"),"any"in e&&r.push("any"),("if"in e||"then"in e||"else"in e)&&r.push("if"),"arrayOperator"in e&&r.push("array"),"dateOperator"in e&&r.push("date"),"aggregate"in e?r.push("aggregate"):"operator"in e&&r.push("field");let t=Array.from(new Set(r));return t.length!==1?null:t[0]},Pe=(e,r,t)=>{if(!Array.isArray(e)){m(t,r,"logical_array_required","Logical operator requires an array of conditions");return}e.forEach((n,a)=>{v(n,`${r}[${a}]`,t);});},vr=(e,r,t)=>{if(typeof e.field!="string"&&m(t,`${r}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!br.has(e.operator)){m(t,`${r}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;if(t.target==="toPrisma"&&((n===i.matches||n===i.notMatches)&&"operator"in e&&m(t,`${r}.operator`,"unsupported_prisma_operator",`Operator '${n}' is not supported by toPrisma()`),typeof e.path=="string"&&e.path.startsWith("$.")&&m(t,`${r}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`)),Fr(n)){Dr(e,r,t);return}if(!M(e,r,t)||"path"in e&&typeof e.path=="string")return;let a=e.value;switch(n){case i.lessThan:case i.lessThanEquals:case i.greaterThan:case i.greaterThanEquals:H(a)||m(t,`${r}.value`,"invalid_ordered_value",`Operator '${n}' requires a string, number, or Date value`);break;case i.in:case i.notIn:Array.isArray(a)||m(t,`${r}.value`,"invalid_membership_value",`Operator '${n}' requires an array value`);break;case i.matches:case i.notMatches:typeof a=="string"||a instanceof RegExp||m(t,`${r}.value`,"invalid_pattern_value",`Operator '${n}' requires a string or RegExp value`);break;case i.startsWith:case i.endsWith:typeof a!="string"&&m(t,`${r}.value`,"invalid_string_value",`Operator '${n}' requires a string value`);break;case i.between:case i.notBetween:Cr(a)||m(t,`${r}.value`,"invalid_range_value",`Operator '${n}' requires a two-item range`);break}},qr=new Set([i.equals,i.notEquals,i.lessThan,i.lessThanEquals,i.greaterThan,i.greaterThanEquals]),kr=new Set([i.between,i.notBetween]),Sr=(e,r,t)=>{if(typeof e.field!="string"&&m(t,`${r}.field`,"field_required","Aggregate rule requires a string field"),!Ce(e.aggregate)){m(t,`${r}.aggregate`,"invalid_aggregate","aggregate must be an object");return}let n=e.aggregate;n.mode!=="sum"&&n.mode!=="avg"&&m(t,`${r}.aggregate.mode`,"invalid_aggregate_mode","aggregate.mode must be 'sum' or 'avg'"),"field"in n&&n.field!==void 0&&typeof n.field!="string"&&m(t,`${r}.aggregate.field`,"invalid_aggregate_field","aggregate.field must be a string");let a=typeof e.operator=="string"&&qr.has(e.operator),o=typeof e.operator=="string"&&kr.has(e.operator);if(!a&&!o){m(t,`${r}.operator`,"invalid_aggregate_operator","Aggregate rules only support: equals, notEquals, lessThan, lessThanEquals, greaterThan, greaterThanEquals, between, notBetween");return}if(t.target==="toPrisma"&&e.operator===i.notBetween&&m(t,`${r}.operator`,"unsupported_prisma_aggregate_operator","Operator 'notBetween' is not supported by toPrisma() for aggregate rules"),t.target==="toPrisma"&&typeof e.path=="string"&&m(t,`${r}.path`,"unsupported_prisma_aggregate_path","path is not supported by toPrisma() for aggregate rules; use value instead"),!M(e,r,t)||"path"in e&&typeof e.path=="string")return;let s=e.value;o?xr(s)||m(t,`${r}.value`,"invalid_range_value",`Operator '${e.operator}' requires a two-item numeric range`):typeof s!="number"&&m(t,`${r}.value`,"invalid_aggregate_value","Aggregate rule value must be a number");},Br=(e,r,t)=>{if(typeof e.field!="string"&&m(t,`${r}.field`,"field_required","Array rule requires a string field"),typeof e.arrayOperator!="string"||!Er.has(e.arrayOperator)){m(t,`${r}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(t.target==="toSql"&&Pr(n)&&m(t,`${r}.arrayOperator`,"unsupported_sql_array_operator",`Array operator '${n}' is not supported by toSql()`),n){case d.empty:case d.notEmpty:"condition"in e&&e.condition!==void 0&&m(t,`${r}.condition`,"unexpected_condition",`Array operator '${n}' does not accept condition`),"count"in e&&e.count!==void 0&&m(t,`${r}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case d.all:case d.any:case d.none:!("condition"in e)||e.condition===void 0?m(t,`${r}.condition`,"missing_condition",`Array operator '${n}' requires condition`):v(e.condition,`${r}.condition`,t),"count"in e&&e.count!==void 0&&m(t,`${r}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case d.atLeast:case d.atMost:case d.exactly:t.target!=="toPrisma"&&typeof e.count!="number"?m(t,`${r}.count`,"missing_count",`Array operator '${n}' requires count`):"count"in e&&e.count!==void 0&&typeof e.count!="number"&&m(t,`${r}.count`,"invalid_count","count must be a number"),t.target==="check"&&(!("condition"in e)||e.condition===void 0)?m(t,`${r}.condition`,"missing_condition",`Array operator '${n}' requires condition for check()`):"condition"in e&&e.condition!==void 0&&v(e.condition,`${r}.condition`,t);break}},Tr=(e,r,t)=>{if(typeof e.field!="string"&&m(t,`${r}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!Or.has(e.dateOperator)){m(t,`${r}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;switch(t.target==="toPrisma"&&((n===c.dayIn||n===c.dayNotIn)&&"dateOperator"in e&&m(t,`${r}.dateOperator`,"unsupported_prisma_date_operator",`Date operator '${n}' is not supported by toPrisma()`),typeof e.path=="string"&&e.path.startsWith("$.")&&m(t,`${r}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`)),n){case c.dayIn:case c.dayNotIn:(!Array.isArray(e.value)||!e.value.every(a=>typeof a=="string"))&&m(t,`${r}.value`,"invalid_day_list",`Date operator '${n}' requires an array of day names`),"path"in e&&e.path!==void 0&&m(t,`${r}.path`,"unexpected_path",`Date operator '${n}' does not accept path`);return;case c.between:case c.notBetween:if(!M(e,r,t)||"path"in e&&typeof e.path=="string")return;_r(e.value)||m(t,`${r}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return;default:if(!M(e,r,t)||"path"in e&&typeof e.path=="string")return;X(e.value)||m(t,`${r}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},M=(e,r,t)=>{let n="value"in e&&e.value!==void 0,a=typeof e.path=="string";return n&&a?(m(t,r,"ambiguous_value_source","Rule cannot define both value and path"),false):!n&&!a?(m(t,r,"missing_value_source","Rule requires either value or path"),false):true},Dr=(e,r,t)=>{"value"in e&&e.value!==void 0&&m(t,`${r}.value`,"unexpected_value","Rule does not accept value"),"path"in e&&e.path!==void 0&&m(t,`${r}.path`,"unexpected_path","Rule does not accept path");},Fr=e=>e===i.isEmpty||e===i.notEmpty||e===i.exists||e===i.notExists,Pr=e=>e===d.all||e===d.any||e===d.none||e===d.atLeast||e===d.atMost||e===d.exactly,Ce=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),H=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Cr=e=>Array.isArray(e)&&e.length===2&&H(e[0])&&H(e[1]),xr=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",X=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,_r=e=>Array.isArray(e)&&e.length===2&&X(e[0])&&X(e[1]),m=(e,r,t,n)=>{e.errors.push({path:r,code:t,message:n});};export{d as ArrayOperator,c as DateOperator,i as Operator,Rn as assertValidRule,S as check,ir as executePrismaQueryPlan,Ft as toPrisma,En as toSql,Ar as validateRule};//# sourceMappingURL=index.js.map
3
+ ${n}`)},q=(e,t,r)=>{if(typeof e=="boolean"){r.target==="toPrisma"&&e===false&&m(r,t,"boolean_false_not_supported","Boolean 'false' is not supported by toPrisma()");return}if(!Me(e)){m(r,t,"invalid_condition","Condition must be a boolean or object");return}let n=Tr(e);if(!n){m(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":Ie(e.all,`${t}.all`,r);break;case "any":Ie(e.any,`${t}.any`,r);break;case "if":q(e.if,`${t}.if`,r),q(e.then,`${t}.then`,r),"else"in e&&e.else!==void 0&&q(e.else,`${t}.else`,r);break;case "field":Fr(e,t,r);break;case "aggregate":Cr(e,t,r);break;case "array":xr(e,t,r);break;case "date":_r(e,t,r);break}},Tr=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]},Ie=(e,t,r)=>{if(!Array.isArray(e)){m(r,t,"logical_array_required","Logical operator requires an array of conditions");return}e.forEach((n,a)=>{q(n,`${t}[${a}]`,r);});},Fr=(e,t,r)=>{if(typeof e.field!="string"&&m(r,`${t}.field`,"field_required","Field rule requires a string field"),typeof e.operator!="string"||!qr.has(e.operator)){m(r,`${t}.operator`,"invalid_operator","Unknown field operator");return}let n=e.operator;if(r.target==="toPrisma"&&((n===i.matches||n===i.notMatches)&&"operator"in e&&m(r,`${t}.operator`,"unsupported_prisma_operator",`Operator '${n}' is not supported by toPrisma()`),typeof e.path=="string"&&e.path.startsWith("$.")&&m(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`)),Ir(n)){Nr(e,t,r);return}if(!W(e,t,r)||"path"in e&&typeof e.path=="string")return;let a=e.value;switch(n){case i.lessThan:case i.lessThanEquals:case i.greaterThan:case i.greaterThanEquals:Y(a)||m(r,`${t}.value`,"invalid_ordered_value",`Operator '${n}' requires a string, number, or Date value`);break;case i.in:case i.notIn:Array.isArray(a)||m(r,`${t}.value`,"invalid_membership_value",`Operator '${n}' requires an array value`);break;case i.matches:case i.notMatches:typeof a=="string"||a instanceof RegExp||m(r,`${t}.value`,"invalid_pattern_value",`Operator '${n}' requires a string or RegExp value`);break;case i.startsWith:case i.endsWith:typeof a!="string"&&m(r,`${t}.value`,"invalid_string_value",`Operator '${n}' requires a string value`);break;case i.between:case i.notBetween:Lr(a)||m(r,`${t}.value`,"invalid_range_value",`Operator '${n}' requires a two-item range`);break}},Dr=new Set([i.equals,i.notEquals,i.lessThan,i.lessThanEquals,i.greaterThan,i.greaterThanEquals]),Pr=new Set([i.between,i.notBetween]),Cr=(e,t,r)=>{if(typeof e.field!="string"&&m(r,`${t}.field`,"field_required","Aggregate rule requires a string field"),!Me(e.aggregate)){m(r,`${t}.aggregate`,"invalid_aggregate","aggregate must be an object");return}let n=e.aggregate;n.mode!=="sum"&&n.mode!=="avg"&&m(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"&&m(r,`${t}.aggregate.field`,"invalid_aggregate_field","aggregate.field must be a string");let a=typeof e.operator=="string"&&Dr.has(e.operator),o=typeof e.operator=="string"&&Pr.has(e.operator);if(!a&&!o){m(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===i.notBetween&&m(r,`${t}.operator`,"unsupported_prisma_aggregate_operator","Operator 'notBetween' is not supported by toPrisma() for aggregate rules"),r.target==="toPrisma"&&typeof e.path=="string"&&m(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"&&m(r,`${t}.condition`,"unsupported_sql_aggregate_condition","Aggregate condition filtering is not supported by toSql(); use check() or toPrisma()"),q(e.condition,`${t}.condition`,r)),!W(e,t,r)||"path"in e&&typeof e.path=="string")return;let s=e.value;o?Vr(s)||m(r,`${t}.value`,"invalid_range_value",`Operator '${e.operator}' requires a two-item numeric range`):typeof s!="number"&&m(r,`${t}.value`,"invalid_aggregate_value","Aggregate rule value must be a number");},xr=(e,t,r)=>{if(typeof e.field!="string"&&m(r,`${t}.field`,"field_required","Array rule requires a string field"),typeof e.arrayOperator!="string"||!kr.has(e.arrayOperator)){m(r,`${t}.arrayOperator`,"invalid_array_operator","Unknown array operator");return}let n=e.arrayOperator;switch(r.target==="toSql"&&Mr(n)&&m(r,`${t}.arrayOperator`,"unsupported_sql_array_operator",`Array operator '${n}' is not supported by toSql()`),n){case d.empty:case d.notEmpty:"condition"in e&&e.condition!==void 0&&m(r,`${t}.condition`,"unexpected_condition",`Array operator '${n}' does not accept condition`),"count"in e&&e.count!==void 0&&m(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case d.all:case d.any:case d.none:!("condition"in e)||e.condition===void 0?m(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition`):q(e.condition,`${t}.condition`,r),"count"in e&&e.count!==void 0&&m(r,`${t}.count`,"unexpected_count",`Array operator '${n}' does not accept count`);break;case d.atLeast:case d.atMost:case d.exactly:r.target!=="toPrisma"&&typeof e.count!="number"?m(r,`${t}.count`,"missing_count",`Array operator '${n}' requires count`):"count"in e&&e.count!==void 0&&typeof e.count!="number"&&m(r,`${t}.count`,"invalid_count","count must be a number"),r.target==="check"&&(!("condition"in e)||e.condition===void 0)?m(r,`${t}.condition`,"missing_condition",`Array operator '${n}' requires condition for check()`):"condition"in e&&e.condition!==void 0&&q(e.condition,`${t}.condition`,r);break}},_r=(e,t,r)=>{if(typeof e.field!="string"&&m(r,`${t}.field`,"field_required","Date rule requires a string field"),typeof e.dateOperator!="string"||!Sr.has(e.dateOperator)){m(r,`${t}.dateOperator`,"invalid_date_operator","Unknown date operator");return}let n=e.dateOperator;switch(r.target==="toPrisma"&&((n===g.dayIn||n===g.dayNotIn)&&"dateOperator"in e&&m(r,`${t}.dateOperator`,"unsupported_prisma_date_operator",`Date operator '${n}' is not supported by toPrisma()`),typeof e.path=="string"&&e.path.startsWith("$.")&&m(r,`${t}.path`,"unsupported_prisma_path",`Path '${e.path}' is not supported by toPrisma()`)),n){case g.dayIn:case g.dayNotIn:(!Array.isArray(e.value)||!e.value.every(a=>typeof a=="string"))&&m(r,`${t}.value`,"invalid_day_list",`Date operator '${n}' requires an array of day names`),"path"in e&&e.path!==void 0&&m(r,`${t}.path`,"unexpected_path",`Date operator '${n}' does not accept path`);return;case g.between:case g.notBetween:if(!W(e,t,r)||"path"in e&&typeof e.path=="string")return;Wr(e.value)||m(r,`${t}.value`,"invalid_date_range",`Date operator '${n}' requires a two-item date range`);return;default:if(!W(e,t,r)||"path"in e&&typeof e.path=="string")return;Z(e.value)||m(r,`${t}.value`,"invalid_date_value",`Date operator '${n}' requires a date-like value`);}},W=(e,t,r)=>{let n="value"in e&&e.value!==void 0,a=typeof e.path=="string";return n&&a?(m(r,t,"ambiguous_value_source","Rule cannot define both value and path"),false):!n&&!a?(m(r,t,"missing_value_source","Rule requires either value or path"),false):true},Nr=(e,t,r)=>{"value"in e&&e.value!==void 0&&m(r,`${t}.value`,"unexpected_value","Rule does not accept value"),"path"in e&&e.path!==void 0&&m(r,`${t}.path`,"unexpected_path","Rule does not accept path");},Ir=e=>e===i.isEmpty||e===i.notEmpty||e===i.exists||e===i.notExists,Mr=e=>e===d.all||e===d.any||e===d.none||e===d.atLeast||e===d.atMost||e===d.exactly,Me=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Y=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Lr=e=>Array.isArray(e)&&e.length===2&&Y(e[0])&&Y(e[1]),Vr=e=>Array.isArray(e)&&e.length===2&&typeof e[0]=="number"&&typeof e[1]=="number",Z=e=>typeof e=="string"||typeof e=="number"||e instanceof Date,Wr=e=>Array.isArray(e)&&e.length===2&&Z(e[0])&&Z(e[1]),m=(e,t,r,n)=>{e.errors.push({path:t,code:r,message:n});};export{d as ArrayOperator,g as DateOperator,i as Operator,Tn as assertValidRule,k as check,mr as executePrismaQueryPlan,It as toPrisma,kn as toSql,Br as validateRule};//# sourceMappingURL=index.js.map
4
4
  //# sourceMappingURL=index.js.map