drizzle-cube 0.4.48 → 0.4.49
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/adapters/{compiler-B_Nl7ZZb.js → compiler-BXfrvebp.js} +3 -2
- package/dist/adapters/{compiler-CdL3ksb3.cjs → compiler-CPE-YZfe.cjs} +1 -1
- package/dist/adapters/express/index.cjs +1 -1
- package/dist/adapters/express/index.js +2 -2
- package/dist/adapters/fastify/index.cjs +1 -1
- package/dist/adapters/fastify/index.js +2 -2
- package/dist/adapters/hono/index.cjs +1 -1
- package/dist/adapters/hono/index.js +2 -2
- package/dist/adapters/mcp-tools.cjs +1 -1
- package/dist/adapters/mcp-tools.js +1 -1
- package/dist/adapters/{mcp-transport-CG5Aw2cs.js → mcp-transport-BhPqU0Ft.js} +24 -12
- package/dist/adapters/{mcp-transport-DlFvZl2c.cjs → mcp-transport-Kk_HTCeR.cjs} +1 -1
- package/dist/adapters/nextjs/index.cjs +1 -1
- package/dist/adapters/nextjs/index.js +2 -2
- package/dist/server/index.cjs +1 -1
- package/dist/server/index.js +3 -2
- package/package.json +1 -1
package/dist/server/index.cjs
CHANGED
|
@@ -59,7 +59,7 @@ Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});var e=Object.
|
|
|
59
59
|
ORDER BY table_name, index_name
|
|
60
60
|
`);return Array.isArray(n)?n.map(e=>({table_name:e.table_name,index_name:e.index_name,columns:typeof e.columns==`string`?e.columns.split(`,`):[],is_unique:!!e.is_unique,is_primary:!!e.is_primary})):[]}catch(e){return console.warn(`Failed to get table indexes:`,e),[]}}};function de(e,t){return new ue(e,t,`duckdb`)}function fe(e,t){let n=[],r=[],i=!1,a,o=[];for(let t of e){if(!t.trim())continue;let e=me(t);if(e){(e.type.includes(`TableScan`)||e.type.includes(`SCAN`))&&(i=!0),e.type.includes(`IndexScan`)&&e.index&&r.push(e.index),n.length===0&&e.estimatedCost!==void 0&&(a=e.estimatedCost);let s=pe(t);for(;o.length>0&&o[o.length-1].indent>=s;)o.pop();if(o.length===0)n.push(e);else{let t=o[o.length-1].op;t.children||=[],t.children.push(e)}o.push({indent:s,op:e})}}return{operations:n,summary:{database:`databend`,planningTime:void 0,executionTime:void 0,totalCost:a,hasSequentialScans:i,usedIndexes:[...new Set(r)]},raw:e.join(`
|
|
61
61
|
`),sql:t}}function pe(e){let t=0;for(let n of e)if(n===` `||n===`│`||n===`├`||n===`└`||n===`─`)t++;else break;return t}function me(e){let t=e.replace(/[┌├└│─┐┤┘]/g,``).replace(/^\s*/,``).trim();if(!t||/^(filters|table|estimated rows|output columns|push downs):/.test(t))return null;let n=t.match(/^([A-Z][A-Za-z_]+(?:\s+[A-Z][A-Za-z_]+)*)(?:\s+(\S+))?/);if(!n)return null;let r=n[1],i=n[2]||void 0,a=t.match(/estimated rows:\s*(\d+)/i);return{type:r,table:i,estimatedRows:a?parseInt(a[1],10):void 0}}var he=class extends b{async execute(e,t){if(e&&typeof e==`object`&&typeof e.execute==`function`)try{let n=await e.execute();return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Databend] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}if(!this.db.execute)throw Error(`Databend database instance must have an execute method`);try{let n=await this.db.execute(e);return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Databend] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}}extractSqlFromQuery(e){try{if(e&&typeof e.toSQL==`function`){let{sql:t,params:n}=e.toSQL();return{sql:t,params:n}}if(e&&typeof e.getSQL==`function`){let t=e.getSQL();if(t&&typeof t.toSQL==`function`){let{sql:e,params:n}=t.toSQL();return{sql:e,params:n}}}return{sql:String(e),params:[]}}catch{return{sql:`[unable to extract SQL]`,params:[]}}}convertNumericFields(e,t){if(!e||typeof e!=`object`)return e;let n={};for(let[r,i]of Object.entries(e))t&&t.includes(r)?n[r]=this.coerceToNumber(i):n[r]=i;return n}coerceToNumber(e){if(e==null||typeof e==`number`)return e;if(typeof e==`bigint`)return Number(e);if(e&&typeof e==`object`){if(typeof e.toString==`function`){let t=e.toString();if(/^-?\d+(\.\d+)?$/.test(t))return t.includes(`.`)?parseFloat(t):parseInt(t,10)}return e}if(typeof e==`string`){if(/^-?\d+(\.\d+)?$/.test(e))return e.includes(`.`)?parseFloat(e):parseInt(e,10);if(!isNaN(parseFloat(e))&&isFinite(parseFloat(e)))return parseFloat(e)}return e}getEngineType(){return`databend`}async explainQuery(e,t,n){let r=n?.analyze?`EXPLAIN ANALYZE`:`EXPLAIN`;if(!this.db.execute)throw Error(`Databend database instance must have an execute method`);let i=await this.db.execute(u.sql`${u.sql.raw(r)} ${u.sql.raw(e.replace(/\$(\d+)/g,(e,n)=>{let r=t[parseInt(n,10)-1];return r===null?`NULL`:typeof r==`number`?String(r):typeof r==`boolean`?r?`TRUE`:`FALSE`:r instanceof Date?`'${r.toISOString()}'`:`'${String(r).replace(/'/g,`''`)}'`}))}`),a=[];if(Array.isArray(i)){for(let e of i)if(e&&typeof e==`object`){let t=e.explain||e[`QUERY PLAN`]||e.query_plan||e.Plan||Object.values(e)[0];typeof t==`string`&&a.push(t)}}return fe(a,{sql:e,params:t})}async getTableIndexes(e){return!e||e.length,[]}};function ge(e,t){return new he(e,t,`databend`)}function _e(e,t){let n=[],r=[],i=!1,a,o=[];for(let t of e){if(!t.trim())continue;let e=ye(t);if(e){(e.type.includes(`TableScan`)||e.type.includes(`SCAN`))&&(i=!0),n.length===0&&e.estimatedCost!==void 0&&(a=e.estimatedCost);let r=ve(t);for(;o.length>0&&o[o.length-1].indent>=r;)o.pop();if(o.length===0)n.push(e);else{let t=o[o.length-1].op;t.children||=[],t.children.push(e)}o.push({indent:r,op:e})}}return{operations:n,summary:{database:`snowflake`,planningTime:void 0,executionTime:void 0,totalCost:a,hasSequentialScans:i,usedIndexes:[...new Set(r)]},raw:e.join(`
|
|
62
|
-
`),sql:t}}function ve(e){let t=0;for(let n of e)if(n===` `||n===`-`||n===`>`)t++;else break;return t}function ye(e){let t=e.replace(/^[\s\d:]*->/,``).trim();if(!t||/^(GlobalStats|partitions|bytes):/i.test(t)||/^\w+=\d+/.test(t))return null;let n=t.match(/^([A-Z][A-Za-z_]+(?:\s+[A-Z][A-Za-z_]+)*)(?:\s+(\S+))?/);if(!n)return null;let r=n[1],i=n[2]||void 0,a=t.match(/estimated rows:\s*(\d+)/i);return{type:r,table:i,estimatedRows:a?parseInt(a[1],10):void 0}}var be=class extends b{async execute(e,t){if(e&&typeof e==`object`&&typeof e.execute==`function`)try{let n=await e.execute();return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Snowflake] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}if(!this.db.execute)throw Error(`Snowflake database instance must have an execute method`);try{let n=await this.db.execute(e);return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Snowflake] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}}extractSqlFromQuery(e){try{if(e&&typeof e.toSQL==`function`){let{sql:t,params:n}=e.toSQL();return{sql:t,params:n}}if(e&&typeof e.getSQL==`function`){let t=e.getSQL();if(t&&typeof t.toSQL==`function`){let{sql:e,params:n}=t.toSQL();return{sql:e,params:n}}}return{sql:String(e),params:[]}}catch{return{sql:`[unable to extract SQL]`,params:[]}}}convertNumericFields(e,t){if(!e||typeof e!=`object`)return e;let n={};for(let[r,i]of Object.entries(e))t&&t.includes(r)?n[r]=this.coerceToNumber(i):n[r]=i;return n}coerceToNumber(e){if(e==null||typeof e==`number`)return e;if(typeof e==`bigint`)return Number(e);if(e&&typeof e==`object`){if(typeof e.toString==`function`){let t=e.toString();if(/^-?\d+(\.\d+)?$/.test(t))return t.includes(`.`)?parseFloat(t):parseInt(t,10)}return e}if(typeof e==`string`){if(/^-?\d+(\.\d+)?$/.test(e))return e.includes(`.`)?parseFloat(e):parseInt(e,10);if(!isNaN(parseFloat(e))&&isFinite(parseFloat(e)))return parseFloat(e)}return e}getEngineType(){return`snowflake`}async explainQuery(e,t,n){if(n?.analyze,!this.db.execute)throw Error(`Snowflake database instance must have an execute method`);let r=await this.db.execute(u.sql`${u.sql.raw(`EXPLAIN`)} ${u.sql.raw(e.replace(/\?/g,()=>{let e=t.shift();return e===null?`NULL`:typeof e==`number`?String(e):typeof e==`boolean`?e?`TRUE`:`FALSE`:e instanceof Date?`'${e.toISOString()}'`:`'${String(e).replace(/'/g,`''`)}'`}))}`),i=[];if(Array.isArray(r)){for(let e of r)if(e&&typeof e==`object`){let t=e.content||e[`QUERY PLAN`]||e.plan||Object.values(e)[0];typeof t==`string`&&i.push(t)}}return _e(i,{sql:e,params:t})}async getTableIndexes(e){return[]}};function xe(e,t){return new be(e,t,`snowflake`)}function Se(e,t,n){if(n)switch(n){case`postgres`:return C(e,t);case`mysql`:return ne(e,t);case`sqlite`:return ie(e,t);case`singlestore`:return oe(e,t);case`duckdb`:return de(e,t);case`databend`:return ge(e,t);case`snowflake`:return xe(e,t)}if(e.all&&e.run)return ie(e,t);if(e.execute)return C(e,t);throw Error(`Unable to determine database engine type. Please specify engineType parameter.`)}function O(e,t){return typeof e==`string`?t?t.get(e)||(console.warn(`[drizzle-cube] Cannot resolve cube reference '${e}': no cube with that name is registered. Registered cubes: ${Array.from(t.keys()).join(`, `)||`(none)`}. Join will be skipped.`),null):(console.warn(`[drizzle-cube] Cannot resolve string cube reference '${e}': no cube registry provided. Join will be skipped.`),null):typeof e==`function`?e():e}function Ce(e){switch(e){case`belongsTo`:return`hasMany`;case`hasMany`:return`belongsTo`;case`hasOne`:return`hasOne`;case`belongsToMany`:return`belongsToMany`;default:return e}}function we(e,t){if(t)return t;switch(e){case`belongsTo`:return`inner`;case`hasOne`:return`left`;case`hasMany`:return`left`;case`belongsToMany`:return`left`;default:return`left`}}function Te(e){return e&&typeof e==`object`?u.sql`${u.sql`${e}`}`:e}function Ee(e){if(e===`__proto__`||e===`constructor`||e===`prototype`)throw Error(`Unsafe property key: ${e}`);return e}function k(e,t){return Te(typeof e==`function`?e(t):e)}function De(e,t,n){return{...e,cubes:t,currentCube:n}}function Oe(e,t){return{name:e,...t}}function ke(e,t){if(e.relationship!==`belongsToMany`||!e.through)throw Error(`expandBelongsToManyJoin can only be called on belongsToMany relationships with through configuration`);let{table:n,sourceKey:r,targetKey:i,securitySql:a}=e.through,o=[];for(let e of r){let t=e.as||u.eq;o.push(t(e.source,e.target))}let s=[];for(let e of i){let t=e.as||u.eq;s.push(t(e.source,e.target))}let c;if(a){let e=a(t);c=Array.isArray(e)?e:[e]}let l=we(`belongsToMany`,e.sqlJoinType);return{junctionJoins:[{joinType:l,table:n,condition:(0,u.and)(...o)},{joinType:l,table:n,condition:(0,u.and)(...s)}],junctionSecurityConditions:c}}function Ae(e){if(`and`in e)return`and:[${e.and.map(Ae).sort().join(`,`)}]`;if(`or`in e)return`or:[${e.or.map(Ae).sort().join(`,`)}]`;let t=e,n=JSON.stringify(Array.isArray(t.values)?[...t.values].sort():t.values),r=t.dateRange?`:dr:${JSON.stringify(t.dateRange)}`:``;return`${t.member}:${t.operator}:${n}${r}`}function je(e,t){return`timeDim:${e}:${JSON.stringify(t)}`}var Me=class{cache=new Map;stats={hits:0,misses:0};getOrBuild(e,t){let n=this.cache.get(e);if(n!==void 0)return this.stats.hits++,n;let r=t();return r&&this.cache.set(e,r),this.stats.misses++,r}has(e){return this.cache.has(e)}get(e){let t=this.cache.get(e);return t!==void 0&&this.stats.hits++,t}preload(e){for(let{key:t,sql:n}of e)this.cache.has(t)||this.cache.set(t,n)}set(e,t){this.cache.set(e,t)}getStats(){return{...this.stats,cacheSize:this.cache.size}}clear(){this.cache.clear(),this.stats={hits:0,misses:0}}};function Ne(e){let t=[];for(let n of e)`and`in n&&n.and?t.push(...Ne(n.and)):`or`in n&&n.or?t.push(...Ne(n.or)):`member`in n&&t.push(n);return t}function Pe(e,t,n={}){let r=n.keyPrefix??`drizzle-cube:`,i=Fe(e),a=`${r}query:${Ve(JSON.stringify(i))}`;if(n.includeSecurityContext!==!1){let e=Ve(n.securityContextSerializer?n.securityContextSerializer(t):JSON.stringify(Be(t)));a+=`:ctx:${e}`}return a}function Fe(e){return{measures:e.measures?[...e.measures].sort():void 0,dimensions:e.dimensions?[...e.dimensions].sort():void 0,filters:e.filters?A(e.filters):void 0,timeDimensions:e.timeDimensions?ze(e.timeDimensions):void 0,limit:e.limit,offset:e.offset,order:e.order?Be(e.order):void 0,fillMissingDatesValue:e.fillMissingDatesValue,funnel:e.funnel?Ie(e.funnel):void 0,flow:e.flow?Le(e.flow):void 0,retention:e.retention?Re(e.retention):void 0}}function Ie(e){return{bindingKey:e.bindingKey,timeDimension:e.timeDimension,steps:e.steps.map(e=>{let t={name:e.name,filter:e.filter?Array.isArray(e.filter)?A(e.filter):A([e.filter])[0]:void 0,timeToConvert:e.timeToConvert};return`cube`in e&&e.cube&&(t.cube=e.cube),t}),includeTimeMetrics:e.includeTimeMetrics,globalTimeWindow:e.globalTimeWindow}}function Le(e){return{bindingKey:e.bindingKey,timeDimension:e.timeDimension,eventDimension:e.eventDimension,startingStep:{name:e.startingStep.name,filter:e.startingStep.filter?Array.isArray(e.startingStep.filter)?A(e.startingStep.filter):A([e.startingStep.filter])[0]:void 0},stepsBefore:e.stepsBefore,stepsAfter:e.stepsAfter,entityLimit:e.entityLimit,outputMode:e.outputMode,joinStrategy:e.joinStrategy}}function Re(e){return{timeDimension:e.timeDimension,bindingKey:e.bindingKey,dateRange:e.dateRange,granularity:e.granularity,periods:e.periods,retentionType:e.retentionType,cohortFilters:e.cohortFilters?Array.isArray(e.cohortFilters)?A(e.cohortFilters):A([e.cohortFilters])[0]:void 0,activityFilters:e.activityFilters?Array.isArray(e.activityFilters)?A(e.activityFilters):A([e.activityFilters])[0]:void 0,breakdownDimensions:e.breakdownDimensions}}function A(e){return[...e].map(e=>{if(`and`in e&&e.and)return{and:A(e.and)};if(`or`in e&&e.or)return{or:A(e.or)};let t=e;return{...t,values:t.values?[...t.values].sort():t.values}}).sort((e,t)=>JSON.stringify(e).localeCompare(JSON.stringify(t)))}function ze(e){return[...e].map(e=>({dimension:e.dimension,granularity:e.granularity,dateRange:e.dateRange,fillMissingDates:e.fillMissingDates,compareDateRange:e.compareDateRange?[...e.compareDateRange].sort((e,t)=>{let n=Array.isArray(e)?e.join(`-`):e,r=Array.isArray(t)?t.join(`-`):t;return n.localeCompare(r)}):void 0})).sort((e,t)=>e.dimension.localeCompare(t.dimension))}function Be(e){return typeof e!=`object`||!e?e:Array.isArray(e)?e.map(Be):Object.keys(e).sort().reduce((t,n)=>(t[n]=Be(e[n]),t),{})}function Ve(e){let t=2166136261,n=Math.min(e.length,65536);for(let r=0;r<n;r++)t^=e.charCodeAt(r),t=t*16777619>>>0;return t.toString(16).padStart(8,`0`)}function He(e,t){return`${t??`drizzle-cube:`}*${e}*`}var j=class{constructor(e){this.databaseAdapter=e}buildTimeDimensionExpression(e,t,n){let r=k(e,n);return t?this.databaseAdapter.buildTimeDimension(t,r):r instanceof u.SQL?r:u.sql`${r}`}buildDateRangeCondition(e,t){if(!t)return null;if(Array.isArray(t)&&t.length>=2){let n=this.normalizeDate(t[0]),r=this.normalizeDate(t[1]);if(!n||!r)return null;if(typeof t[1]==`string`&&/^\d{4}-\d{2}-\d{2}$/.test(t[1].trim())){let e=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),t=new Date(e);t.setUTCHours(23,59,59,999),r=this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}return(0,u.and)((0,u.gte)(e,n),(0,u.lte)(e,r))}if(typeof t==`string`){let n=this.parseRelativeDateRange(t);if(n){let t,r;return this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?(t=Math.floor(n.start.getTime()/1e3),r=Math.floor(n.end.getTime()/1e3)):(t=n.start.getTime(),r=n.end.getTime()):(t=n.start.toISOString(),r=n.end.toISOString()),(0,u.and)((0,u.gte)(e,t),(0,u.lte)(e,r))}let r=this.normalizeDate(t);if(!r)return null;let i=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),a=new Date(i);a.setUTCHours(0,0,0,0);let o=new Date(i);o.setUTCHours(23,59,59,999);let s,c;return this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?(s=Math.floor(a.getTime()/1e3),c=Math.floor(o.getTime()/1e3)):(s=a.getTime(),c=o.getTime()):(s=a.toISOString(),c=o.toISOString()),(0,u.and)((0,u.gte)(e,s),(0,u.lte)(e,c))}return null}parseRelativeDateRange(e){let t=new Date,n=e.toLowerCase().trim(),r=t.getUTCFullYear(),i=t.getUTCMonth(),a=t.getUTCDate(),o=t.getUTCDay();if(n===`today`){let e=new Date(t);e.setUTCHours(0,0,0,0);let n=new Date(t);return n.setUTCHours(23,59,59,999),{start:e,end:n}}if(n===`yesterday`){let e=new Date(t);e.setUTCDate(a-1),e.setUTCHours(0,0,0,0);let n=new Date(t);return n.setUTCDate(a-1),n.setUTCHours(23,59,59,999),{start:e,end:n}}if(n===`this week`){let e=o===0?-6:1-o,n=new Date(t);n.setUTCDate(a+e),n.setUTCHours(0,0,0,0);let r=new Date(n);return r.setUTCDate(n.getUTCDate()+6),r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`this month`)return{start:new Date(Date.UTC(r,i,1,0,0,0,0)),end:new Date(Date.UTC(r,i+1,0,23,59,59,999))};if(n===`this quarter`){let e=Math.floor(i/3);return{start:new Date(Date.UTC(r,e*3,1,0,0,0,0)),end:new Date(Date.UTC(r,e*3+3,0,23,59,59,999))}}if(n===`this year`)return{start:new Date(Date.UTC(r,0,1,0,0,0,0)),end:new Date(Date.UTC(r,11,31,23,59,59,999))};let s=n.match(/^last\s+(\d+)\s+days?$/);if(s){let e=parseInt(s[1],10),n=new Date(t);n.setUTCDate(a-e+1),n.setUTCHours(0,0,0,0);let r=new Date(t);return r.setUTCHours(23,59,59,999),{start:n,end:r}}let c=n.match(/^last\s+(\d+)\s+weeks?$/);if(c){let e=parseInt(c[1],10)*7,n=new Date(t);n.setUTCDate(a-e+1),n.setUTCHours(0,0,0,0);let r=new Date(t);return r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`last week`){let e=o===0?-13:-6-o,n=new Date(t);n.setUTCDate(a+e),n.setUTCHours(0,0,0,0);let r=new Date(n);return r.setUTCDate(n.getUTCDate()+6),r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`last month`)return{start:new Date(Date.UTC(r,i-1,1,0,0,0,0)),end:new Date(Date.UTC(r,i,0,23,59,59,999))};if(n===`last quarter`){let e=Math.floor(i/3),t=e===0?3:e-1,n=e===0?r-1:r;return{start:new Date(Date.UTC(n,t*3,1,0,0,0,0)),end:new Date(Date.UTC(n,t*3+3,0,23,59,59,999))}}if(n===`last year`)return{start:new Date(Date.UTC(r-1,0,1,0,0,0,0)),end:new Date(Date.UTC(r-1,11,31,23,59,59,999))};if(n===`last 12 months`){let e=new Date(Date.UTC(r,i-11,1,0,0,0,0)),n=new Date(t);return n.setUTCHours(23,59,59,999),{start:e,end:n}}let l=n.match(/^last\s+(\d+)\s+months?$/);if(l){let e=parseInt(l[1],10),n=new Date(Date.UTC(r,i-e+1,1,0,0,0,0)),a=new Date(t);return a.setUTCHours(23,59,59,999),{start:n,end:a}}let u=n.match(/^last\s+(\d+)\s+years?$/);if(u){let e=parseInt(u[1],10),n=new Date(Date.UTC(r-e,0,1,0,0,0,0)),i=new Date(t);return i.setUTCHours(23,59,59,999),{start:n,end:i}}return null}normalizeDate(e){if(!e)return null;if(e instanceof Date)return isNaN(e.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(e.getTime()/1e3):e.getTime():e.toISOString();if(typeof e==`number`){let t=e<1e10?e*1e3:e,n=new Date(t);return isNaN(n.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t/1e3):t:n.toISOString()}if(typeof e==`string`){if(/^\d{4}-\d{2}-\d{2}$/.test(e.trim())){let t=new Date(e+`T00:00:00Z`);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}let t=new Date(e);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}let t=new Date(e);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}},Ue=class{constructor(e,t){this.databaseAdapter=e,this.dateTimeBuilder=t}buildFilterCondition(e,t,n,r,i){if(i!==void 0){if(t!==`inDateRange`)throw Error(`dateRange can only be used with 'inDateRange' operator, but got '${t}'. Use explicit date values in the 'values' array for other date operators.`);if(r&&r.type!==`time`)throw Error(`dateRange can only be used on time dimensions, but field '${r.name||`unknown`}' has type '${r.type}'`);return this.dateTimeBuilder.buildDateRangeCondition(e,i)}if(!n||n.length===0)return t===`equals`?this.databaseAdapter.buildBooleanLiteral(!1):null;let a=n.filter(e=>!(e==null||e===``||typeof e==`string`&&e.includes(`\0`))).map(this.databaseAdapter.convertFilterValue);if(a.length===0&&![`set`,`notSet`].includes(t))return t===`equals`?this.databaseAdapter.buildBooleanLiteral(!1):null;let o=a[0];switch(t){case`equals`:return a.length>1?r?.type===`time`?(0,u.inArray)(e,a.map(e=>this.dateTimeBuilder.normalizeDate(e)||e)):(0,u.inArray)(e,a):a.length===1?(0,u.eq)(e,r?.type===`time`&&this.dateTimeBuilder.normalizeDate(o)||o):this.databaseAdapter.buildBooleanLiteral(!1);case`notEquals`:return a.length>1?(0,u.notInArray)(e,a):a.length===1?(0,u.ne)(e,o):null;case`contains`:return this.databaseAdapter.buildStringCondition(e,`contains`,o);case`notContains`:return this.databaseAdapter.buildStringCondition(e,`notContains`,o);case`startsWith`:return this.databaseAdapter.buildStringCondition(e,`startsWith`,o);case`endsWith`:return this.databaseAdapter.buildStringCondition(e,`endsWith`,o);case`gt`:return(0,u.gt)(e,o);case`gte`:return(0,u.gte)(e,o);case`lt`:return(0,u.lt)(e,o);case`lte`:return(0,u.lte)(e,o);case`set`:return(0,u.isNotNull)(e);case`notSet`:return(0,u.isNull)(e);case`inDateRange`:if(a.length>=2){let t=this.dateTimeBuilder.normalizeDate(a[0]),r=this.dateTimeBuilder.normalizeDate(a[1]);if(t&&r){let i=n[1];if(typeof i==`string`&&/^\d{4}-\d{2}-\d{2}$/.test(i.trim())){let e=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),t=new Date(e);t.setUTCHours(23,59,59,999),r=this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}return(0,u.and)((0,u.gte)(e,t),(0,u.lte)(e,r))}}return null;case`beforeDate`:{let t=this.dateTimeBuilder.normalizeDate(o);return t?(0,u.lt)(e,t):null}case`afterDate`:{let t=this.dateTimeBuilder.normalizeDate(o);return t?(0,u.gt)(e,t):null}case`between`:return a.length>=2?(0,u.and)((0,u.gte)(e,a[0]),(0,u.lte)(e,a[1])):null;case`notBetween`:return a.length>=2?(0,u.or)((0,u.lt)(e,a[0]),(0,u.gt)(e,a[1])):null;case`in`:return a.length>0?(0,u.inArray)(e,a):null;case`notIn`:return a.length>0?(0,u.notInArray)(e,a):null;case`like`:return this.databaseAdapter.buildStringCondition(e,`like`,o);case`notLike`:return this.databaseAdapter.buildStringCondition(e,`notLike`,o);case`ilike`:return this.databaseAdapter.buildStringCondition(e,`ilike`,o);case`regex`:return this.databaseAdapter.buildStringCondition(e,`regex`,o);case`notRegex`:return this.databaseAdapter.buildStringCondition(e,`notRegex`,o);case`isEmpty`:return(0,u.or)((0,u.isNull)(e),(0,u.eq)(e,``));case`isNotEmpty`:return(0,u.and)((0,u.isNotNull)(e),(0,u.ne)(e,``));case`arrayContains`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayContains)(e,a):null;case`arrayOverlaps`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayOverlaps)(e,a):null;case`arrayContained`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayContained)(e,a):null;default:return null}}buildLogicalFilter(e,t,n){if(`and`in e&&e.and){let r=e.and.map(e=>this.buildSingleFilter(e,t,n)).filter(e=>e!==null);return r.length>0?r.length===1?r[0]:(0,u.and)(...r):null}if(`or`in e&&e.or){let r=e.or.map(e=>this.buildSingleFilter(e,t,n)).filter(e=>e!==null);return r.length>0?r.length===1?r[0]:(0,u.or)(...r):null}return null}buildSingleFilter(e,t,n){if(`and`in e||`or`in e)return this.buildLogicalFilter(e,t,n);let r=e,[i,a]=r.member.split(`.`),o=t.get(i);if(!o)return null;let s=o.dimensions?.[a];if(!s)return null;let c=s.type===`time`?k(s.sql,n):typeof s.sql==`function`?s.sql(n):s.sql;return this.buildFilterCondition(c,r.operator,r.values,s,r.dateRange)}},M=class{dependencyGraph;cubes;constructor(e){this.cubes=e instanceof Map?e:new Map([[e.name,e]]),this.dependencyGraph=new Map}extractDependencies(e){if(e.length>1e3)return[];let t=e.matchAll(/\{([^}]+)\}/g),n=[];for(let e of t){let t=e[1].trim();if(t.includes(`.`)){let[e,r]=t.split(`.`);n.push({measureName:t,cubeName:e.trim(),fieldName:r.trim()})}else n.push({measureName:t,cubeName:null,fieldName:t})}return n}buildGraph(e){for(let[t,n]of Object.entries(e.measures))if(n.type===`calculated`&&n.calculatedSql){let r=`${e.name}.${t}`,i=this.extractDependencies(n.calculatedSql),a=new Set;for(let t of i){let n=`${t.cubeName||e.name}.${t.fieldName}`;a.add(n)}this.dependencyGraph.set(r,{id:r,dependencies:a,inDegree:0})}this.calculateInDegrees()}buildGraphForMultipleCubes(e){for(let t of e.values())this.buildGraph(t)}calculateInDegrees(){for(let e of this.dependencyGraph.values())e.inDegree=0;for(let e of this.dependencyGraph.values())for(let t of e.dependencies){let e=this.dependencyGraph.get(t);e&&e.inDegree++}}topologicalSort(e){let t=new Map,n=[],r=[];for(let n of e){let e=this.dependencyGraph.get(n);e&&t.set(n,{id:e.id,dependencies:new Set(e.dependencies),inDegree:0})}for(let e of t.values()){let n=0;for(let r of e.dependencies)t.has(r)&&n++;e.inDegree=n}for(let[e,r]of t)r.inDegree===0&&n.push(e);for(;n.length>0;){let e=n.shift();r.push(e);for(let[r,i]of t)i.dependencies.has(e)&&(i.inDegree--,i.inDegree===0&&n.push(r))}if(r.length<t.size){let e=this.detectCycle();throw Error(`Circular dependency detected in calculated measures: ${e?e.join(` -> `):`unknown cycle`}`)}return r}detectCycle(){let e=new Set,t=new Set,n=[];for(let r of this.dependencyGraph.keys())if(!e.has(r)){let i=this.dfs(r,e,t,n);if(i)return i}return null}dfs(e,t,n,r){t.add(e),n.add(e),r.push(e);let i=this.dependencyGraph.get(e);if(!i)return r.pop(),n.delete(e),null;for(let e of i.dependencies)if(!t.has(e)){let i=this.dfs(e,t,n,r);if(i)return i}else if(n.has(e)){let t=r.indexOf(e);return[...r.slice(t),e]}return r.pop(),n.delete(e),null}getAllDependencies(e){let t=new Set,n=new Set,r=e=>{if(n.has(e))return;n.add(e);let i=this.dependencyGraph.get(e);if(i)for(let e of i.dependencies)t.add(e),r(e)};return r(e),t}validateDependencies(e){for(let[t,n]of Object.entries(e.measures))if(n.type===`calculated`&&n.calculatedSql){let r=this.extractDependencies(n.calculatedSql);for(let n of r){let r=n.cubeName||e.name,i=this.cubes.get(r);if(!i)throw Error(`Calculated measure '${e.name}.${t}' references unknown cube '${r}'`);if(!i.measures[n.fieldName])throw Error(`Calculated measure '${e.name}.${t}' references unknown measure '${n.measureName}'`);if(r===e.name&&n.fieldName===t)throw Error(`Calculated measure '${e.name}.${t}' cannot reference itself`)}}}populateDependencies(e){for(let[,t]of Object.entries(e.measures))t.type===`calculated`&&t.calculatedSql&&!t.dependencies&&(t.dependencies=this.extractDependencies(t.calculatedSql).map(e=>e.measureName))}static isCalculatedMeasure(e){return e.type===`calculated`&&!!e.calculatedSql}};function We(e,t){let{cube:n,allCubes:r,resolvedMeasures:i}=t,a=Ge(e),o=new Map;for(let e of a){let{originalRef:t,cubeName:a,fieldName:s}=e,c=a||n.name;if(!r.get(c))throw Error(`Cannot substitute {${t}}: cube '${c}' not found`);let l=`${c}.${s}`,d=i.get(l);if(!d)throw Error(`Cannot substitute {${t}}: measure '${l}' not resolved yet. Ensure measures are resolved in dependency order.`);let f=u.sql`${d()}`;o.set(t,f)}let s=[],c=[],l=0;for(let t of a){let n=`{${t.originalRef}}`,r=e.indexOf(n,l);if(r>=0){s.push(e.substring(l,r));let i=o.get(t.originalRef);i&&c.push(i),l=r+n.length}}if(s.push(e.substring(l)),c.length===0)return u.sql.raw(e);let d=[];for(let e=0;e<s.length;e++)s[e]&&d.push(new u.StringChunk(s[e])),e<c.length&&d.push(c[e]);return u.sql.join(d,u.sql.raw(``))}function Ge(e){if(e.length>1e3)return[];let t=e.matchAll(/\{([^}]+)\}/g),n=[];for(let e of t){let t=e[1].trim();if(t.includes(`.`)){let[e,r]=t.split(`.`).map(e=>e.trim());n.push({originalRef:t,cubeName:e,fieldName:r})}else n.push({originalRef:t,cubeName:null,fieldName:t})}return n}function Ke(e){let t=[],n=0;for(let r=0;r<e.length;r++)if(e[r]===`{`)n++;else if(e[r]===`}`&&(n--,n<0)){t.push(`Unmatched closing brace at position ${r}`);break}n>0&&t.push(`Unmatched opening brace in template`),/\{\s*\}/.test(e)&&t.push(`Empty member reference {} found in template`),/\{[^}]*\{/.test(e)&&t.push(`Nested braces are not allowed in member references`);let r=Ge(e);for(let e of r){let n=e.cubeName?`${e.cubeName}.${e.fieldName}`:e.fieldName;/^[a-zA-Z_][a-zA-Z0-9_.]*$/.test(n)||t.push(`Invalid member reference {${e.originalRef}}: must start with letter or underscore, and contain only letters, numbers, underscores, and dots`),n.split(`.`).length>2&&t.push(`Invalid member reference {${e.originalRef}}: only one dot allowed (Cube.measure format)`)}return{isValid:t.length===0,errors:t}}function qe(e,t){let n=Ge(e),r=new Set;for(let e of n){let n=`${e.cubeName||t}.${e.fieldName}`;r.add(n)}return Array.from(r)}var N=class e{constructor(e){this.databaseAdapter=e}buildResolvedMeasures(t,n,r,i){let a=new Map,o=[],s=[],c=new Set(t),l=new M(n);for(let e of n.values())l.buildGraph(e);let u=[];for(let r of t){let[t,i]=r.split(`.`),a=n.get(t);if(a&&a.measures&&a.measures[i]){let d=a.measures[i];if(e.isPostAggregationWindow(d)){u.push(r);let n=e.getWindowBaseMeasure(d,t);n&&c.add(n);continue}M.isCalculatedMeasure(d)?(s.push(r),qe(d.calculatedSql,t).forEach(e=>c.add(e)),l.getAllDependencies(r).forEach(e=>{let[t,r]=e.split(`.`),i=n.get(t);if(i&&i.measures[r]){let e=i.measures[r];M.isCalculatedMeasure(e)&&qe(e.calculatedSql,t).forEach(e=>c.add(e))}})):o.push(r)}}for(let t of c){let[r,i]=t.split(`.`),a=n.get(r);if(a&&a.measures&&a.measures[i]){let n=a.measures[i];if(e.isPostAggregationWindow(n))continue;M.isCalculatedMeasure(n)?s.includes(t)||s.push(t):o.includes(t)||o.push(t)}}for(let e of o){let[t,o]=e.split(`.`),s=n.get(t),c=s.measures[o];if(i){let t=i(e,c,s);a.set(e,()=>t)}else a.set(e,()=>this.buildMeasureExpression(c,r,s))}if(s.length>0){let e=l.topologicalSort(s);for(let t of e){let[e,i]=t.split(`.`),o=n.get(e),s=o.measures[i];a.set(t,()=>this.buildCalculatedMeasure(s,o,n,a,r))}}return a}buildCalculatedMeasure(e,t,n,r,i){if(!e.calculatedSql)throw Error(`Calculated measure '${t.name}.${e.name}' missing calculatedSql property`);return We(this.databaseAdapter.preprocessCalculatedTemplate(e.calculatedSql),{cube:t,allCubes:n,resolvedMeasures:r,queryContext:i})}buildCTECalculatedMeasure(e,t,n,r,i){if(!e.calculatedSql)throw Error(`Calculated measure '${t.name}.${e.name||`unknown`}' missing calculatedSql property`);let a=new Map,o=qe(e.calculatedSql,t.name);for(let e of o){let[t,i]=e.split(`.`),o=r.get(t);if(o&&o.measures[i]){let t=o.measures[i];if(n.measures.includes(e)){let r=u.sql`${u.sql.identifier(n.cteAlias)}.${u.sql.identifier(i)}`,o;switch(t.type){case`count`:case`countDistinct`:case`sum`:o=(0,u.sum)(r);break;case`avg`:o=this.databaseAdapter.buildAvg(r);break;case`min`:o=(0,u.min)(r);break;case`max`:o=(0,u.max)(r);break;case`number`:o=(0,u.sum)(r);break;default:o=(0,u.sum)(r)}a.set(e,()=>o)}}}return this.buildCalculatedMeasure(e,t,r,a,i)}buildHavingMeasureExpression(e,t,n,r,i){if(i&&i.preAggregationCTEs){let a=i.preAggregationCTEs.find(t=>t.cube.name===e);if(a&&a.measures.includes(`${e}.${t}`))if(n.type===`calculated`&&n.calculatedSql){let t=i.primaryCube.name===e?i.primaryCube:i.joinCubes?.find(t=>t.cube.name===e)?.cube;if(!t)throw Error(`Cube ${e} not found in query plan`);let o=new Map([[i.primaryCube.name,i.primaryCube]]);if(i.joinCubes)for(let e of i.joinCubes)o.set(e.cube.name,e.cube);return this.buildCTECalculatedMeasure(n,t,a,o,r)}else{let e=u.sql`${u.sql.identifier(a.cteAlias)}.${u.sql.identifier(t)}`;switch(n.type){case`count`:case`countDistinct`:case`sum`:return(0,u.sum)(e);case`avg`:return this.databaseAdapter.buildAvg(e);case`min`:return(0,u.min)(e);case`max`:return(0,u.max)(e);case`number`:return(0,u.sum)(e);default:return(0,u.sum)(e)}}}return this.buildMeasureExpression(n,r)}buildMeasureExpression(t,n,r){if(t.type===`calculated`)throw Error(`Cannot build calculated measure '${t.name}' directly. Use buildCalculatedMeasure instead.`);if(e.isPostAggregationWindow(t))throw Error(`Post-aggregation window measure '${t.name}' should be built via buildPostAggregationWindowExpression, not buildMeasureExpression.`);if(!t.sql)throw Error(`Measure '${t.name}' of type '${t.type}' is missing required 'sql' property. Only calculated measures and post-aggregation window functions can omit 'sql'.`);let i=k(t.sql,n);if(n.ungrouped)return i;if(t.filters&&t.filters.length>0){let e=t.filters.map(e=>{let t=e(n);return t?u.sql`(${t})`:void 0}).filter(Boolean);if(e.length>0){let t=e.length===1?e[0]:(0,u.and)(...e);i=this.databaseAdapter.buildCaseWhen([{when:t,then:i}])}}switch(t.type){case`count`:return(0,u.count)(i);case`countDistinct`:return(0,u.countDistinct)(i);case`sum`:return(0,u.sum)(i);case`avg`:return this.databaseAdapter.buildAvg(i);case`min`:return(0,u.min)(i);case`max`:return(0,u.max)(i);case`number`:return i;case`stddev`:case`stddevSamp`:{let e=t.type===`stddevSamp`||t.statisticalConfig?.useSample,n=this.databaseAdapter.buildStddev(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`variance`:case`varianceSamp`:{let e=t.type===`varianceSamp`||t.statisticalConfig?.useSample,n=this.databaseAdapter.buildVariance(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`percentile`:case`median`:case`p95`:case`p99`:{let e;switch(t.type){case`median`:e=50;break;case`p95`:e=95;break;case`p99`:e=99;break;default:e=t.statisticalConfig?.percentile??50}let n=this.databaseAdapter.buildPercentile(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`lag`:case`lead`:case`rank`:case`denseRank`:case`rowNumber`:case`ntile`:case`firstValue`:case`lastValue`:case`movingAvg`:case`movingSum`:{let e=t.windowConfig||{},a;if(e.partitionBy&&e.partitionBy.length>0&&r){let t=e.partitionBy.map(e=>{let t=e.includes(`.`)?e.split(`.`)[1]:e,i=r.dimensions?.[t];return i?k(i.sql,n):(console.warn(`[drizzle-cube] Window function partition dimension '${e}' not found in cube '${r.name}'`),null)}).filter(e=>e!==null);t.length>0&&(a=t)}let o;if(e.orderBy&&e.orderBy.length>0&&r){let t=e.orderBy.map(e=>{let t=e.field.includes(`.`)?e.field.split(`.`)[1]:e.field,i=r.dimensions?.[t];if(i)return{field:k(i.sql,n),direction:e.direction};let a=r.measures?.[t];return a&&a.sql?{field:k(a.sql,n),direction:e.direction}:(console.warn(`[drizzle-cube] Window function order field '${e.field}' not found in cube '${r.name}'`),null)}).filter(e=>e!==null);t.length>0&&(o=t)}let s=this.databaseAdapter.buildWindowFunction(t.type,[`rank`,`denseRank`,`rowNumber`].includes(t.type)?null:i,a,o,{offset:e.offset,defaultValue:e.defaultValue,nTile:e.nTile,frame:e.frame});return s===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`NULL`):s}default:return(0,u.count)(i)}}static WINDOW_FUNCTION_TYPES=[`lag`,`lead`,`rank`,`denseRank`,`rowNumber`,`ntile`,`firstValue`,`lastValue`,`movingAvg`,`movingSum`];static isWindowFunction(t){return e.WINDOW_FUNCTION_TYPES.includes(t)}static categorizeMeasures(t,n){let r=[],i=[];for(let a of t){let[t,o]=a.split(`.`),s=n.get(t);if(s?.measures?.[o]){let t=s.measures[o];e.isWindowFunction(t.type)?r.push(a):i.push(a)}}return{windowMeasures:r,aggregateMeasures:i}}static hasWindowFunctions(t,n){let{windowMeasures:r}=e.categorizeMeasures(t,n);return r.length>0}static isPostAggregationWindow(t){return e.isWindowFunction(t.type)&&t.windowConfig?.measure!==void 0}static getWindowBaseMeasure(e,t){if(!e.windowConfig?.measure)return null;let n=e.windowConfig.measure;return n.includes(`.`)?n:`${t}.${n}`}static getDefaultWindowOperation(e){switch(e){case`lag`:case`lead`:return`difference`;default:return`raw`}}static categorizeForPostAggregation(t,n){let r=[],i=[],a=new Set;for(let o of t){let[t,s]=o.split(`.`),c=n.get(t);if(c?.measures?.[s]){let n=c.measures[s];if(e.isPostAggregationWindow(n)){i.push(o);let r=e.getWindowBaseMeasure(n,t);r&&a.add(r)}else e.isWindowFunction(n.type)||r.push(o)}}return{aggregateMeasures:r,postAggWindowMeasures:i,requiredBaseMeasures:a}}static hasPostAggregationWindows(t,n){let{postAggWindowMeasures:r}=e.categorizeForPostAggregation(t,n);return r.length>0}},Je=class{constructor(e){this.dateTimeBuilder=e}isWindowFunctionType(e){return[`lag`,`lead`,`rank`,`denseRank`,`rowNumber`,`ntile`,`firstValue`,`lastValue`,`movingAvg`,`movingSum`].includes(e)}isAggregateFunctionType(e){return[`count`,`countDistinct`,`sum`,`avg`,`min`,`max`,`stddev`,`stddevSamp`,`variance`,`varianceSamp`,`median`,`p95`,`p99`,`percentile`,`number`].includes(e)}buildGroupByFields(e,t,n,r){if(t.ungrouped)return[];let i=[],a=e instanceof Map?e:new Map([[e.name,e]]),o=t.dimensions&&t.dimensions.length>0||t.timeDimensions&&t.timeDimensions.length>0,s=t.measures&&t.measures.length>0,c=o&&!s,l=!1;for(let e of t.measures||[]){let[t,n]=e.split(`.`),r=a.get(t);if(r&&r.measures&&r.measures[n]){let e=r.measures[n];if(this.isAggregateFunctionType(e.type)||e.type===`calculated`){l=!0;break}if(N.isPostAggregationWindow(e)){let n=N.getWindowBaseMeasure(e,t);if(n){let[e,t]=n.split(`.`),r=a.get(e)?.measures?.[t];if(r&&this.isAggregateFunctionType(r.type)){l=!0;break}}}}}if(!l&&!c)return[];if(t.dimensions)for(let e of t.dimensions){let[t,o]=e.split(`.`),s=a.get(t);if(s&&s.dimensions&&s.dimensions[o]){let e=r?.preAggregationCTEs?.find(e=>e.cube.name===t);if(e){let t=e.joinKeys.find(e=>e.targetColumn===o);if(t&&t.sourceColumnObj)i.push(t.sourceColumnObj);else{let t=u.sql`${u.sql.identifier(e.cteAlias)}.${u.sql.identifier(o)}`;i.push(t)}}else{let e=s.dimensions[o],t=k(e.sql,n);i.push(t)}}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,o]=e.dimension.split(`.`),s=a.get(t);if(s&&s.dimensions&&s.dimensions[o]){let a=r?.preAggregationCTEs?.find(e=>e.cube.name===t);if(a){let t=a.joinKeys.find(e=>e.targetColumn===o);if(t&&t.sourceColumnObj){let r=this.dateTimeBuilder.buildTimeDimensionExpression(t.sourceColumnObj,e.granularity,n);i.push(r)}else{let e=u.sql`${u.sql.identifier(a.cteAlias)}.${u.sql.identifier(o)}`;i.push(e)}}else{let t=s.dimensions[o],r=this.dateTimeBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n);i.push(r)}}}return i}},Ye=class{dateTimeBuilder;filterBuilder;groupByBuilder;measureBuilder;constructor(e){this.dateTimeBuilder=new j(e),this.filterBuilder=new Ue(e,this.dateTimeBuilder),this.groupByBuilder=new Je(this.dateTimeBuilder),this.measureBuilder=new N(e)}buildResolvedMeasures(e,t,n,r){return this.measureBuilder.buildResolvedMeasures(e,t,n,r)}buildSelections(e,t,n){let r={},i=e instanceof Map?e:new Map([[e.name,e]]);if(t.dimensions)for(let e of t.dimensions){let[t,a]=e.split(`.`),o=i.get(t);if(o&&o.dimensions&&o.dimensions[a]){let t=o.dimensions[a];r[e]=u.sql`${k(t.sql,n)}`.as(e)}}if(t.measures){let e=this.buildResolvedMeasures(t.measures,i,n);for(let n of t.measures){let t=e.get(n);t&&typeof t==`function`&&(r[n]=u.sql`${t()}`.as(n))}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,a]=e.dimension.split(`.`),o=i.get(t);if(o&&o.dimensions&&o.dimensions[a]){let t=o.dimensions[a],i=this.buildTimeDimensionExpression(t.sql,e.granularity,n);r[e.dimension]=u.sql`${i}`.as(e.dimension)}}return Object.keys(r).length===0&&(r.count=(0,u.count)()),r}buildCalculatedMeasure(e,t,n,r,i){return this.measureBuilder.buildCalculatedMeasure(e,t,n,r,i)}buildCTECalculatedMeasure(e,t,n,r,i){return this.measureBuilder.buildCTECalculatedMeasure(e,t,n,r,i)}buildHavingMeasureExpression(e,t,n,r,i){return this.measureBuilder.buildHavingMeasureExpression(e,t,n,r,i)}buildMeasureExpression(e,t,n){return this.measureBuilder.buildMeasureExpression(e,t,n)}buildTimeDimensionExpression(e,t,n){return this.dateTimeBuilder.buildTimeDimensionExpression(e,t,n)}buildWhereConditions(e,t,n,r,i){let a=[],o=e instanceof Map?e:new Map([[e.name,e]]),s=new Set;if(t.filters&&t.filters.length>0)for(let e of t.filters){if(i&&`member`in e){let[t]=e.member.split(`.`);if(o.has(t)&&i.has(t)&&!s.has(t)){let e=i.get(t);a.push(...e),s.add(t);continue}else if(s.has(t))continue}let t=this.processFilter(e,o,n,`where`,r);t&&a.push(t)}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,i]=e.dimension.split(`.`),s=o.get(t);if(s&&s.dimensions[i]&&e.dateRange){if(r?.preAggregationCTEs&&r.preAggregationCTEs.some(e=>e.cube.name===t))continue;if(n.filterCache){let t=je(e.dimension,e.dateRange),r=n.filterCache.get(t);if(r){a.push(r);continue}}let o=s.dimensions[i],c=k(o.sql,n),l=this.buildDateRangeCondition(c,e.dateRange);l&&a.push(l)}}return a}buildHavingConditions(e,t,n,r){let i=[],a=e instanceof Map?e:new Map([[e.name,e]]);if(t.filters&&t.filters.length>0)for(let e of t.filters){let t=this.processFilter(e,a,n,`having`,r);t&&i.push(t)}return i}processFilter(e,t,n,r,i){if(`and`in e||`or`in e){let a=e;if(a.and){let e=a.and.map(e=>this.processFilter(e,t,n,r,i)).filter(e=>e!==null);return e.length>0?(0,u.and)(...e):null}if(a.or){let e=a.or.map(e=>this.processFilter(e,t,n,r,i)).filter(e=>e!==null);return e.length>0?(0,u.or)(...e):null}}let a=e,[o,s]=a.member.split(`.`),c=t.get(o);if(!c)return null;let l=c.dimensions[s],d=c.measures[s],f=l||d;if(!f)return null;if(r===`where`&&l){if(i?.preAggregationCTEs&&i.preAggregationCTEs.some(e=>e.cube.name===o))return null;let t=l.type===`time`;if(n.filterCache){let t=Ae(e),r=n.filterCache.get(t);if(r)return r}let r=t?k(l.sql,n):typeof l.sql==`function`?l.sql(n):l.sql;return this.buildFilterCondition(r,a.operator,a.values,f,a.dateRange)}else if(r===`where`&&d)return null;else if(r===`having`&&d){let e=this.buildHavingMeasureExpression(o,s,d,n,i);return this.buildFilterCondition(e,a.operator,a.values,f,a.dateRange)}return null}buildFilterCondition(e,t,n,r,i){return this.filterBuilder.buildFilterCondition(e,t,n,r,i)}buildDateRangeCondition(e,t){return this.dateTimeBuilder.buildDateRangeCondition(e,t)}buildGroupByFields(e,t,n,r){return this.groupByBuilder.buildGroupByFields(e,t,n,r)}buildOrderBy(e,t){let n=[],r=t||[...e.measures||[],...e.dimensions||[],...e.timeDimensions?.map(e=>e.dimension)||[]];if(e.order&&Object.keys(e.order).length>0)for(let[t,i]of Object.entries(e.order)){if(!r.includes(t))throw Error(`Cannot order by '${t}': field is not selected in the query`);let e=i===`desc`?(0,u.desc)(u.sql.identifier(t)):(0,u.asc)(u.sql.identifier(t));n.push(e)}if(e.timeDimensions&&e.timeDimensions.length>0){let t=new Set(Object.keys(e.order||{})),r=[...e.timeDimensions].sort((e,t)=>e.dimension.localeCompare(t.dimension));for(let e of r)t.has(e.dimension)||n.push((0,u.asc)(u.sql.identifier(e.dimension)))}return n}collectNumericFields(e,t){let n=[],r=e instanceof Map?e:new Map([[e.name,e]]);if(t.measures&&n.push(...t.measures),t.dimensions)for(let e of t.dimensions){let[t,i]=e.split(`.`),a=r.get(t);if(a){let t=a.dimensions[i];t&&t.type===`number`&&n.push(e)}}return n}applyLimitAndOffset(e,t){let n=t.limit;t.offset!==void 0&&t.offset>0&&n===void 0&&(n=50);let r=e;if(n!==void 0){if(n<0)throw Error(`Limit must be non-negative`);r=r.limit(n)}if(t.offset!==void 0){if(t.offset<0)throw Error(`Offset must be non-negative`);r=r.offset(t.offset)}return r}buildFilterConditionPublic(e,t,n,r,i){return this.buildFilterCondition(e,t,n,r,i)}buildLogicalFilter(e,t,n){return this.filterBuilder.buildLogicalFilter(e,t,n)}},Xe=class{cubes;connectivityCache=new Map;reverseIndex;constructor(e){this.cubes=e,this.reverseIndex=this.buildReverseIndex()}buildReverseIndex(){let e=new Map;for(let[t,n]of this.cubes)if(n.joins)for(let[,r]of Object.entries(n.joins)){if(r.relationship===`belongsToMany`)continue;let n=O(r.targetCube,this.cubes);if(!n)continue;let i=n.name,a=e.get(i);a||(a=[],e.set(i,a)),a.push({definingCube:t,joinDef:r})}return e}findPath(e,t,n=new Set){if(e===t)return[];let r=this.getCacheKey(e,t,n),i=this.getFromCache(r);if(i!==void 0)return i;let a=[{cube:e,path:[]}],o=new Set([e,...n]);for(;a.length>0;){let{cube:e,path:n}=a.shift(),i=this.cubes.get(e);if(i?.joins)for(let[,s]of Object.entries(i.joins)){let i=O(s.targetCube,this.cubes);if(!i)continue;let c=i.name;if(o.has(c))continue;let l=[...n,{fromCube:e,toCube:c,joinDef:s}];if(c===t)return this.setInCache(r,l),l;o.add(c),a.push({cube:c,path:l})}let s=this.reverseIndex.get(e)||[];for(let{definingCube:i,joinDef:c}of s){if(o.has(i))continue;let s=[...n,{fromCube:e,toCube:i,joinDef:c,reversed:!0}];if(i===t)return this.setInCache(r,s),s;o.add(i),a.push({cube:i,path:s})}}return this.setInCache(r,null),null}findPathPreferring(e,t,n,r=new Set){return this.findPathPreferringDetailed(e,t,n,r).selectedPath}findPathPreferringDetailed(e,t,n,r=new Set){let i=this.findAllPaths(e,t,new Set);if(i.length===0){let i=this.findPath(e,t,r),a=i?[{path:i,score:0,usesPreferredJoin:!1,preferredCubesInPath:0,usesProcessed:i.some(e=>r.has(e.toCube)),scoreBreakdown:{preferredJoinBonus:0,preferredCubeBonus:0,lengthPenalty:0}}]:[];return{strategy:`fallbackShortest`,preferredCubes:Array.from(n).sort(),selectedIndex:i?0:-1,candidates:a,selectedPath:i}}let a=i.map(i=>{let a=0,o=i.some((n,r)=>r===0?n.reversed?n.joinDef.preferredFor?.includes(e)??!1:n.joinDef.preferredFor?.includes(t)??!1:!1);o&&(a=10);let s=i.filter(e=>n.has(e.toCube)).length,c=s,l=i.length-1;return{path:i,score:a+c-l,usesPreferredJoin:o,preferredCubesInPath:s,usesProcessed:i.some(e=>r.has(e.toCube)),scoreBreakdown:{preferredJoinBonus:a,preferredCubeBonus:c,lengthPenalty:l}}});return a.sort((e,t)=>t.score===e.score?e.usesProcessed===t.usesProcessed?e.path.length-t.path.length:e.usesProcessed?-1:1:t.score-e.score),{strategy:`preferred`,preferredCubes:Array.from(n).sort(),selectedIndex:a.length>0?0:-1,candidates:a,selectedPath:a[0]?.path??null}}findAllPaths(e,t,n,r=4){if(e===t)return[[]];let i=[],a=[{cube:e,path:[],visited:new Set([e,...n])}];for(;a.length>0;){let{cube:e,path:n,visited:o}=a.shift();if(n.length>=r)continue;let s=this.cubes.get(e);if(s?.joins)for(let[,r]of Object.entries(s.joins)){let s=O(r.targetCube,this.cubes);if(!s)continue;let c=s.name;if(o.has(c))continue;let l=[...n,{fromCube:e,toCube:c,joinDef:r}];if(c===t)i.push(l);else{let e=new Set(o);e.add(c),a.push({cube:c,path:l,visited:e})}}let c=this.reverseIndex.get(e)||[];for(let{definingCube:r,joinDef:s}of c){if(o.has(r))continue;let c=[...n,{fromCube:e,toCube:r,joinDef:s,reversed:!0}];if(r===t)i.push(c);else{let e=new Set(o);e.add(r),a.push({cube:r,path:c,visited:e})}}}return i}canReachAll(e,t){let n=t.filter(t=>t!==e);for(let t of n){let n=this.findForwardOnlyPath(e,t,new Set);if(!n||n.length===0)return!1}return!0}findForwardOnlyPath(e,t,n){if(e===t)return[];let r=[{cube:e,path:[]}],i=new Set([e,...n]);for(;r.length>0;){let{cube:e,path:n}=r.shift(),a=this.cubes.get(e);if(a?.joins)for(let[,o]of Object.entries(a.joins)){let a=O(o.targetCube,this.cubes);if(!a)continue;let s=a.name;if(i.has(s))continue;let c=[...n,{fromCube:e,toCube:s,joinDef:o}];if(s===t)return c;i.add(s),r.push({cube:s,path:c})}}return null}buildJoinCondition(e,t,n){let r=[];for(let i of e.on){let e=t?u.sql`${u.sql.identifier(t)}.${u.sql.identifier(i.source.name)}`:Te(i.source),a=n?u.sql`${u.sql.identifier(n)}.${u.sql.identifier(i.target.name)}`:Te(i.target),o=i.as||u.eq;r.push(o(e,a))}return(0,u.and)(...r)}getReachableCubes(e){let t=new Set([e]),n=[e];for(;n.length>0;){let e=n.shift(),r=this.cubes.get(e);if(r?.joins)for(let[,e]of Object.entries(r.joins)){let r=O(e.targetCube,this.cubes);if(!r)continue;let i=r.name;t.has(i)||(t.add(i),n.push(i))}let i=this.reverseIndex.get(e)||[];for(let{definingCube:e}of i)t.has(e)||(t.add(e),n.push(e))}return t}getCacheKey(e,t,n){return`${e}:${t}:${Array.from(n).sort().join(`,`)}`}getFromCache(e){let t=this.connectivityCache.get(e);if(t)return t.path}setInCache(e,t){this.connectivityCache.set(e,{path:t})}},Ze=class{resolverCache=new WeakMap;getResolver(e){let t=this.resolverCache.get(e);return t||(t=new Xe(e),this.resolverCache.set(e,t)),t}analyzeCubeUsage(e){let t=new Set;if(e.measures)for(let n of e.measures){let[e]=n.split(`.`);t.add(e)}if(e.dimensions)for(let n of e.dimensions){let[e]=n.split(`.`);t.add(e)}if(e.timeDimensions)for(let n of e.timeDimensions){let[e]=n.dimension.split(`.`);t.add(e)}if(e.filters)for(let n of e.filters)this.extractCubeNamesFromFilter(n,t);if(e.order)for(let n of Object.keys(e.order)){let[e]=n.split(`.`);e&&t.add(e)}return t}collectPathHintCubes(e){return this.analyzeCubeUsage(e)}extractCubeNamesFromFilter(e,t){if(`and`in e||`or`in e){let n=e.and||e.or||[];for(let e of n)this.extractCubeNamesFromFilter(e,t);return}if(`member`in e){let[n]=e.member.split(`.`);n&&t.add(n)}}extractMeasuresFromFilters(e,t){let n=[];if(!e.filters)return n;for(let r of e.filters)this.extractMeasuresFromFilter(r,t,n);return n}extractMeasuresFromFilter(e,t,n){if(`and`in e||`or`in e){let r=e.and||e.or||[];for(let e of r)this.extractMeasuresFromFilter(e,t,n);return}if(`member`in e){let r=e.member,[i,a]=r.split(`.`);i===t.name&&t.measures&&t.measures[a]&&n.push(r)}}choosePrimaryCube(e,t,n){return e.length===1?e[0]:n?this.analyzePrimaryCubeSelection(e,t,n).selectedCube:[...e].sort()[0]}analyzePrimaryCube(e,t,n){return this.analyzePrimaryCubeSelection(e,t,n)}analyzeJoinPathForTarget(e,t,n,r){return this.analyzeJoinPath(e,t,n,r)}buildJoinPlanForPrimary(e,t,n,r,i){return this.buildJoinPlan(e,t,n,r,i)}buildPreAggregationCTEs(e,t,n,r,i){return this.planPreAggregationCTEs(e,t,n,r,i)}buildWarnings(e,t){return this.generateWarnings(e,t)}buildJoinPlan(e,t,n,r,i){let a=this.getResolver(e),o=[],s=new Set([t.name]),c=new Set;if(i.measures)for(let e of i.measures){let[t]=e.split(`.`);c.add(t)}let l=this.collectPathHintCubes(i),u=new Set;for(let n of c)n!==t.name&&this.findHasManyJoinDef(t,n,e)&&u.add(n);let d=n.filter(e=>e!==t.name);for(let n of d){if(s.has(n))continue;let i=new Set([...s].filter(e=>!u.has(e))),c=a.findPathPreferring(t.name,n,l,i);if(!c||c.length===0)throw Error(`No join path found from '${t.name}' to '${n}'`);for(let{fromCube:t,toCube:n,joinDef:i,reversed:l}of c){if(s.has(n))continue;let c=e.get(n);if(!c)throw Error(`Cube '${n}' not found`);let u=l?Ce(i.relationship):i.relationship;if(u===`belongsToMany`&&i.through){let e=ke(i,r.securityContext);o.push({cube:c,alias:`${n.toLowerCase()}_cube`,joinType:e.junctionJoins[1].joinType,joinCondition:e.junctionJoins[1].condition,relationship:`belongsToMany`,junctionTable:{table:i.through.table,alias:`junction_${n.toLowerCase()}`,joinType:e.junctionJoins[0].joinType,joinCondition:e.junctionJoins[0].condition,securitySql:i.through.securitySql,sourceCubeName:t}})}else{let e=a.buildJoinCondition(i,null,null),t=we(u,i.sqlJoinType);o.push({cube:c,alias:`${n.toLowerCase()}_cube`,joinType:t,joinCondition:e,relationship:u})}s.add(n)}}return o}planPreAggregationCTEs(e,t,n,r,i){let a=[];if(!r.measures||r.measures.length===0)return a;let o=this.computeCTEReasons(t,n,r);if(o.size===0)return a;for(let s of n){let n=o.get(s.cube.name);if(!n)continue;let c=s.cube,l=s.alias,u=r.measures.filter(e=>e.startsWith(c.name+`.`)),d=this.extractMeasuresFromFilters(r,c),f=[...new Set([...u,...d])];if(f.length===0)continue;let p=this.analyzeJoinPathToPrimary(e,t,c.name,i,r),m,h;if(p?.hasIntermediateHasMany&&p.intermediateJoins.length>0)m=p.correctJoinKeys,h=p.intermediateJoins;else{let n=(p?.path&&p.path.length>0?(()=>{let t=p.path[p.path.length-1],n=e.get(t.fromCube);return n?{sourceCube:n,joinDef:t.joinDef,reversed:t.reversed}:null})():null)??this.findJoinInfoForCube(e,t,c.name);if(!n)continue;m=n.joinDef.relationship===`belongsToMany`&&n.joinDef.through?n.sourceCube?.name===t.name&&!(`reversed`in n&&n.reversed)?n.joinDef.through.targetKey.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})):n.joinDef.through.sourceKey.map(e=>({sourceColumn:e.target.name,targetColumn:e.source.name,sourceColumnObj:e.target,targetColumnObj:e.source})):`reversed`in n&&n.reversed?n.joinDef.on.map(e=>({sourceColumn:e.target.name,targetColumn:e.source.name,sourceColumnObj:e.target,targetColumnObj:e.source})):n.joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})),h=void 0}let g=this.findPropagatingFilters(r,c,e),_=new Map([[c.name,c]]),{aggregateMeasures:v,requiredBaseMeasures:y}=N.categorizeForPostAggregation(f,_),b=[...new Set([...v,...Array.from(y).filter(e=>e.startsWith(c.name+`.`))])];if(b.length>0){let t=this.expandCalculatedMeasureDependencies(c,b),i=this.findDownstreamJoinKeys(c,r,e);a.push({cube:c,alias:l,cteAlias:`${c.name.toLowerCase()}_agg`,joinKeys:m,measures:t,propagatingFilters:g.length>0?g:void 0,downstreamJoinKeys:i.length>0?i:void 0,intermediateJoins:h&&h.length>0?h:void 0,cteType:`aggregate`,cteReason:n})}}return a}findJoinInfoToCube(e,t){for(let[,n]of e)if(n.name!==t&&n.joins)for(let[,r]of Object.entries(n.joins)){let i=O(r.targetCube,e);if(i&&i.name===t)return{sourceCube:n,joinDef:r}}return null}analyzeJoinPathToPrimary(e,t,n,r,i){let a=this.getResolver(e),o=this.collectPathHintCubes(i),s=o.size>0?a.findPathPreferring(t.name,n,o,new Set):a.findPath(t.name,n);if(!s||s.length===0)return null;let c=s.map(e=>({fromCube:e.fromCube,toCube:e.toCube,joinDef:e.joinDef,reversed:e.reversed}));if(!c.slice(0,-1).some(e=>(e.reversed?Ce(e.joinDef.relationship):e.joinDef.relationship)===`hasMany`))return{path:c,hasIntermediateHasMany:!1,intermediateJoins:[],correctJoinKeys:[]};let l=[];for(let t=0;t<c.length-1;t++){let n=c[t],i=c[t+1],a=e.get(n.toCube);if(!a)continue;let o=a.sql(r).where,s=i.joinDef.on[0]?.source,u=n.joinDef.on[0]?.target;l.push({cube:a,joinDef:i.joinDef,securityFilter:o,primaryJoinColumn:u,cteJoinColumn:s})}return{path:c,hasIntermediateHasMany:!0,intermediateJoins:l,correctJoinKeys:c[0].joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target}))}}computeCTEReasons(e,t,n){let r=new Map,i=new Set,a=new Set,o=new Set;if(n.measures)for(let e of n.measures){let[t]=e.split(`.`);o.add(t)}for(let e of t)e.relationship===`hasMany`||e.relationship===`belongsToMany`?i.add(e.cube.name):e.relationship===`belongsTo`&&o.has(e.cube.name)&&a.add(e.cube.name);if(i.size===0&&a.size===0)return r;for(let e of t)o.has(e.cube.name)&&(i.has(e.cube.name)?r.set(e.cube.name,`hasMany`):(a.has(e.cube.name)||i.size>0)&&r.set(e.cube.name,`fanOutPrevention`));return r}findJoinInfoForCube(e,t,n){if(t.joins)for(let[,r]of Object.entries(t.joins)){let i=O(r.targetCube,e);if(i&&i.name===n)return{sourceCube:t,joinDef:r}}let r=e.get(n);if(r?.joins)for(let[,n]of Object.entries(r.joins)){let i=O(n.targetCube,e);if(i&&i.name===t.name)return{sourceCube:r,joinDef:n,reversed:!0}}for(let[,r]of e)if(!(r.name===t.name||r.name===n)&&r.joins)for(let[,t]of Object.entries(r.joins)){let i=O(t.targetCube,e);if(i&&i.name===n)return{sourceCube:r,joinDef:t}}return null}findDownstreamJoinKeys(e,t,n){let r=[],i=new Set;if(t.dimensions)for(let n of t.dimensions){let[t]=n.split(`.`);t!==e.name&&i.add(t)}if(t.timeDimensions)for(let n of t.timeDimensions){let[t]=n.dimension.split(`.`);t!==e.name&&i.add(t)}if(t.filters){for(let e of t.filters)this.extractCubeNamesFromFilter(e,i);i.delete(e.name)}if(e.joins)for(let[,t]of Object.entries(e.joins)){let e=O(t.targetCube,n);if(!e)continue;let a=e.name;if(i.has(a)){let e;e=t.relationship===`belongsToMany`&&t.through?t.through.sourceKey.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})):t.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})),r.push({targetCubeName:a,joinKeys:e})}}return r}expandCalculatedMeasureDependencies(e,t){let n=new Set,r=[...t];for(;r.length>0;){let t=r.pop();if(n.has(t))continue;n.add(t);let[,i]=t.split(`.`);if(!e.measures||!e.measures[i])continue;let a=e.measures[i];if(a.type===`calculated`&&a.calculatedSql){let t=this.extractDependenciesFromTemplate(a.calculatedSql,e.name);for(let e of t)n.has(e)||r.push(e)}}return Array.from(n)}extractDependenciesFromTemplate(e,t){if(e.length>1e3)return[];let n=e.matchAll(/\{([^}]+)\}/g),r=[];for(let e of n){let n=e[1].trim();n.includes(`.`)?r.push(n):r.push(`${t}.${n}`)}return r}findHasManyJoinDef(e,t,n){if(!e.joins)return null;for(let[,r]of Object.entries(e.joins)){let e=O(r.targetCube,n);if(e&&e.name===t&&r.relationship===`hasMany`)return r}return null}findPropagatingFilters(e,t,n){let r=[];if(!e.filters)return r;let i=new Set;if(this.extractFilterCubeNamesToSet(e.filters,i),e.timeDimensions){for(let t of e.timeDimensions)if(t.dateRange){let[e]=t.dimension.split(`.`);e&&i.add(e)}}for(let a of i){if(a===t.name)continue;let i=n.get(a);if(i?.joins)for(let[,o]of Object.entries(i.joins)){let s=O(o.targetCube,n);if(s&&s.name===t.name&&o.relationship===`hasMany`){let t=this.extractFiltersForCube(e.filters,a),n=this.extractTimeDimensionFiltersForCube(e,a),s=[...t,...n];s.length>0&&o.on.length>0&&r.push({sourceCube:i,filters:s,joinConditions:o.on.map(e=>({source:e.source,target:e.target}))})}}}return r}extractFilterCubeNamesToSet(e,t){for(let n of e){if(`and`in n||`or`in n){let e=n.and||n.or||[];this.extractFilterCubeNamesToSet(e,t);continue}if(`member`in n){let[e]=n.member.split(`.`);e&&t.add(e)}}}extractFiltersForCube(e,t){let n=[];for(let r of e){if(`and`in r){let e=this.extractFiltersForCube(r.and||[],t);e.length>0&&n.push({and:e});continue}if(`or`in r){let e=r.or||[];if(this.allFiltersFromCube(e,t)){let r=this.extractFiltersForCube(e,t);r.length>0&&n.push({or:r})}continue}if(`member`in r){let[e]=r.member.split(`.`);e===t&&n.push(r)}}return n}allFiltersFromCube(e,t){for(let n of e){if(`and`in n){if(!this.allFiltersFromCube(n.and||[],t))return!1;continue}if(`or`in n){if(!this.allFiltersFromCube(n.or||[],t))return!1;continue}if(`member`in n){let[e]=n.member.split(`.`);if(e!==t)return!1}}return!0}extractTimeDimensionFiltersForCube(e,t){let n=[];if(!e.timeDimensions)return n;for(let r of e.timeDimensions){let[e]=r.dimension.split(`.`);e===t&&r.dateRange&&n.push({member:r.dimension,operator:`inDateRange`,values:Array.isArray(r.dateRange)?r.dateRange:[r.dateRange]})}return n}analyzePrimaryCubeSelection(e,t,n){if(e.length===1)return{selectedCube:e[0],reason:`single_cube`,explanation:`Only one cube is used in this query`};let r=[],i=(t.dimensions||[]).map(e=>e.split(`.`)[0]),a=new Map;for(let e of i)a.set(e,(a.get(e)||0)+1);let o=this.getResolver(n);for(let t of e){let i=n.get(t),s=a.get(t)||0,c=i?.joins?Object.keys(i.joins).length:0,l=o.canReachAll(t,e);r.push({cubeName:t,dimensionCount:s,joinCount:c,canReachAll:l})}if(t.dimensions&&t.dimensions.length>0){let e=Math.max(...r.map(e=>e.dimensionCount));if(e>0){let t=r.filter(t=>t.dimensionCount===e).sort((e,t)=>e.cubeName.localeCompare(t.cubeName));for(let e of t)if(e.canReachAll)return{selectedCube:e.cubeName,reason:`most_dimensions`,explanation:`Selected because it has ${e.dimensionCount} dimension${e.dimensionCount===1?``:`s`} in the query (defines the analytical grain)`,candidates:r}}}let s=r.filter(e=>e.canReachAll);if(s.length>0){let e=Math.max(...s.map(e=>e.joinCount)),t=s.filter(t=>t.joinCount===e).sort((e,t)=>e.cubeName.localeCompare(t.cubeName))[0];return{selectedCube:t.cubeName,reason:`most_connected`,explanation:`Selected because it has ${t.joinCount} join relationship${t.joinCount===1?``:`s`} and can reach all other cubes`,candidates:r}}return{selectedCube:[...e].sort()[0],reason:`alphabetical_fallback`,explanation:`Selected alphabetically as fallback (no cube could reach all others)`,candidates:r}}analyzeJoinPath(e,t,n,r){let i=this.getResolver(e),a=r?this.collectPathHintCubes(r):new Set,o=a.size>0?i.findPathPreferringDetailed(t,n,a):null,s=o?.selectedPath??i.findPath(t,n),c=[t];if(s)for(let e of s)c.push(e.toCube);if(!s||s.length===0)return{targetCube:n,pathFound:!1,error:`No join path found from '${t}' to '${n}'. Ensure the target cube has a relationship defined (belongsTo, hasOne, hasMany, or belongsToMany).`,visitedCubes:c,selection:this.buildJoinPathSelectionAnalysis(o)};let l=this.convertInternalPathToJoinPathSteps(s);return{targetCube:n,pathFound:!0,path:l,pathLength:l.length,visitedCubes:c,selection:this.buildJoinPathSelectionAnalysis(o)}}convertInternalPathToJoinPathSteps(e){return e.map(e=>{let t=e.reversed?Ce(e.joinDef.relationship):e.joinDef.relationship,n=we(t,e.joinDef.sqlJoinType),r=e.joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name})),i={fromCube:e.fromCube,toCube:e.toCube,relationship:t,joinType:n,joinColumns:r};if(e.reversed&&(i.reversed=!0),t===`belongsToMany`&&e.joinDef.through){let t=e.joinDef.through;i.junctionTable={tableName:t.table[Symbol.for(`drizzle:Name`)]||`junction_table`,sourceColumns:t.sourceKey.map(e=>e.target.name),targetColumns:t.targetKey.map(e=>e.source.name)}}return i})}buildJoinPathSelectionAnalysis(e){if(!e)return{strategy:`shortest`};let t=e.candidates.map((e,t)=>this.mapPreferredCandidate(e,t+1));return{strategy:e.strategy,preferredCubes:e.preferredCubes,selectedRank:e.selectedIndex>=0?e.selectedIndex+1:void 0,selectedScore:e.selectedIndex>=0?e.candidates[e.selectedIndex]?.score:void 0,candidates:t}}mapPreferredCandidate(e,t){return{rank:t,score:e.score,usesPreferredJoin:e.usesPreferredJoin,preferredCubesInPath:e.preferredCubesInPath,usesProcessed:e.usesProcessed,scoreBreakdown:e.scoreBreakdown,path:this.convertInternalPathToJoinPathSteps(e.path)}}generateWarnings(e,t){let n=[],r=this.checkFanOutNoDimensions(e,t);return r&&n.push(r),n}checkFanOutNoDimensions(e,t){if(!t||t.length===0||!e.measures||e.measures.length===0)return null;let n=new Set;for(let t of e.measures){let[e]=t.split(`.`);n.add(e)}if(n.size<2)return null;let r=e.dimensions&&e.dimensions.length>0,i=e.timeDimensions?.some(e=>e.granularity);return r||i?null:{code:`FAN_OUT_NO_DIMENSIONS`,message:`Query combines measures from multiple cubes with hasMany relationships but has no dimensions. Results are aggregated at the join key level, which may produce unexpected totals.`,severity:`warning`,cubes:[...n].sort(),measures:e.measures,suggestion:`Add a dimension to see per-group breakdowns, or add a time dimension with granularity.`}}},Qe=class{constructor(e){this.queryBuilder=e}buildPreAggregationCTE(e,t,n,r,i){let a=e.cube,o=a.sql(n),s=e.intermediateJoins&&e.intermediateJoins.length>0,c={};if(s&&e.intermediateJoins){let t=e.intermediateJoins[0].primaryJoinColumn;if(t){let e=t.name;c[e]=t}}else for(let t of e.joinKeys)if(t.targetColumnObj){c[t.targetColumn]=t.targetColumnObj;for(let[e,n]of Object.entries(a.dimensions||{}))n.sql===t.targetColumnObj&&e!==t.targetColumn&&(c[e]=u.sql`${t.targetColumnObj}`.as(e))}if(e.downstreamJoinKeys)for(let t of e.downstreamJoinKeys)for(let e of t.joinKeys)e.sourceColumnObj&&(c[e.sourceColumn]=e.sourceColumnObj);let l=a.name,d=new Map([[l,a]]),f=this.queryBuilder.buildResolvedMeasures(e.measures,d,n);for(let t of e.measures){let[,e]=t.split(`.`),n=f.get(t);n&&(c[e]=u.sql`${n()}`.as(e))}if(t.dimensions)for(let e of t.dimensions){let[t,r]=e.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let e=a.dimensions[r];c[r]=u.sql`${this.queryBuilder.buildMeasureExpression({sql:e.sql,type:`number`},n)}`.as(r)}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let t=a.dimensions[r];c[r]=u.sql`${this.queryBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n)}`.as(r)}}if(Object.keys(c).length===0)return null;let p=n.db.select(c).from(o.from);if(s&&e.intermediateJoins){let t=[...e.intermediateJoins].reverse();for(let e of t){let t=e.cube.sql(n),r=[(0,u.eq)(e.cteJoinColumn,e.joinDef.on[0]?.target)];e.securityFilter&&r.push(e.securityFilter),p=p.leftJoin(t.from,(0,u.and)(...r))}}let m=r?{...r,preAggregationCTEs:r.preAggregationCTEs?.filter(e=>e.cube.name!==a.name)}:void 0,h=this.queryBuilder.buildWhereConditions(a,t,n,m,i),g=[];if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]&&e.dateRange){let t=a.dimensions[r],i=this.queryBuilder.buildMeasureExpression({sql:t.sql,type:`number`},n),o=this.queryBuilder.buildDateRangeCondition(i,e.dateRange);o&&g.push(o)}}if(t.filters){for(let e of t.filters)if(!(`and`in e)&&!(`or`in e)&&`member`in e&&`operator`in e){let t=e,[r,i]=t.member.split(`.`);if(r===l&&a.dimensions&&a.dimensions[i]){let e=a.dimensions[i];if(t.operator===`inDateRange`){let r=this.queryBuilder.buildMeasureExpression({sql:e.sql,type:`number`},n),i=this.queryBuilder.buildDateRangeCondition(r,t.values);i&&g.push(i)}}}}if(e.propagatingFilters&&e.propagatingFilters.length>0)for(let t of e.propagatingFilters){let e=this.buildPropagatingFilterSubquery(t,n);e&&g.push(e)}let _=[];if(o.where&&_.push(o.where),_.push(...h,...g),_.length>0){let e=_.length===1?_[0]:(0,u.and)(..._);p=p.where(e)}let v=[],y=new Set,b=e=>{let t=e?.name||(typeof e==`string`?e:null);t&&!y.has(t)?(y.add(t),v.push(e)):t||v.push(e)};if(s&&e.intermediateJoins){let t=e.intermediateJoins[0];t.primaryJoinColumn&&b(t.primaryJoinColumn)}else for(let t of e.joinKeys)t.targetColumnObj&&b(t.targetColumnObj);if(e.downstreamJoinKeys)for(let t of e.downstreamJoinKeys)for(let e of t.joinKeys)e.sourceColumnObj&&b(e.sourceColumnObj);if(t.dimensions)for(let e of t.dimensions){let[t,r]=e.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let e=a.dimensions[r],t=k(e.sql,n);v.push(t)}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let t=a.dimensions[r],i=this.queryBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n);v.push(i)}}return v.length>0&&(p=p.groupBy(...v)),n.db.$with(e.cteAlias).as(p)}buildCTEJoinCondition(e,t,n){let r=n.preAggregationCTEs?.find(t=>t.cube.name===e.cube.name);if(!r)throw Error(`CTE info not found for cube ${e.cube.name}`);let i=[];if(r.intermediateJoins&&r.intermediateJoins.length>0){let e=r.intermediateJoins[0],a=this.resolveCTEJoinSourceColumn(r.joinKeys[0],r,n),o=u.sql`${u.sql.identifier(t)}.${u.sql.identifier(e.primaryJoinColumn.name)}`;i.push((0,u.eq)(a,o))}else for(let e of r.joinKeys){let a=this.resolveCTEJoinSourceColumn(e,r,n),o=u.sql`${u.sql.identifier(t)}.${u.sql.identifier(e.targetColumn)}`;i.push((0,u.eq)(a,o))}return i.length===1?i[0]:(0,u.and)(...i)}resolveCTEJoinSourceColumn(e,t,n){if(!e)throw Error(`Missing join key while building CTE join condition for '${t.cube.name}'`);let r=e.sourceColumnObj||u.sql.identifier(e.sourceColumn);if(!e.sourceColumnObj||!n.preAggregationCTEs)return r;for(let r of n.preAggregationCTEs)if(r.cube.name!==t.cube.name){for(let[t,n]of Object.entries(r.cube.dimensions||{}))if(typeof n.sql!=`function`&&n.sql===e.sourceColumnObj)return u.sql`${u.sql.identifier(r.cteAlias)}.${u.sql.identifier(t)}`}return r}buildPropagatingFilterSubquery(e,t){let n=e.sourceCube,r=n.sql(t),i=[];if(r.where&&i.push(r.where),e.preBuiltFilterSQL)i.push(e.preBuiltFilterSQL);else{let r={filters:e.filters},a=new Map([[n.name,n]]),o=this.queryBuilder.buildWhereConditions(a,r,t);i.push(...o)}if(i.length===0)return null;let a=i.length===1?i[0]:(0,u.and)(...i),o=e.joinConditions;if(o.length===1){let{source:e,target:n}=o[0];return u.sql`${n} IN ${t.db.select({pk:e}).from(r.from).where(a)}`}else{let e=(0,u.and)(...o.map(e=>(0,u.eq)(e.source,e.target)),a);return u.sql`EXISTS ${t.db.select({one:u.sql`1`}).from(r.from).where(e)}`}}};function $e(e,t,n){let r=[],i=et(new Date(e),n),a=et(new Date(t),n);for(;i<=a&&r.length<1e4;)r.push(new Date(i)),i=tt(i,n);return r}function et(e,t){let n=new Date(e);switch(t){case`second`:n.setUTCMilliseconds(0);break;case`minute`:n.setUTCSeconds(0,0);break;case`hour`:n.setUTCMinutes(0,0,0);break;case`day`:n.setUTCHours(0,0,0,0);break;case`week`:{let e=n.getUTCDay(),t=e===0?6:e-1;n.setUTCDate(n.getUTCDate()-t),n.setUTCHours(0,0,0,0);break}case`month`:n.setUTCDate(1),n.setUTCHours(0,0,0,0);break;case`quarter`:{let e=Math.floor(n.getUTCMonth()/3)*3;n.setUTCMonth(e,1),n.setUTCHours(0,0,0,0);break}case`year`:n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0);break}return n}function tt(e,t){let n=new Date(e);switch(t){case`second`:n.setUTCSeconds(n.getUTCSeconds()+1);break;case`minute`:n.setUTCMinutes(n.getUTCMinutes()+1);break;case`hour`:n.setUTCHours(n.getUTCHours()+1);break;case`day`:n.setUTCDate(n.getUTCDate()+1);break;case`week`:n.setUTCDate(n.getUTCDate()+7);break;case`month`:n.setUTCMonth(n.getUTCMonth()+1);break;case`quarter`:n.setUTCMonth(n.getUTCMonth()+3);break;case`year`:n.setUTCFullYear(n.getUTCFullYear()+1);break}return n}function nt(e){if(e instanceof Date)return e.toISOString();if(typeof e==`string`){let t=new Date(e);if(!isNaN(t.getTime()))return t.toISOString()}return String(e)}function rt(e,t){return t.length===0?`__all__`:t.map(t=>String(e[t]??``)).join(`|||`)}function it(e,t){let{timeDimensionKey:n,granularity:r,dateRange:i,fillValue:a,measures:o,dimensions:s}=t,c=$e(i[0],i[1],r);if(c.length===0)return e;let l=new Map;for(let t of e){let e=rt(t,s),r=nt(t[n]);l.has(e)||l.set(e,new Map),l.get(e).set(r,t)}l.size===0&&s.length===0&&l.set(`__all__`,new Map);let u=[];for(let[e,t]of l){let e=t.size>0?t.values().next().value:null;for(let r of c){let i=r.toISOString(),c=t.get(i);if(c)u.push(c);else{let t={[n]:i};if(e)for(let n of s)t[n]=e[n];for(let e of o)t[e]=a;u.push(t)}}}return u}function at(e){if(!e)return null;if(Array.isArray(e)){if(e.length<2)return null;let t=new Date(e[0]),n=new Date(e[1]);return isNaN(t.getTime())||isNaN(n.getTime())?null:[t,n]}let t=new Date(e);return isNaN(t.getTime())?null:[t,t]}function ot(e,t,n){if(!t.timeDimensions||t.timeDimensions.length===0)return e;let r=t.timeDimensions.filter(e=>{let t=e.fillMissingDates!==!1,n=e.granularity&&e.dateRange;return t&&n});if(r.length===0)return e;let i=t.fillMissingDatesValue===void 0?0:t.fillMissingDatesValue,a=new Set(t.timeDimensions.map(e=>e.dimension)),o=(t.dimensions||[]).filter(e=>!a.has(e)),s=e;for(let e of r){let t=at(e.dateRange);if(!t)continue;let r={timeDimensionKey:e.dimension,granularity:e.granularity,dateRange:t,fillValue:i,measures:n,dimensions:o};s=it(s,r)}return s}var st=class{dateTimeBuilder;constructor(e){this.dateTimeBuilder=new j(e)}hasComparison(e){return e.timeDimensions?.some(e=>e.compareDateRange&&e.compareDateRange.length>=2)??!1}getComparisonTimeDimension(e){return e.timeDimensions?.find(e=>e.compareDateRange&&e.compareDateRange.length>=2)}normalizePeriods(e){let t=[];for(let n=0;n<e.length;n++){let r=e[n],i,a,o;if(typeof r==`string`){let e=this.dateTimeBuilder.parseRelativeDateRange(r);if(e)i=e.start,a=e.end,o=r;else{let e=new Date(r);if(!isNaN(e.getTime()))i=new Date(e),i.setUTCHours(0,0,0,0),a=new Date(e),a.setUTCHours(23,59,59,999),o=r;else continue}}else{if(i=new Date(r[0]),a=new Date(r[1]),isNaN(i.getTime())||isNaN(a.getTime()))continue;/^\d{4}-\d{2}-\d{2}$/.test(r[1])&&a.setUTCHours(23,59,59,999),o=`${r[0]} - ${r[1]}`}t.push({start:i,end:a,label:o,index:n})}return t}createPeriodQuery(e,t){return{...e,timeDimensions:e.timeDimensions?.map(e=>e.compareDateRange?{...e,dateRange:[t.start.toISOString(),t.end.toISOString()],compareDateRange:void 0}:e)}}calculatePeriodDayIndex(e,t,n){let r=typeof e==`string`?new Date(e):e,i=t.getTime(),a=r.getTime();switch(n){case`second`:return Math.floor((a-i)/1e3);case`minute`:return Math.floor((a-i)/(1e3*60));case`hour`:return Math.floor((a-i)/(1e3*60*60));case`day`:return Math.floor((a-i)/(1e3*60*60*24));case`week`:return Math.floor((a-i)/(1e3*60*60*24*7));case`month`:{let e=t.getUTCFullYear(),n=t.getUTCMonth(),i=r.getUTCFullYear(),a=r.getUTCMonth();return(i-e)*12+(a-n)}case`quarter`:{let e=t.getUTCFullYear(),n=Math.floor(t.getUTCMonth()/3),i=r.getUTCFullYear(),a=Math.floor(r.getUTCMonth()/3);return(i-e)*4+(a-n)}case`year`:return r.getUTCFullYear()-t.getUTCFullYear();default:return Math.floor((a-i)/(1e3*60*60*24))}}addPeriodMetadata(e,t,n,r){return e.map(e=>{let i=e[n],a=0;if(i){let e=typeof i==`string`?new Date(i):i instanceof Date?i:null;e&&!isNaN(e.getTime())&&(a=this.calculatePeriodDayIndex(e,t.start,r))}return{...e,__period:t.label,__periodIndex:t.index,__periodDayIndex:a}})}mergeComparisonResults(e,t,n){let r=[],i={measures:{},dimensions:{},segments:{},timeDimensions:{}},a=e.map(e=>e.period);for(let{result:a,period:o}of e){let e=this.addPeriodMetadata(a.data,o,t.dimension,n);r.push(...e),i={measures:{...i.measures,...a.annotation.measures},dimensions:{...i.dimensions,...a.annotation.dimensions},segments:{...i.segments,...a.annotation.segments},timeDimensions:{...i.timeDimensions,...a.annotation.timeDimensions}}}let o={ranges:a.map(e=>[e.start.toISOString().split(`T`)[0],e.end.toISOString().split(`T`)[0]]),labels:a.map(e=>e.label),timeDimension:t.dimension,granularity:n};return{data:r,annotation:{...i,periods:o}}}sortComparisonResults(e,t){return[...e].sort((e,n)=>{let r=e.__periodIndex-n.__periodIndex;if(r!==0)return r;let i=e[t],a=n[t];return typeof i==`string`&&typeof a==`string`?new Date(i).getTime()-new Date(a).getTime():0})}},ct=class{filterBuilder;dateTimeBuilder;constructor(e){this.databaseAdapter=e,this.dateTimeBuilder=new j(e),this.filterBuilder=new Ue(e,this.dateTimeBuilder)}hasFunnel(e){return e.funnel!==void 0&&e.funnel.steps.length>=2}validateConfig(e,t){let n=[];if(e.steps.length<2&&n.push(`Funnel must have at least 2 steps`),typeof e.bindingKey==`string`){let[r,i]=e.bindingKey.split(`.`);if(!r||!i)n.push(`Invalid binding key format: ${e.bindingKey}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Binding key dimension not found: ${i} in cube ${r}`):n.push(`Binding key cube not found: ${r}`)}}else if(Array.isArray(e.bindingKey))for(let r of e.bindingKey){let e=t.get(r.cube);if(!e)n.push(`Binding key mapping cube not found: ${r.cube}`);else{let[,t]=r.dimension.split(`.`);e.dimensions?.[t]||n.push(`Binding key dimension not found: ${t} in cube ${r.cube}`)}}if(typeof e.timeDimension==`string`){let[r,i]=e.timeDimension.split(`.`);if(!r||!i)n.push(`Invalid time dimension format: ${e.timeDimension}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Time dimension not found: ${i} in cube ${r}`):n.push(`Time dimension cube not found: ${r}`)}}for(let r=0;r<e.steps.length;r++){let i=e.steps[r];if(i.name||n.push(`Step ${r} must have a name`),`cube`in i&&i.cube&&(t.get(i.cube)||n.push(`Step ${r} cube not found: ${i.cube}`)),i.filter){let a;`cube`in i&&i.cube?a=i.cube:typeof e.bindingKey==`string`&&([a]=e.bindingKey.split(`.`));let o=a?new Xe(t):null,s=Array.isArray(i.filter)?i.filter:[i.filter];for(let e of s)if(`member`in e){let[i,s]=e.member.split(`.`),c=t.get(i);if(!c)n.push(`Step ${r} filter cube not found: ${i}`);else if(c.dimensions?.[s]||(c.measures?.[s]?n.push(`Step ${r} filter '${i}.${s}' is a measure. Funnel step filters only support dimensions, not measures.`):n.push(`Step ${r} filter member not found: ${s} in cube ${i}`)),a&&i!==a&&o){let e=o.findPath(a,i);(!e||e.length===0)&&n.push(`Step ${r} filter '${i}.${s}' requires a join from '${a}' but no join path was found. Define a join relationship between these cubes.`)}}}i.timeToConvert&&r>0&&(/^P(?:\d+Y)?(?:\d+M)?(?:\d+D)?(?:T(?:\d+H)?(?:\d+M)?(?:\d+(?:\.\d+)?S)?)?$/.test(i.timeToConvert)||n.push(`Step ${r} timeToConvert must be ISO 8601 duration format: ${i.timeToConvert}`))}return{isValid:n.length===0,errors:n}}buildFunnelQuery(e,t,n){let r=this.resolveSteps(e,t,n),i=[];for(let e=0;e<r.length;e++){let t=e>0?i[e-1]:void 0;i.push(this.buildStepCTE(r[e],n,t))}let a=this.buildFunnelResultsCTE(i,r,e,n),o=this.buildAggregationCTE(a,i,r,e,n),s=[...i,a,o];return n.db.with(...s).select().from(o)}transformResult(e,t){if(!e||e.length===0)return[];let n=e[0],r=[],i=Number(n.step_0_count)||0;for(let e=0;e<t.steps.length;e++){let a=t.steps[e],o=Number(n[`step_${e}_count`])||0,s=e>0&&Number(n[`step_${e-1}_count`])||0,c={step:a.name,stepIndex:e,count:o,conversionRate:e===0?null:s>0?o/s:0,cumulativeConversionRate:i>0?o/i:0};t.includeTimeMetrics&&e>0&&(c.avgSecondsToConvert=n[`step_${e}_avg_seconds`]===null?null:Number(n[`step_${e}_avg_seconds`]),c.minSecondsToConvert=n[`step_${e}_min_seconds`]===null?null:Number(n[`step_${e}_min_seconds`]),c.maxSecondsToConvert=n[`step_${e}_max_seconds`]===null?null:Number(n[`step_${e}_max_seconds`]),n[`step_${e}_median_seconds`]!==void 0&&(c.medianSecondsToConvert=n[`step_${e}_median_seconds`]===null?null:Number(n[`step_${e}_median_seconds`])),n[`step_${e}_p90_seconds`]!==void 0&&(c.p90SecondsToConvert=n[`step_${e}_p90_seconds`]===null?null:Number(n[`step_${e}_p90_seconds`]))),r.push(c)}return r}extractFilterCubeNames(e){let t=new Set;if(!e.filter)return t;let n=Array.isArray(e.filter)?e.filter:[e.filter],r=e=>{if(`and`in e&&e.and)for(let t of e.and)r(t);else if(`or`in e&&e.or)for(let t of e.or)r(t);else if(`type`in e&&`filters`in e){let t=e;for(let e of t.filters||[])r(e)}else if(`member`in e){let[n]=e.member.split(`.`);t.add(n)}};for(let e of n)r(e);return t}resolveSteps(e,t,n){let r=new Xe(t);return e.steps.map((i,a)=>{let o=this.resolveCubeForStep(i,e,t),s=this.resolveBindingKey(e,o,n),c=this.resolveTimeDimension(e,o,n),l=this.buildStepFilters(i,o,t,n),u=this.extractFilterCubeNames(i),d=[];for(let e of u)if(e!==o.name){let n=t.get(e);if(n){let t=r.findPath(o.name,e);t&&t.length>0&&d.push({cube:n,joinPath:t})}}return{name:i.name,index:a,cube:o,bindingKeyExpr:s,timeExpr:c,filterConditions:l,timeToConvert:i.timeToConvert,joinedCubes:d}})}resolveCubeForStep(e,t,n){if(`cube`in e&&e.cube){let t=n.get(e.cube);if(!t)throw Error(`Cube not found for step: ${e.cube}`);return t}if(typeof t.bindingKey==`string`){let[e]=t.bindingKey.split(`.`),r=n.get(e);if(!r)throw Error(`Cube not found for binding key: ${t.bindingKey}`);return r}throw Error(`Cannot resolve cube for step - multi-cube funnel requires cube specification in each step`)}resolveBindingKey(e,t,n){if(typeof e.bindingKey==`string`){let[,r]=e.bindingKey.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Binding key dimension not found: ${e.bindingKey}`);return k(i.sql,n)}let r=e.bindingKey.find(e=>e.cube===t.name);if(!r)throw Error(`No binding key mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Binding key dimension not found: ${r.dimension}`);return k(a.sql,n)}resolveTimeDimension(e,t,n){if(typeof e.timeDimension==`string`){let[,r]=e.timeDimension.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Time dimension not found: ${e.timeDimension}`);return k(i.sql,n)}let r=e.timeDimension.find(e=>e.cube===t.name);if(!r)throw Error(`No time dimension mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Time dimension not found: ${r.dimension}`);return k(a.sql,n)}buildStepFilters(e,t,n,r){if(!e.filter)return[];let i=Array.isArray(e.filter)?e.filter:[e.filter],a=[];for(let e of i){let i=this.buildFilterCondition(e,t,n,r);i&&a.push(i)}return a}buildFilterCondition(e,t,n,r){let i=`and`in e||`or`in e,a=`type`in e&&`filters`in e&&(e.type===`and`||e.type===`or`);if(i||a){let i=[],o;if(a){let a=e;o=a.type===`and`;for(let e of a.filters||[]){let a=this.buildFilterCondition(e,t,n,r);a&&i.push(a)}}else{let a=e;o=`and`in a&&!!a.and;let s=a.and||a.or||[];for(let e of s){let a=this.buildFilterCondition(e,t,n,r);a&&i.push(a)}}return i.length===0?null:i.length===1?i[0]:o?(0,u.and)(...i):u.sql`(${u.sql.join(i,u.sql` OR `)})`}let o=e,[s,c]=o.member.split(`.`),l=o.dateRange!==void 0;if(o.operator!==`set`&&o.operator!==`notSet`&&!l&&(!o.values||o.values.length===0||o.values[0]===void 0||o.values[0]===``))return null;let d=n.get(s);if(!d)return null;if(s!==t.name){let e=new Xe(n).findPath(t.name,s);if(!e||e.length===0)return console.warn(`Funnel filter: Cannot filter by '${String(s).replace(/\n|\r/g,``)}.${String(c).replace(/\n|\r/g,``)}' in step using '${String(t.name).replace(/\n|\r/g,``)}'. No join path found. Filter will be skipped.`),null}let f=d.dimensions?.[c];if(!f)return null;let p=f.type===`time`?k(f.sql,r):typeof f.sql==`function`?f.sql(r):f.sql;return this.filterBuilder.buildFilterCondition(p,o.operator,o.values||[],f,o.dateRange)}buildStepCTE(e,t,n){return e.index===0?this.buildFirstStepCTE(e,t):this.buildSubsequentStepCTE(e,t,n)}buildFirstStepCTE(e,t){let n=`step_${e.index}`,r=e.cube.sql(t),i=[];r.where&&i.push(r.where),i.push(...e.filterConditions);let a=t.db.select({binding_key:u.sql`${e.bindingKeyExpr}`.as(`binding_key`),step_time:u.sql`MIN(${e.timeExpr})`.as(`step_time`)}).from(r.from);if(a=this.addCrossJoinsToQuery(a,e,t,i),i.length>0){let e=i.length===1?i[0]:(0,u.and)(...i);a=a.where(e)}return a=a.groupBy(e.bindingKeyExpr),t.db.$with(n).as(a)}buildSubsequentStepCTE(e,t,n){let r=`step_${e.index}`,i=`step_${e.index-1}`,a=e.cube.sql(t),o=[];a.where&&o.push(a.where),o.push(...e.filterConditions);let s=u.sql`${u.sql.identifier(i)}.step_time`,c=u.sql`${e.timeExpr} > ${s}`;if(e.timeToConvert){let t=this.databaseAdapter.buildDateAddInterval(s,e.timeToConvert);c=u.sql`${c} AND ${e.timeExpr} <= ${t}`}o.push(c);let l=t.db.select({binding_key:u.sql`${e.bindingKeyExpr}`.as(`binding_key`),step_time:u.sql`MIN(${e.timeExpr})`.as(`step_time`)}).from(a.from).innerJoin(n,u.sql`${e.bindingKeyExpr} = ${u.sql.identifier(i)}.binding_key`);if(l=this.addCrossJoinsToQuery(l,e,t,o),o.length>0){let e=o.length===1?o[0]:(0,u.and)(...o);l=l.where(e)}return l=l.groupBy(e.bindingKeyExpr),t.db.$with(r).as(l)}addCrossJoinsToQuery(e,t,n,r){if(t.joinedCubes.length===0)return e;for(let i of t.joinedCubes)for(let t of i.joinPath){let a=t.joinDef,o=[];for(let e of a.on)e.as?o.push(e.as(e.source,e.target)):o.push((0,u.eq)(e.source,e.target));let s=o.length===1?o[0]:(0,u.and)(...o),c=i.cube.sql(n);e=e.leftJoin(c.from,s),c.where&&r.push(c.where)}return e}buildFunnelResultsCTE(e,t,n,r){let i={binding_key:u.sql`s0.binding_key`,step_0_time:u.sql`s0.step_time`};for(let e=1;e<t.length;e++)i[`step_${e}_time`]=u.sql`s${u.sql.raw(String(e))}.step_time`;let a=u.sql`${u.sql.identifier(`step_0`)} s0`;for(let e=1;e<t.length;e++)a=u.sql`${a}
|
|
62
|
+
`),sql:t}}function ve(e){let t=0;for(let n of e)if(n===` `||n===`-`||n===`>`)t++;else break;return t}function ye(e){let t=e.replace(/^[\s\d:]*->/,``).trim();if(!t||/^(GlobalStats|partitions|bytes):/i.test(t)||/^\w+=\d+/.test(t))return null;let n=t.match(/^([A-Z][A-Za-z_]+(?:\s+[A-Z][A-Za-z_]+)*)(?:\s+(\S+))?/);if(!n)return null;let r=n[1],i=n[2]||void 0,a=t.match(/estimated rows:\s*(\d+)/i);return{type:r,table:i,estimatedRows:a?parseInt(a[1],10):void 0}}var be=class extends b{async execute(e,t){if(e&&typeof e==`object`&&typeof e.execute==`function`)try{let n=await e.execute();return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Snowflake] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}if(!this.db.execute)throw Error(`Snowflake database instance must have an execute method`);try{let n=await this.db.execute(e);return Array.isArray(n)?n.map(e=>this.convertNumericFields(e,t)):n}catch(t){let n=this.extractSqlFromQuery(e);throw console.error(`[Snowflake] Query execution failed:`,{error:t instanceof Error?t.message:String(t),sql:n.sql,params:n.params}),t}}extractSqlFromQuery(e){try{if(e&&typeof e.toSQL==`function`){let{sql:t,params:n}=e.toSQL();return{sql:t,params:n}}if(e&&typeof e.getSQL==`function`){let t=e.getSQL();if(t&&typeof t.toSQL==`function`){let{sql:e,params:n}=t.toSQL();return{sql:e,params:n}}}return{sql:String(e),params:[]}}catch{return{sql:`[unable to extract SQL]`,params:[]}}}convertNumericFields(e,t){if(!e||typeof e!=`object`)return e;let n={};for(let[r,i]of Object.entries(e))t&&t.includes(r)?n[r]=this.coerceToNumber(i):n[r]=i;return n}coerceToNumber(e){if(e==null||typeof e==`number`)return e;if(typeof e==`bigint`)return Number(e);if(e&&typeof e==`object`){if(typeof e.toString==`function`){let t=e.toString();if(/^-?\d+(\.\d+)?$/.test(t))return t.includes(`.`)?parseFloat(t):parseInt(t,10)}return e}if(typeof e==`string`){if(/^-?\d+(\.\d+)?$/.test(e))return e.includes(`.`)?parseFloat(e):parseInt(e,10);if(!isNaN(parseFloat(e))&&isFinite(parseFloat(e)))return parseFloat(e)}return e}getEngineType(){return`snowflake`}async explainQuery(e,t,n){if(n?.analyze,!this.db.execute)throw Error(`Snowflake database instance must have an execute method`);let r=await this.db.execute(u.sql`${u.sql.raw(`EXPLAIN`)} ${u.sql.raw(e.replace(/\?/g,()=>{let e=t.shift();return e===null?`NULL`:typeof e==`number`?String(e):typeof e==`boolean`?e?`TRUE`:`FALSE`:e instanceof Date?`'${e.toISOString()}'`:`'${String(e).replace(/'/g,`''`)}'`}))}`),i=[];if(Array.isArray(r)){for(let e of r)if(e&&typeof e==`object`){let t=e.content||e[`QUERY PLAN`]||e.plan||Object.values(e)[0];typeof t==`string`&&i.push(t)}}return _e(i,{sql:e,params:t})}async getTableIndexes(e){return[]}};function xe(e,t){return new be(e,t,`snowflake`)}function Se(e,t,n){if(n)switch(n){case`postgres`:return C(e,t);case`mysql`:return ne(e,t);case`sqlite`:return ie(e,t);case`singlestore`:return oe(e,t);case`duckdb`:return de(e,t);case`databend`:return ge(e,t);case`snowflake`:return xe(e,t)}if(e.all&&e.run)return ie(e,t);if(e.execute)return C(e,t);throw Error(`Unable to determine database engine type. Please specify engineType parameter.`)}function O(e,t){return typeof e==`string`?t?t.get(e)||(console.warn(`[drizzle-cube] Cannot resolve cube reference '${e}': no cube with that name is registered. Registered cubes: ${Array.from(t.keys()).join(`, `)||`(none)`}. Join will be skipped.`),null):(console.warn(`[drizzle-cube] Cannot resolve string cube reference '${e}': no cube registry provided. Join will be skipped.`),null):typeof e==`function`?e():e}function Ce(e){switch(e){case`belongsTo`:return`hasMany`;case`hasMany`:return`belongsTo`;case`hasOne`:return`hasOne`;case`belongsToMany`:return`belongsToMany`;default:return e}}function we(e,t){if(t)return t;switch(e){case`belongsTo`:return`inner`;case`hasOne`:return`left`;case`hasMany`:return`left`;case`belongsToMany`:return`left`;default:return`left`}}function Te(e){return e&&typeof e==`object`?u.sql`${u.sql`${e}`}`:e}function Ee(e){if(e===`__proto__`||e===`constructor`||e===`prototype`)throw Error(`Unsafe property key: ${e}`);return e}function k(e,t){return Te(typeof e==`function`?e(t):e)}function De(e,t,n){return{...e,cubes:t,currentCube:n}}function Oe(e,t){return{name:e,...t}}function ke(e,t){if(e.relationship!==`belongsToMany`||!e.through)throw Error(`expandBelongsToManyJoin can only be called on belongsToMany relationships with through configuration`);let{table:n,sourceKey:r,targetKey:i,securitySql:a}=e.through,o=[];for(let e of r){let t=e.as||u.eq;o.push(t(e.source,e.target))}let s=[];for(let e of i){let t=e.as||u.eq;s.push(t(e.source,e.target))}let c;if(a){let e=a(t);c=Array.isArray(e)?e:[e]}let l=we(`belongsToMany`,e.sqlJoinType);return{junctionJoins:[{joinType:l,table:n,condition:(0,u.and)(...o)},{joinType:l,table:n,condition:(0,u.and)(...s)}],junctionSecurityConditions:c}}function Ae(e){if(`and`in e)return`and:[${e.and.map(Ae).sort().join(`,`)}]`;if(`or`in e)return`or:[${e.or.map(Ae).sort().join(`,`)}]`;let t=e,n=JSON.stringify(Array.isArray(t.values)?[...t.values].sort():t.values),r=t.dateRange?`:dr:${JSON.stringify(t.dateRange)}`:``;return`${t.member}:${t.operator}:${n}${r}`}function je(e,t){return`timeDim:${e}:${JSON.stringify(t)}`}var Me=class{cache=new Map;stats={hits:0,misses:0};getOrBuild(e,t){let n=this.cache.get(e);if(n!==void 0)return this.stats.hits++,n;let r=t();return r&&this.cache.set(e,r),this.stats.misses++,r}has(e){return this.cache.has(e)}get(e){let t=this.cache.get(e);return t!==void 0&&this.stats.hits++,t}preload(e){for(let{key:t,sql:n}of e)this.cache.has(t)||this.cache.set(t,n)}set(e,t){this.cache.set(e,t)}getStats(){return{...this.stats,cacheSize:this.cache.size}}clear(){this.cache.clear(),this.stats={hits:0,misses:0}}};function Ne(e){let t=[];for(let n of e)`and`in n&&n.and?t.push(...Ne(n.and)):`or`in n&&n.or?t.push(...Ne(n.or)):`member`in n&&t.push(n);return t}function Pe(e,t,n={}){let r=n.keyPrefix??`drizzle-cube:`,i=Fe(e),a=`${r}query:${Ve(JSON.stringify(i))}`;if(n.includeSecurityContext!==!1){let e=Ve(n.securityContextSerializer?n.securityContextSerializer(t):JSON.stringify(Be(t)));a+=`:ctx:${e}`}return a}function Fe(e){return{measures:e.measures?[...e.measures].sort():void 0,dimensions:e.dimensions?[...e.dimensions].sort():void 0,filters:e.filters?A(e.filters):void 0,timeDimensions:e.timeDimensions?ze(e.timeDimensions):void 0,limit:e.limit,offset:e.offset,order:e.order?Be(e.order):void 0,fillMissingDatesValue:e.fillMissingDatesValue,funnel:e.funnel?Ie(e.funnel):void 0,flow:e.flow?Le(e.flow):void 0,retention:e.retention?Re(e.retention):void 0}}function Ie(e){return{bindingKey:e.bindingKey,timeDimension:e.timeDimension,steps:e.steps.map(e=>{let t={name:e.name,filter:e.filter?Array.isArray(e.filter)?A(e.filter):A([e.filter])[0]:void 0,timeToConvert:e.timeToConvert};return`cube`in e&&e.cube&&(t.cube=e.cube),t}),includeTimeMetrics:e.includeTimeMetrics,globalTimeWindow:e.globalTimeWindow}}function Le(e){return{bindingKey:e.bindingKey,timeDimension:e.timeDimension,eventDimension:e.eventDimension,startingStep:{name:e.startingStep.name,filter:e.startingStep.filter?Array.isArray(e.startingStep.filter)?A(e.startingStep.filter):A([e.startingStep.filter])[0]:void 0},stepsBefore:e.stepsBefore,stepsAfter:e.stepsAfter,entityLimit:e.entityLimit,outputMode:e.outputMode,joinStrategy:e.joinStrategy}}function Re(e){return{timeDimension:e.timeDimension,bindingKey:e.bindingKey,dateRange:e.dateRange,granularity:e.granularity,periods:e.periods,retentionType:e.retentionType,cohortFilters:e.cohortFilters?Array.isArray(e.cohortFilters)?A(e.cohortFilters):A([e.cohortFilters])[0]:void 0,activityFilters:e.activityFilters?Array.isArray(e.activityFilters)?A(e.activityFilters):A([e.activityFilters])[0]:void 0,breakdownDimensions:e.breakdownDimensions}}function A(e){return[...e].map(e=>{if(`and`in e&&e.and)return{and:A(e.and)};if(`or`in e&&e.or)return{or:A(e.or)};let t=e;return{...t,values:t.values?[...t.values].sort():t.values}}).sort((e,t)=>JSON.stringify(e).localeCompare(JSON.stringify(t)))}function ze(e){return[...e].map(e=>({dimension:e.dimension,granularity:e.granularity,dateRange:e.dateRange,fillMissingDates:e.fillMissingDates,compareDateRange:e.compareDateRange?[...e.compareDateRange].sort((e,t)=>{let n=Array.isArray(e)?e.join(`-`):e,r=Array.isArray(t)?t.join(`-`):t;return n.localeCompare(r)}):void 0})).sort((e,t)=>e.dimension.localeCompare(t.dimension))}function Be(e){return typeof e!=`object`||!e?e:Array.isArray(e)?e.map(Be):Object.keys(e).sort().reduce((t,n)=>(t[n]=Be(e[n]),t),{})}function Ve(e){let t=2166136261,n=Math.min(e.length,65536);for(let r=0;r<n;r++)t^=e.charCodeAt(r),t=t*16777619>>>0;return t.toString(16).padStart(8,`0`)}function He(e,t){return`${t??`drizzle-cube:`}*${e}*`}var j=class{constructor(e){this.databaseAdapter=e}buildTimeDimensionExpression(e,t,n){let r=k(e,n);return t?this.databaseAdapter.buildTimeDimension(t,r):r instanceof u.SQL?r:u.sql`${r}`}buildDateRangeCondition(e,t){if(!t)return null;if(Array.isArray(t)&&t.length>=2){let n=this.normalizeDate(t[0]),r=this.normalizeDate(t[1]);if(!n||!r)return null;if(typeof t[1]==`string`&&/^\d{4}-\d{2}-\d{2}$/.test(t[1].trim())){let e=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),t=new Date(e);t.setUTCHours(23,59,59,999),r=this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}return(0,u.and)((0,u.gte)(e,n),(0,u.lte)(e,r))}if(typeof t==`string`){let n=this.parseRelativeDateRange(t);if(n){let t,r;return this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?(t=Math.floor(n.start.getTime()/1e3),r=Math.floor(n.end.getTime()/1e3)):(t=n.start.getTime(),r=n.end.getTime()):(t=n.start.toISOString(),r=n.end.toISOString()),(0,u.and)((0,u.gte)(e,t),(0,u.lte)(e,r))}let r=this.normalizeDate(t);if(!r)return null;let i=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),a=new Date(i);a.setUTCHours(0,0,0,0);let o=new Date(i);o.setUTCHours(23,59,59,999);let s,c;return this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?(s=Math.floor(a.getTime()/1e3),c=Math.floor(o.getTime()/1e3)):(s=a.getTime(),c=o.getTime()):(s=a.toISOString(),c=o.toISOString()),(0,u.and)((0,u.gte)(e,s),(0,u.lte)(e,c))}return null}parseRelativeDateRange(e){let t=new Date,n=e.toLowerCase().trim(),r=t.getUTCFullYear(),i=t.getUTCMonth(),a=t.getUTCDate(),o=t.getUTCDay();if(n===`today`){let e=new Date(t);e.setUTCHours(0,0,0,0);let n=new Date(t);return n.setUTCHours(23,59,59,999),{start:e,end:n}}if(n===`yesterday`){let e=new Date(t);e.setUTCDate(a-1),e.setUTCHours(0,0,0,0);let n=new Date(t);return n.setUTCDate(a-1),n.setUTCHours(23,59,59,999),{start:e,end:n}}if(n===`this week`){let e=o===0?-6:1-o,n=new Date(t);n.setUTCDate(a+e),n.setUTCHours(0,0,0,0);let r=new Date(n);return r.setUTCDate(n.getUTCDate()+6),r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`this month`)return{start:new Date(Date.UTC(r,i,1,0,0,0,0)),end:new Date(Date.UTC(r,i+1,0,23,59,59,999))};if(n===`this quarter`){let e=Math.floor(i/3);return{start:new Date(Date.UTC(r,e*3,1,0,0,0,0)),end:new Date(Date.UTC(r,e*3+3,0,23,59,59,999))}}if(n===`this year`)return{start:new Date(Date.UTC(r,0,1,0,0,0,0)),end:new Date(Date.UTC(r,11,31,23,59,59,999))};let s=n.match(/^last\s+(\d+)\s+days?$/);if(s){let e=parseInt(s[1],10),n=new Date(t);n.setUTCDate(a-e+1),n.setUTCHours(0,0,0,0);let r=new Date(t);return r.setUTCHours(23,59,59,999),{start:n,end:r}}let c=n.match(/^last\s+(\d+)\s+weeks?$/);if(c){let e=parseInt(c[1],10)*7,n=new Date(t);n.setUTCDate(a-e+1),n.setUTCHours(0,0,0,0);let r=new Date(t);return r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`last week`){let e=o===0?-13:-6-o,n=new Date(t);n.setUTCDate(a+e),n.setUTCHours(0,0,0,0);let r=new Date(n);return r.setUTCDate(n.getUTCDate()+6),r.setUTCHours(23,59,59,999),{start:n,end:r}}if(n===`last month`)return{start:new Date(Date.UTC(r,i-1,1,0,0,0,0)),end:new Date(Date.UTC(r,i,0,23,59,59,999))};if(n===`last quarter`){let e=Math.floor(i/3),t=e===0?3:e-1,n=e===0?r-1:r;return{start:new Date(Date.UTC(n,t*3,1,0,0,0,0)),end:new Date(Date.UTC(n,t*3+3,0,23,59,59,999))}}if(n===`last year`)return{start:new Date(Date.UTC(r-1,0,1,0,0,0,0)),end:new Date(Date.UTC(r-1,11,31,23,59,59,999))};if(n===`last 12 months`){let e=new Date(Date.UTC(r,i-11,1,0,0,0,0)),n=new Date(t);return n.setUTCHours(23,59,59,999),{start:e,end:n}}let l=n.match(/^last\s+(\d+)\s+months?$/);if(l){let e=parseInt(l[1],10),n=new Date(Date.UTC(r,i-e+1,1,0,0,0,0)),a=new Date(t);return a.setUTCHours(23,59,59,999),{start:n,end:a}}let u=n.match(/^last\s+(\d+)\s+years?$/);if(u){let e=parseInt(u[1],10),n=new Date(Date.UTC(r-e,0,1,0,0,0,0)),i=new Date(t);return i.setUTCHours(23,59,59,999),{start:n,end:i}}return null}normalizeDate(e){if(!e)return null;if(e instanceof Date)return isNaN(e.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(e.getTime()/1e3):e.getTime():e.toISOString();if(typeof e==`number`){let t=e<1e10?e*1e3:e,n=new Date(t);return isNaN(n.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t/1e3):t:n.toISOString()}if(typeof e==`string`){if(/^\d{4}-\d{2}-\d{2}$/.test(e.trim())){let t=new Date(e+`T00:00:00Z`);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}let t=new Date(e);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}let t=new Date(e);return isNaN(t.getTime())?null:this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}},Ue=class{constructor(e,t){this.databaseAdapter=e,this.dateTimeBuilder=t}buildFilterCondition(e,t,n,r,i){if(i!==void 0){if(t!==`inDateRange`)throw Error(`dateRange can only be used with 'inDateRange' operator, but got '${t}'. Use explicit date values in the 'values' array for other date operators.`);if(r&&r.type!==`time`)throw Error(`dateRange can only be used on time dimensions, but field '${r.name||`unknown`}' has type '${r.type}'`);return this.dateTimeBuilder.buildDateRangeCondition(e,i)}if(!n||n.length===0)return t===`equals`?this.databaseAdapter.buildBooleanLiteral(!1):null;let a=n.filter(e=>!(e==null||e===``||typeof e==`string`&&e.includes(`\0`))).map(this.databaseAdapter.convertFilterValue);if(a.length===0&&![`set`,`notSet`].includes(t))return t===`equals`?this.databaseAdapter.buildBooleanLiteral(!1):null;let o=a[0];switch(t){case`equals`:return a.length>1?r?.type===`time`?(0,u.inArray)(e,a.map(e=>this.dateTimeBuilder.normalizeDate(e)||e)):(0,u.inArray)(e,a):a.length===1?(0,u.eq)(e,r?.type===`time`&&this.dateTimeBuilder.normalizeDate(o)||o):this.databaseAdapter.buildBooleanLiteral(!1);case`notEquals`:return a.length>1?(0,u.notInArray)(e,a):a.length===1?(0,u.ne)(e,o):null;case`contains`:return this.databaseAdapter.buildStringCondition(e,`contains`,o);case`notContains`:return this.databaseAdapter.buildStringCondition(e,`notContains`,o);case`startsWith`:return this.databaseAdapter.buildStringCondition(e,`startsWith`,o);case`endsWith`:return this.databaseAdapter.buildStringCondition(e,`endsWith`,o);case`gt`:return(0,u.gt)(e,o);case`gte`:return(0,u.gte)(e,o);case`lt`:return(0,u.lt)(e,o);case`lte`:return(0,u.lte)(e,o);case`set`:return(0,u.isNotNull)(e);case`notSet`:return(0,u.isNull)(e);case`inDateRange`:if(a.length>=2){let t=this.dateTimeBuilder.normalizeDate(a[0]),r=this.dateTimeBuilder.normalizeDate(a[1]);if(t&&r){let i=n[1];if(typeof i==`string`&&/^\d{4}-\d{2}-\d{2}$/.test(i.trim())){let e=typeof r==`number`?new Date(r*(this.databaseAdapter.getEngineType()===`sqlite`?1e3:1)):new Date(r),t=new Date(e);t.setUTCHours(23,59,59,999),r=this.databaseAdapter.isTimestampInteger()?this.databaseAdapter.getEngineType()===`sqlite`?Math.floor(t.getTime()/1e3):t.getTime():t.toISOString()}return(0,u.and)((0,u.gte)(e,t),(0,u.lte)(e,r))}}return null;case`beforeDate`:{let t=this.dateTimeBuilder.normalizeDate(o);return t?(0,u.lt)(e,t):null}case`afterDate`:{let t=this.dateTimeBuilder.normalizeDate(o);return t?(0,u.gt)(e,t):null}case`between`:return a.length>=2?(0,u.and)((0,u.gte)(e,a[0]),(0,u.lte)(e,a[1])):null;case`notBetween`:return a.length>=2?(0,u.or)((0,u.lt)(e,a[0]),(0,u.gt)(e,a[1])):null;case`in`:return a.length>0?(0,u.inArray)(e,a):null;case`notIn`:return a.length>0?(0,u.notInArray)(e,a):null;case`like`:return this.databaseAdapter.buildStringCondition(e,`like`,o);case`notLike`:return this.databaseAdapter.buildStringCondition(e,`notLike`,o);case`ilike`:return this.databaseAdapter.buildStringCondition(e,`ilike`,o);case`regex`:return this.databaseAdapter.buildStringCondition(e,`regex`,o);case`notRegex`:return this.databaseAdapter.buildStringCondition(e,`notRegex`,o);case`isEmpty`:return(0,u.or)((0,u.isNull)(e),(0,u.eq)(e,``));case`isNotEmpty`:return(0,u.and)((0,u.isNotNull)(e),(0,u.ne)(e,``));case`arrayContains`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayContains)(e,a):null;case`arrayOverlaps`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayOverlaps)(e,a):null;case`arrayContained`:return this.databaseAdapter.getEngineType()===`postgres`?(0,u.arrayContained)(e,a):null;default:return null}}buildLogicalFilter(e,t,n){if(`and`in e&&e.and){let r=e.and.map(e=>this.buildSingleFilter(e,t,n)).filter(e=>e!==null);return r.length>0?r.length===1?r[0]:(0,u.and)(...r):null}if(`or`in e&&e.or){let r=e.or.map(e=>this.buildSingleFilter(e,t,n)).filter(e=>e!==null);return r.length>0?r.length===1?r[0]:(0,u.or)(...r):null}return null}buildSingleFilter(e,t,n){if(`and`in e||`or`in e)return this.buildLogicalFilter(e,t,n);let r=e,[i,a]=r.member.split(`.`),o=t.get(i);if(!o)return null;let s=o.dimensions?.[a];if(!s)return null;let c=s.type===`time`?k(s.sql,n):typeof s.sql==`function`?s.sql(n):s.sql;return this.buildFilterCondition(c,r.operator,r.values,s,r.dateRange)}},M=class{dependencyGraph;cubes;constructor(e){this.cubes=e instanceof Map?e:new Map([[e.name,e]]),this.dependencyGraph=new Map}extractDependencies(e){if(e.length>1e3)return[];let t=e.matchAll(/\{([^}]+)\}/g),n=[];for(let e of t){let t=e[1].trim();if(t.includes(`.`)){let[e,r]=t.split(`.`);n.push({measureName:t,cubeName:e.trim(),fieldName:r.trim()})}else n.push({measureName:t,cubeName:null,fieldName:t})}return n}buildGraph(e){for(let[t,n]of Object.entries(e.measures))if(n.type===`calculated`&&n.calculatedSql){let r=`${e.name}.${t}`,i=this.extractDependencies(n.calculatedSql),a=new Set;for(let t of i){let n=`${t.cubeName||e.name}.${t.fieldName}`;a.add(n)}this.dependencyGraph.set(r,{id:r,dependencies:a,inDegree:0})}this.calculateInDegrees()}buildGraphForMultipleCubes(e){for(let t of e.values())this.buildGraph(t)}calculateInDegrees(){for(let e of this.dependencyGraph.values())e.inDegree=0;for(let e of this.dependencyGraph.values())for(let t of e.dependencies){let e=this.dependencyGraph.get(t);e&&e.inDegree++}}topologicalSort(e){let t=new Map,n=[],r=[];for(let n of e){let e=this.dependencyGraph.get(n);e&&t.set(n,{id:e.id,dependencies:new Set(e.dependencies),inDegree:0})}for(let e of t.values()){let n=0;for(let r of e.dependencies)t.has(r)&&n++;e.inDegree=n}for(let[e,r]of t)r.inDegree===0&&n.push(e);for(;n.length>0;){let e=n.shift();r.push(e);for(let[r,i]of t)i.dependencies.has(e)&&(i.inDegree--,i.inDegree===0&&n.push(r))}if(r.length<t.size){let e=this.detectCycle();throw Error(`Circular dependency detected in calculated measures: ${e?e.join(` -> `):`unknown cycle`}`)}return r}detectCycle(){let e=new Set,t=new Set,n=[];for(let r of this.dependencyGraph.keys())if(!e.has(r)){let i=this.dfs(r,e,t,n);if(i)return i}return null}dfs(e,t,n,r){t.add(e),n.add(e),r.push(e);let i=this.dependencyGraph.get(e);if(!i)return r.pop(),n.delete(e),null;for(let e of i.dependencies)if(!t.has(e)){let i=this.dfs(e,t,n,r);if(i)return i}else if(n.has(e)){let t=r.indexOf(e);return[...r.slice(t),e]}return r.pop(),n.delete(e),null}getAllDependencies(e){let t=new Set,n=new Set,r=e=>{if(n.has(e))return;n.add(e);let i=this.dependencyGraph.get(e);if(i)for(let e of i.dependencies)t.add(e),r(e)};return r(e),t}validateDependencies(e){for(let[t,n]of Object.entries(e.measures))if(n.type===`calculated`&&n.calculatedSql){let r=this.extractDependencies(n.calculatedSql);for(let n of r){let r=n.cubeName||e.name,i=this.cubes.get(r);if(!i)throw Error(`Calculated measure '${e.name}.${t}' references unknown cube '${r}'`);if(!i.measures[n.fieldName])throw Error(`Calculated measure '${e.name}.${t}' references unknown measure '${n.measureName}'`);if(r===e.name&&n.fieldName===t)throw Error(`Calculated measure '${e.name}.${t}' cannot reference itself`)}}}populateDependencies(e){for(let[,t]of Object.entries(e.measures))t.type===`calculated`&&t.calculatedSql&&!t.dependencies&&(t.dependencies=this.extractDependencies(t.calculatedSql).map(e=>e.measureName))}static isCalculatedMeasure(e){return e.type===`calculated`&&!!e.calculatedSql}};function We(e,t){let{cube:n,allCubes:r,resolvedMeasures:i}=t,a=Ge(e),o=new Map;for(let e of a){let{originalRef:t,cubeName:a,fieldName:s}=e,c=a||n.name;if(!r.get(c))throw Error(`Cannot substitute {${t}}: cube '${c}' not found`);let l=`${c}.${s}`,d=i.get(l);if(!d)throw Error(`Cannot substitute {${t}}: measure '${l}' not resolved yet. Ensure measures are resolved in dependency order.`);let f=u.sql`${d()}`;o.set(t,f)}let s=[],c=[],l=0;for(let t of a){let n=`{${t.originalRef}}`,r=e.indexOf(n,l);if(r>=0){s.push(e.substring(l,r));let i=o.get(t.originalRef);i&&c.push(i),l=r+n.length}}if(s.push(e.substring(l)),c.length===0)return u.sql.raw(e);let d=[];for(let e=0;e<s.length;e++)s[e]&&d.push(new u.StringChunk(s[e])),e<c.length&&d.push(c[e]);return u.sql.join(d,u.sql.raw(``))}function Ge(e){if(e.length>1e3)return[];let t=e.matchAll(/\{([^}]+)\}/g),n=[];for(let e of t){let t=e[1].trim();if(t.includes(`.`)){let[e,r]=t.split(`.`).map(e=>e.trim());n.push({originalRef:t,cubeName:e,fieldName:r})}else n.push({originalRef:t,cubeName:null,fieldName:t})}return n}function Ke(e){let t=[],n=0;for(let r=0;r<e.length;r++)if(e[r]===`{`)n++;else if(e[r]===`}`&&(n--,n<0)){t.push(`Unmatched closing brace at position ${r}`);break}n>0&&t.push(`Unmatched opening brace in template`),/\{\s*\}/.test(e)&&t.push(`Empty member reference {} found in template`),/\{[^}]*\{/.test(e)&&t.push(`Nested braces are not allowed in member references`);let r=Ge(e);for(let e of r){let n=e.cubeName?`${e.cubeName}.${e.fieldName}`:e.fieldName;/^[a-zA-Z_][a-zA-Z0-9_.]*$/.test(n)||t.push(`Invalid member reference {${e.originalRef}}: must start with letter or underscore, and contain only letters, numbers, underscores, and dots`),n.split(`.`).length>2&&t.push(`Invalid member reference {${e.originalRef}}: only one dot allowed (Cube.measure format)`)}return{isValid:t.length===0,errors:t}}function qe(e,t){let n=Ge(e),r=new Set;for(let e of n){let n=`${e.cubeName||t}.${e.fieldName}`;r.add(n)}return Array.from(r)}var N=class e{constructor(e){this.databaseAdapter=e}buildResolvedMeasures(t,n,r,i){let a=new Map,o=[],s=[],c=new Set(t),l=new M(n);for(let e of n.values())l.buildGraph(e);let u=[];for(let r of t){let[t,i]=r.split(`.`),a=n.get(t);if(a&&a.measures&&a.measures[i]){let d=a.measures[i];if(e.isPostAggregationWindow(d)){u.push(r);let n=e.getWindowBaseMeasure(d,t);n&&c.add(n);continue}M.isCalculatedMeasure(d)?(s.push(r),qe(d.calculatedSql,t).forEach(e=>c.add(e)),l.getAllDependencies(r).forEach(e=>{let[t,r]=e.split(`.`),i=n.get(t);if(i&&i.measures[r]){let e=i.measures[r];M.isCalculatedMeasure(e)&&qe(e.calculatedSql,t).forEach(e=>c.add(e))}})):o.push(r)}}for(let t of c){let[r,i]=t.split(`.`),a=n.get(r);if(a&&a.measures&&a.measures[i]){let n=a.measures[i];if(e.isPostAggregationWindow(n))continue;M.isCalculatedMeasure(n)?s.includes(t)||s.push(t):o.includes(t)||o.push(t)}}for(let e of o){let[t,o]=e.split(`.`),s=n.get(t),c=s.measures[o];if(i){let t=i(e,c,s);a.set(e,()=>t)}else a.set(e,()=>this.buildMeasureExpression(c,r,s))}if(s.length>0){let e=l.topologicalSort(s);for(let t of e){let[e,i]=t.split(`.`),o=n.get(e),s=o.measures[i];a.set(t,()=>this.buildCalculatedMeasure(s,o,n,a,r))}}return a}buildCalculatedMeasure(e,t,n,r,i){if(!e.calculatedSql)throw Error(`Calculated measure '${t.name}.${e.name}' missing calculatedSql property`);return We(this.databaseAdapter.preprocessCalculatedTemplate(e.calculatedSql),{cube:t,allCubes:n,resolvedMeasures:r,queryContext:i})}buildCTECalculatedMeasure(e,t,n,r,i){if(!e.calculatedSql)throw Error(`Calculated measure '${t.name}.${e.name||`unknown`}' missing calculatedSql property`);let a=new Map,o=qe(e.calculatedSql,t.name);for(let e of o){let[t,i]=e.split(`.`),o=r.get(t);if(o&&o.measures[i]){let t=o.measures[i];if(n.measures.includes(e)){let r=u.sql`${u.sql.identifier(n.cteAlias)}.${u.sql.identifier(i)}`,o;switch(t.type){case`count`:case`countDistinct`:case`sum`:o=(0,u.sum)(r);break;case`avg`:o=this.databaseAdapter.buildAvg(r);break;case`min`:o=(0,u.min)(r);break;case`max`:o=(0,u.max)(r);break;case`number`:o=(0,u.sum)(r);break;default:o=(0,u.sum)(r)}a.set(e,()=>o)}}}return this.buildCalculatedMeasure(e,t,r,a,i)}buildHavingMeasureExpression(e,t,n,r,i){if(i&&i.preAggregationCTEs){let a=i.preAggregationCTEs.find(t=>t.cube.name===e);if(a&&a.measures.includes(`${e}.${t}`))if(n.type===`calculated`&&n.calculatedSql){let t=i.primaryCube.name===e?i.primaryCube:i.joinCubes?.find(t=>t.cube.name===e)?.cube;if(!t)throw Error(`Cube ${e} not found in query plan`);let o=new Map([[i.primaryCube.name,i.primaryCube]]);if(i.joinCubes)for(let e of i.joinCubes)o.set(e.cube.name,e.cube);return this.buildCTECalculatedMeasure(n,t,a,o,r)}else{let e=u.sql`${u.sql.identifier(a.cteAlias)}.${u.sql.identifier(t)}`;switch(n.type){case`count`:case`countDistinct`:case`sum`:return(0,u.sum)(e);case`avg`:return this.databaseAdapter.buildAvg(e);case`min`:return(0,u.min)(e);case`max`:return(0,u.max)(e);case`number`:return(0,u.sum)(e);default:return(0,u.sum)(e)}}}return this.buildMeasureExpression(n,r)}buildMeasureExpression(t,n,r){if(t.type===`calculated`)throw Error(`Cannot build calculated measure '${t.name}' directly. Use buildCalculatedMeasure instead.`);if(e.isPostAggregationWindow(t))throw Error(`Post-aggregation window measure '${t.name}' should be built via buildPostAggregationWindowExpression, not buildMeasureExpression.`);if(!t.sql)throw Error(`Measure '${t.name}' of type '${t.type}' is missing required 'sql' property. Only calculated measures and post-aggregation window functions can omit 'sql'.`);let i=k(t.sql,n);if(n.ungrouped)return i;if(t.filters&&t.filters.length>0){let e=t.filters.map(e=>{let t=e(n);return t?u.sql`(${t})`:void 0}).filter(Boolean);if(e.length>0){let t=e.length===1?e[0]:(0,u.and)(...e);i=this.databaseAdapter.buildCaseWhen([{when:t,then:i}])}}switch(t.type){case`count`:return(0,u.count)(i);case`countDistinct`:return(0,u.countDistinct)(i);case`sum`:return(0,u.sum)(i);case`avg`:return this.databaseAdapter.buildAvg(i);case`min`:return(0,u.min)(i);case`max`:return(0,u.max)(i);case`number`:return i;case`stddev`:case`stddevSamp`:{let e=t.type===`stddevSamp`||t.statisticalConfig?.useSample,n=this.databaseAdapter.buildStddev(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`variance`:case`varianceSamp`:{let e=t.type===`varianceSamp`||t.statisticalConfig?.useSample,n=this.databaseAdapter.buildVariance(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`percentile`:case`median`:case`p95`:case`p99`:{let e;switch(t.type){case`median`:e=50;break;case`p95`:e=95;break;case`p99`:e=99;break;default:e=t.statisticalConfig?.percentile??50}let n=this.databaseAdapter.buildPercentile(i,e);return n===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`MAX(NULL)`):n}case`lag`:case`lead`:case`rank`:case`denseRank`:case`rowNumber`:case`ntile`:case`firstValue`:case`lastValue`:case`movingAvg`:case`movingSum`:{let e=t.windowConfig||{},a;if(e.partitionBy&&e.partitionBy.length>0&&r){let t=e.partitionBy.map(e=>{let t=e.includes(`.`)?e.split(`.`)[1]:e,i=r.dimensions?.[t];return i?k(i.sql,n):(console.warn(`[drizzle-cube] Window function partition dimension '${e}' not found in cube '${r.name}'`),null)}).filter(e=>e!==null);t.length>0&&(a=t)}let o;if(e.orderBy&&e.orderBy.length>0&&r){let t=e.orderBy.map(e=>{let t=e.field.includes(`.`)?e.field.split(`.`)[1]:e.field,i=r.dimensions?.[t];if(i)return{field:k(i.sql,n),direction:e.direction};let a=r.measures?.[t];return a&&a.sql?{field:k(a.sql,n),direction:e.direction}:(console.warn(`[drizzle-cube] Window function order field '${e.field}' not found in cube '${r.name}'`),null)}).filter(e=>e!==null);t.length>0&&(o=t)}let s=this.databaseAdapter.buildWindowFunction(t.type,[`rank`,`denseRank`,`rowNumber`].includes(t.type)?null:i,a,o,{offset:e.offset,defaultValue:e.defaultValue,nTile:e.nTile,frame:e.frame});return s===null?(console.warn(`[drizzle-cube] ${t.type} not supported on ${this.databaseAdapter.getEngineType()}, returning NULL`),u.sql`NULL`):s}default:return(0,u.count)(i)}}static WINDOW_FUNCTION_TYPES=[`lag`,`lead`,`rank`,`denseRank`,`rowNumber`,`ntile`,`firstValue`,`lastValue`,`movingAvg`,`movingSum`];static isWindowFunction(t){return e.WINDOW_FUNCTION_TYPES.includes(t)}static categorizeMeasures(t,n){let r=[],i=[];for(let a of t){let[t,o]=a.split(`.`),s=n.get(t);if(s?.measures?.[o]){let t=s.measures[o];e.isWindowFunction(t.type)?r.push(a):i.push(a)}}return{windowMeasures:r,aggregateMeasures:i}}static hasWindowFunctions(t,n){let{windowMeasures:r}=e.categorizeMeasures(t,n);return r.length>0}static isPostAggregationWindow(t){return e.isWindowFunction(t.type)&&t.windowConfig?.measure!==void 0}static getWindowBaseMeasure(e,t){if(!e.windowConfig?.measure)return null;let n=e.windowConfig.measure;return n.includes(`.`)?n:`${t}.${n}`}static getDefaultWindowOperation(e){switch(e){case`lag`:case`lead`:return`difference`;default:return`raw`}}static categorizeForPostAggregation(t,n){let r=[],i=[],a=new Set;for(let o of t){let[t,s]=o.split(`.`),c=n.get(t);if(c?.measures?.[s]){let n=c.measures[s];if(e.isPostAggregationWindow(n)){i.push(o);let r=e.getWindowBaseMeasure(n,t);r&&a.add(r)}else e.isWindowFunction(n.type)||r.push(o)}}return{aggregateMeasures:r,postAggWindowMeasures:i,requiredBaseMeasures:a}}static hasPostAggregationWindows(t,n){let{postAggWindowMeasures:r}=e.categorizeForPostAggregation(t,n);return r.length>0}},Je=class{constructor(e){this.dateTimeBuilder=e}isWindowFunctionType(e){return[`lag`,`lead`,`rank`,`denseRank`,`rowNumber`,`ntile`,`firstValue`,`lastValue`,`movingAvg`,`movingSum`].includes(e)}isAggregateFunctionType(e){return[`count`,`countDistinct`,`sum`,`avg`,`min`,`max`,`stddev`,`stddevSamp`,`variance`,`varianceSamp`,`median`,`p95`,`p99`,`percentile`,`number`].includes(e)}buildGroupByFields(e,t,n,r){if(t.ungrouped)return[];let i=[],a=e instanceof Map?e:new Map([[e.name,e]]),o=t.dimensions&&t.dimensions.length>0||t.timeDimensions&&t.timeDimensions.length>0,s=t.measures&&t.measures.length>0,c=o&&!s,l=!1;for(let e of t.measures||[]){let[t,n]=e.split(`.`),r=a.get(t);if(r&&r.measures&&r.measures[n]){let e=r.measures[n];if(this.isAggregateFunctionType(e.type)||e.type===`calculated`){l=!0;break}if(N.isPostAggregationWindow(e)){let n=N.getWindowBaseMeasure(e,t);if(n){let[e,t]=n.split(`.`),r=a.get(e)?.measures?.[t];if(r&&this.isAggregateFunctionType(r.type)){l=!0;break}}}}}if(!l&&!c)return[];if(t.dimensions)for(let e of t.dimensions){let[t,o]=e.split(`.`),s=a.get(t);if(s&&s.dimensions&&s.dimensions[o]){let e=r?.preAggregationCTEs?.find(e=>e.cube.name===t);if(e){let t=e.joinKeys.find(e=>e.targetColumn===o);if(t&&t.sourceColumnObj)i.push(t.sourceColumnObj);else{let t=u.sql`${u.sql.identifier(e.cteAlias)}.${u.sql.identifier(o)}`;i.push(t)}}else{let e=s.dimensions[o],t=k(e.sql,n);i.push(t)}}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,o]=e.dimension.split(`.`),s=a.get(t);if(s&&s.dimensions&&s.dimensions[o]){let a=r?.preAggregationCTEs?.find(e=>e.cube.name===t);if(a){let t=a.joinKeys.find(e=>e.targetColumn===o);if(t&&t.sourceColumnObj){let r=this.dateTimeBuilder.buildTimeDimensionExpression(t.sourceColumnObj,e.granularity,n);i.push(r)}else{let e=u.sql`${u.sql.identifier(a.cteAlias)}.${u.sql.identifier(o)}`;i.push(e)}}else{let t=s.dimensions[o],r=this.dateTimeBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n);i.push(r)}}}return i}},Ye=class{dateTimeBuilder;filterBuilder;groupByBuilder;measureBuilder;constructor(e){this.dateTimeBuilder=new j(e),this.filterBuilder=new Ue(e,this.dateTimeBuilder),this.groupByBuilder=new Je(this.dateTimeBuilder),this.measureBuilder=new N(e)}buildResolvedMeasures(e,t,n,r){return this.measureBuilder.buildResolvedMeasures(e,t,n,r)}buildSelections(e,t,n){let r={},i=e instanceof Map?e:new Map([[e.name,e]]);if(t.dimensions)for(let e of t.dimensions){let[t,a]=e.split(`.`),o=i.get(t);if(o&&o.dimensions&&o.dimensions[a]){let t=o.dimensions[a];r[e]=u.sql`${k(t.sql,n)}`.as(e)}}if(t.measures){let e=this.buildResolvedMeasures(t.measures,i,n);for(let n of t.measures){let t=e.get(n);t&&typeof t==`function`&&(r[n]=u.sql`${t()}`.as(n))}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,a]=e.dimension.split(`.`),o=i.get(t);if(o&&o.dimensions&&o.dimensions[a]){let t=o.dimensions[a],i=this.buildTimeDimensionExpression(t.sql,e.granularity,n);r[e.dimension]=u.sql`${i}`.as(e.dimension)}}return Object.keys(r).length===0&&(r.count=(0,u.count)()),r}buildCalculatedMeasure(e,t,n,r,i){return this.measureBuilder.buildCalculatedMeasure(e,t,n,r,i)}buildCTECalculatedMeasure(e,t,n,r,i){return this.measureBuilder.buildCTECalculatedMeasure(e,t,n,r,i)}buildHavingMeasureExpression(e,t,n,r,i){return this.measureBuilder.buildHavingMeasureExpression(e,t,n,r,i)}buildMeasureExpression(e,t,n){return this.measureBuilder.buildMeasureExpression(e,t,n)}buildTimeDimensionExpression(e,t,n){return this.dateTimeBuilder.buildTimeDimensionExpression(e,t,n)}buildWhereConditions(e,t,n,r,i){let a=[],o=e instanceof Map?e:new Map([[e.name,e]]),s=new Set;if(t.filters&&t.filters.length>0)for(let e of t.filters){if(i&&`member`in e){let[t]=e.member.split(`.`),n=o.has(t);if(r?.preAggregationCTEs&&r.preAggregationCTEs.some(e=>e.cube.name===t))continue;if(n&&i.has(t)&&!s.has(t)){let e=i.get(t);a.push(...e),s.add(t);continue}else if(s.has(t))continue}let t=this.processFilter(e,o,n,`where`,r);t&&a.push(t)}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,i]=e.dimension.split(`.`),s=o.get(t);if(s&&s.dimensions[i]&&e.dateRange){if(r?.preAggregationCTEs&&r.preAggregationCTEs.some(e=>e.cube.name===t))continue;if(n.filterCache){let t=je(e.dimension,e.dateRange),r=n.filterCache.get(t);if(r){a.push(r);continue}}let o=s.dimensions[i],c=k(o.sql,n),l=this.buildDateRangeCondition(c,e.dateRange);l&&a.push(l)}}return a}buildHavingConditions(e,t,n,r){let i=[],a=e instanceof Map?e:new Map([[e.name,e]]);if(t.filters&&t.filters.length>0)for(let e of t.filters){let t=this.processFilter(e,a,n,`having`,r);t&&i.push(t)}return i}processFilter(e,t,n,r,i){if(`and`in e||`or`in e){let a=e;if(a.and){let e=a.and.map(e=>this.processFilter(e,t,n,r,i)).filter(e=>e!==null);return e.length>0?(0,u.and)(...e):null}if(a.or){let e=a.or.map(e=>this.processFilter(e,t,n,r,i)).filter(e=>e!==null);return e.length>0?(0,u.or)(...e):null}}let a=e,[o,s]=a.member.split(`.`),c=t.get(o);if(!c)return null;let l=c.dimensions[s],d=c.measures[s],f=l||d;if(!f)return null;if(r===`where`&&l){if(i?.preAggregationCTEs&&i.preAggregationCTEs.some(e=>e.cube.name===o))return null;let t=l.type===`time`;if(n.filterCache){let t=Ae(e),r=n.filterCache.get(t);if(r)return r}let r=t?k(l.sql,n):typeof l.sql==`function`?l.sql(n):l.sql;return this.buildFilterCondition(r,a.operator,a.values,f,a.dateRange)}else if(r===`where`&&d)return null;else if(r===`having`&&d){let e=this.buildHavingMeasureExpression(o,s,d,n,i);return this.buildFilterCondition(e,a.operator,a.values,f,a.dateRange)}return null}buildFilterCondition(e,t,n,r,i){return this.filterBuilder.buildFilterCondition(e,t,n,r,i)}buildDateRangeCondition(e,t){return this.dateTimeBuilder.buildDateRangeCondition(e,t)}buildGroupByFields(e,t,n,r){return this.groupByBuilder.buildGroupByFields(e,t,n,r)}buildOrderBy(e,t){let n=[],r=t||[...e.measures||[],...e.dimensions||[],...e.timeDimensions?.map(e=>e.dimension)||[]];if(e.order&&Object.keys(e.order).length>0)for(let[t,i]of Object.entries(e.order)){if(!r.includes(t))throw Error(`Cannot order by '${t}': field is not selected in the query`);let e=i===`desc`?(0,u.desc)(u.sql.identifier(t)):(0,u.asc)(u.sql.identifier(t));n.push(e)}if(e.timeDimensions&&e.timeDimensions.length>0){let t=new Set(Object.keys(e.order||{})),r=[...e.timeDimensions].sort((e,t)=>e.dimension.localeCompare(t.dimension));for(let e of r)t.has(e.dimension)||n.push((0,u.asc)(u.sql.identifier(e.dimension)))}return n}collectNumericFields(e,t){let n=[],r=e instanceof Map?e:new Map([[e.name,e]]);if(t.measures&&n.push(...t.measures),t.dimensions)for(let e of t.dimensions){let[t,i]=e.split(`.`),a=r.get(t);if(a){let t=a.dimensions[i];t&&t.type===`number`&&n.push(e)}}return n}applyLimitAndOffset(e,t){let n=t.limit;t.offset!==void 0&&t.offset>0&&n===void 0&&(n=50);let r=e;if(n!==void 0){if(n<0)throw Error(`Limit must be non-negative`);r=r.limit(n)}if(t.offset!==void 0){if(t.offset<0)throw Error(`Offset must be non-negative`);r=r.offset(t.offset)}return r}buildFilterConditionPublic(e,t,n,r,i){return this.buildFilterCondition(e,t,n,r,i)}buildLogicalFilter(e,t,n){return this.filterBuilder.buildLogicalFilter(e,t,n)}},Xe=class{cubes;connectivityCache=new Map;reverseIndex;constructor(e){this.cubes=e,this.reverseIndex=this.buildReverseIndex()}buildReverseIndex(){let e=new Map;for(let[t,n]of this.cubes)if(n.joins)for(let[,r]of Object.entries(n.joins)){if(r.relationship===`belongsToMany`)continue;let n=O(r.targetCube,this.cubes);if(!n)continue;let i=n.name,a=e.get(i);a||(a=[],e.set(i,a)),a.push({definingCube:t,joinDef:r})}return e}findPath(e,t,n=new Set){if(e===t)return[];let r=this.getCacheKey(e,t,n),i=this.getFromCache(r);if(i!==void 0)return i;let a=[{cube:e,path:[]}],o=new Set([e,...n]);for(;a.length>0;){let{cube:e,path:n}=a.shift(),i=this.cubes.get(e);if(i?.joins)for(let[,s]of Object.entries(i.joins)){let i=O(s.targetCube,this.cubes);if(!i)continue;let c=i.name;if(o.has(c))continue;let l=[...n,{fromCube:e,toCube:c,joinDef:s}];if(c===t)return this.setInCache(r,l),l;o.add(c),a.push({cube:c,path:l})}let s=this.reverseIndex.get(e)||[];for(let{definingCube:i,joinDef:c}of s){if(o.has(i))continue;let s=[...n,{fromCube:e,toCube:i,joinDef:c,reversed:!0}];if(i===t)return this.setInCache(r,s),s;o.add(i),a.push({cube:i,path:s})}}return this.setInCache(r,null),null}findPathPreferring(e,t,n,r=new Set){return this.findPathPreferringDetailed(e,t,n,r).selectedPath}findPathPreferringDetailed(e,t,n,r=new Set){let i=this.findAllPaths(e,t,new Set);if(i.length===0){let i=this.findPath(e,t,r),a=i?[{path:i,score:0,usesPreferredJoin:!1,preferredCubesInPath:0,usesProcessed:i.some(e=>r.has(e.toCube)),scoreBreakdown:{preferredJoinBonus:0,preferredCubeBonus:0,lengthPenalty:0}}]:[];return{strategy:`fallbackShortest`,preferredCubes:Array.from(n).sort(),selectedIndex:i?0:-1,candidates:a,selectedPath:i}}let a=i.map(i=>{let a=0,o=i.some((n,r)=>r===0?n.reversed?n.joinDef.preferredFor?.includes(e)??!1:n.joinDef.preferredFor?.includes(t)??!1:!1);o&&(a=10);let s=i.filter(e=>n.has(e.toCube)).length,c=s,l=i.length-1;return{path:i,score:a+c-l,usesPreferredJoin:o,preferredCubesInPath:s,usesProcessed:i.some(e=>r.has(e.toCube)),scoreBreakdown:{preferredJoinBonus:a,preferredCubeBonus:c,lengthPenalty:l}}});return a.sort((e,t)=>t.score===e.score?e.usesProcessed===t.usesProcessed?e.path.length-t.path.length:e.usesProcessed?-1:1:t.score-e.score),{strategy:`preferred`,preferredCubes:Array.from(n).sort(),selectedIndex:a.length>0?0:-1,candidates:a,selectedPath:a[0]?.path??null}}findAllPaths(e,t,n,r=4){if(e===t)return[[]];let i=[],a=[{cube:e,path:[],visited:new Set([e,...n])}];for(;a.length>0;){let{cube:e,path:n,visited:o}=a.shift();if(n.length>=r)continue;let s=this.cubes.get(e);if(s?.joins)for(let[,r]of Object.entries(s.joins)){let s=O(r.targetCube,this.cubes);if(!s)continue;let c=s.name;if(o.has(c))continue;let l=[...n,{fromCube:e,toCube:c,joinDef:r}];if(c===t)i.push(l);else{let e=new Set(o);e.add(c),a.push({cube:c,path:l,visited:e})}}let c=this.reverseIndex.get(e)||[];for(let{definingCube:r,joinDef:s}of c){if(o.has(r))continue;let c=[...n,{fromCube:e,toCube:r,joinDef:s,reversed:!0}];if(r===t)i.push(c);else{let e=new Set(o);e.add(r),a.push({cube:r,path:c,visited:e})}}}return i}canReachAll(e,t){let n=t.filter(t=>t!==e);for(let t of n){let n=this.findForwardOnlyPath(e,t,new Set);if(!n||n.length===0)return!1}return!0}findForwardOnlyPath(e,t,n){if(e===t)return[];let r=[{cube:e,path:[]}],i=new Set([e,...n]);for(;r.length>0;){let{cube:e,path:n}=r.shift(),a=this.cubes.get(e);if(a?.joins)for(let[,o]of Object.entries(a.joins)){let a=O(o.targetCube,this.cubes);if(!a)continue;let s=a.name;if(i.has(s))continue;let c=[...n,{fromCube:e,toCube:s,joinDef:o}];if(s===t)return c;i.add(s),r.push({cube:s,path:c})}}return null}buildJoinCondition(e,t,n){let r=[];for(let i of e.on){let e=t?u.sql`${u.sql.identifier(t)}.${u.sql.identifier(i.source.name)}`:Te(i.source),a=n?u.sql`${u.sql.identifier(n)}.${u.sql.identifier(i.target.name)}`:Te(i.target),o=i.as||u.eq;r.push(o(e,a))}return(0,u.and)(...r)}getReachableCubes(e){let t=new Set([e]),n=[e];for(;n.length>0;){let e=n.shift(),r=this.cubes.get(e);if(r?.joins)for(let[,e]of Object.entries(r.joins)){let r=O(e.targetCube,this.cubes);if(!r)continue;let i=r.name;t.has(i)||(t.add(i),n.push(i))}let i=this.reverseIndex.get(e)||[];for(let{definingCube:e}of i)t.has(e)||(t.add(e),n.push(e))}return t}getCacheKey(e,t,n){return`${e}:${t}:${Array.from(n).sort().join(`,`)}`}getFromCache(e){let t=this.connectivityCache.get(e);if(t)return t.path}setInCache(e,t){this.connectivityCache.set(e,{path:t})}},Ze=class{resolverCache=new WeakMap;getResolver(e){let t=this.resolverCache.get(e);return t||(t=new Xe(e),this.resolverCache.set(e,t)),t}analyzeCubeUsage(e){let t=new Set;if(e.measures)for(let n of e.measures){let[e]=n.split(`.`);t.add(e)}if(e.dimensions)for(let n of e.dimensions){let[e]=n.split(`.`);t.add(e)}if(e.timeDimensions)for(let n of e.timeDimensions){let[e]=n.dimension.split(`.`);t.add(e)}if(e.filters)for(let n of e.filters)this.extractCubeNamesFromFilter(n,t);if(e.order)for(let n of Object.keys(e.order)){let[e]=n.split(`.`);e&&t.add(e)}return t}collectPathHintCubes(e){return this.analyzeCubeUsage(e)}extractCubeNamesFromFilter(e,t){if(`and`in e||`or`in e){let n=e.and||e.or||[];for(let e of n)this.extractCubeNamesFromFilter(e,t);return}if(`member`in e){let[n]=e.member.split(`.`);n&&t.add(n)}}extractMeasuresFromFilters(e,t){let n=[];if(!e.filters)return n;for(let r of e.filters)this.extractMeasuresFromFilter(r,t,n);return n}extractMeasuresFromFilter(e,t,n){if(`and`in e||`or`in e){let r=e.and||e.or||[];for(let e of r)this.extractMeasuresFromFilter(e,t,n);return}if(`member`in e){let r=e.member,[i,a]=r.split(`.`);i===t.name&&t.measures&&t.measures[a]&&n.push(r)}}choosePrimaryCube(e,t,n){return e.length===1?e[0]:n?this.analyzePrimaryCubeSelection(e,t,n).selectedCube:[...e].sort()[0]}analyzePrimaryCube(e,t,n){return this.analyzePrimaryCubeSelection(e,t,n)}analyzeJoinPathForTarget(e,t,n,r){return this.analyzeJoinPath(e,t,n,r)}buildJoinPlanForPrimary(e,t,n,r,i){return this.buildJoinPlan(e,t,n,r,i)}buildPreAggregationCTEs(e,t,n,r,i){return this.planPreAggregationCTEs(e,t,n,r,i)}buildWarnings(e,t){return this.generateWarnings(e,t)}buildJoinPlan(e,t,n,r,i){let a=this.getResolver(e),o=[],s=new Set([t.name]),c=new Set;if(i.measures)for(let e of i.measures){let[t]=e.split(`.`);c.add(t)}let l=this.collectPathHintCubes(i),u=new Set;for(let n of c)n!==t.name&&this.findHasManyJoinDef(t,n,e)&&u.add(n);let d=n.filter(e=>e!==t.name);for(let n of d){if(s.has(n))continue;let i=new Set([...s].filter(e=>!u.has(e))),c=a.findPathPreferring(t.name,n,l,i);if(!c||c.length===0)throw Error(`No join path found from '${t.name}' to '${n}'`);for(let{fromCube:t,toCube:n,joinDef:i,reversed:l}of c){if(s.has(n))continue;let c=e.get(n);if(!c)throw Error(`Cube '${n}' not found`);let u=l?Ce(i.relationship):i.relationship;if(u===`belongsToMany`&&i.through){let e=ke(i,r.securityContext);o.push({cube:c,alias:`${n.toLowerCase()}_cube`,joinType:e.junctionJoins[1].joinType,joinCondition:e.junctionJoins[1].condition,relationship:`belongsToMany`,junctionTable:{table:i.through.table,alias:`junction_${n.toLowerCase()}`,joinType:e.junctionJoins[0].joinType,joinCondition:e.junctionJoins[0].condition,securitySql:i.through.securitySql,sourceCubeName:t}})}else{let e=a.buildJoinCondition(i,null,null),t=we(u,i.sqlJoinType);o.push({cube:c,alias:`${n.toLowerCase()}_cube`,joinType:t,joinCondition:e,relationship:u})}s.add(n)}}return o}planPreAggregationCTEs(e,t,n,r,i){let a=[];if(!r.measures||r.measures.length===0)return a;let o=this.computeCTEReasons(t,n,r);if(o.size===0)return a;for(let s of n){let n=o.get(s.cube.name);if(!n)continue;let c=s.cube,l=s.alias,u=r.measures.filter(e=>e.startsWith(c.name+`.`)),d=this.extractMeasuresFromFilters(r,c),f=[...new Set([...u,...d])];if(f.length===0)continue;let p=this.analyzeJoinPathToPrimary(e,t,c.name,i,r),m,h;if(p?.hasIntermediateHasMany&&p.intermediateJoins.length>0)m=p.correctJoinKeys,h=p.intermediateJoins;else{let n=(p?.path&&p.path.length>0?(()=>{let t=p.path[p.path.length-1],n=e.get(t.fromCube);return n?{sourceCube:n,joinDef:t.joinDef,reversed:t.reversed}:null})():null)??this.findJoinInfoForCube(e,t,c.name);if(!n)continue;m=n.joinDef.relationship===`belongsToMany`&&n.joinDef.through?n.sourceCube?.name===t.name&&!(`reversed`in n&&n.reversed)?n.joinDef.through.targetKey.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})):n.joinDef.through.sourceKey.map(e=>({sourceColumn:e.target.name,targetColumn:e.source.name,sourceColumnObj:e.target,targetColumnObj:e.source})):`reversed`in n&&n.reversed?n.joinDef.on.map(e=>({sourceColumn:e.target.name,targetColumn:e.source.name,sourceColumnObj:e.target,targetColumnObj:e.source})):n.joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})),h=void 0}let g=this.findPropagatingFilters(r,c,e),_=new Map([[c.name,c]]),{aggregateMeasures:v,requiredBaseMeasures:y}=N.categorizeForPostAggregation(f,_),b=[...new Set([...v,...Array.from(y).filter(e=>e.startsWith(c.name+`.`))])];if(b.length>0){let t=this.expandCalculatedMeasureDependencies(c,b),i=this.findDownstreamJoinKeys(c,r,e);a.push({cube:c,alias:l,cteAlias:`${c.name.toLowerCase()}_agg`,joinKeys:m,measures:t,propagatingFilters:g.length>0?g:void 0,downstreamJoinKeys:i.length>0?i:void 0,intermediateJoins:h&&h.length>0?h:void 0,cteType:`aggregate`,cteReason:n})}}return a}findJoinInfoToCube(e,t){for(let[,n]of e)if(n.name!==t&&n.joins)for(let[,r]of Object.entries(n.joins)){let i=O(r.targetCube,e);if(i&&i.name===t)return{sourceCube:n,joinDef:r}}return null}analyzeJoinPathToPrimary(e,t,n,r,i){let a=this.getResolver(e),o=this.collectPathHintCubes(i),s=o.size>0?a.findPathPreferring(t.name,n,o,new Set):a.findPath(t.name,n);if(!s||s.length===0)return null;let c=s.map(e=>({fromCube:e.fromCube,toCube:e.toCube,joinDef:e.joinDef,reversed:e.reversed}));if(!c.slice(0,-1).some(e=>(e.reversed?Ce(e.joinDef.relationship):e.joinDef.relationship)===`hasMany`))return{path:c,hasIntermediateHasMany:!1,intermediateJoins:[],correctJoinKeys:[]};let l=[];for(let t=0;t<c.length-1;t++){let n=c[t],i=c[t+1],a=e.get(n.toCube);if(!a)continue;let o=a.sql(r).where,s=i.joinDef.on[0]?.source,u=n.joinDef.on[0]?.target;l.push({cube:a,joinDef:i.joinDef,securityFilter:o,primaryJoinColumn:u,cteJoinColumn:s})}return{path:c,hasIntermediateHasMany:!0,intermediateJoins:l,correctJoinKeys:c[0].joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target}))}}computeCTEReasons(e,t,n){let r=new Map,i=new Set,a=new Set,o=new Set;if(n.measures)for(let e of n.measures){let[t]=e.split(`.`);o.add(t)}for(let e of t)e.relationship===`hasMany`||e.relationship===`belongsToMany`?i.add(e.cube.name):e.relationship===`belongsTo`&&o.has(e.cube.name)&&a.add(e.cube.name);if(i.size===0&&a.size===0)return r;for(let e of t)o.has(e.cube.name)&&(i.has(e.cube.name)?r.set(e.cube.name,`hasMany`):(a.has(e.cube.name)||i.size>0)&&r.set(e.cube.name,`fanOutPrevention`));return r}findJoinInfoForCube(e,t,n){if(t.joins)for(let[,r]of Object.entries(t.joins)){let i=O(r.targetCube,e);if(i&&i.name===n)return{sourceCube:t,joinDef:r}}let r=e.get(n);if(r?.joins)for(let[,n]of Object.entries(r.joins)){let i=O(n.targetCube,e);if(i&&i.name===t.name)return{sourceCube:r,joinDef:n,reversed:!0}}for(let[,r]of e)if(!(r.name===t.name||r.name===n)&&r.joins)for(let[,t]of Object.entries(r.joins)){let i=O(t.targetCube,e);if(i&&i.name===n)return{sourceCube:r,joinDef:t}}return null}findDownstreamJoinKeys(e,t,n){let r=[],i=new Set;if(t.dimensions)for(let n of t.dimensions){let[t]=n.split(`.`);t!==e.name&&i.add(t)}if(t.timeDimensions)for(let n of t.timeDimensions){let[t]=n.dimension.split(`.`);t!==e.name&&i.add(t)}if(t.filters){for(let e of t.filters)this.extractCubeNamesFromFilter(e,i);i.delete(e.name)}if(e.joins)for(let[,t]of Object.entries(e.joins)){let e=O(t.targetCube,n);if(!e)continue;let a=e.name;if(i.has(a)){let e;e=t.relationship===`belongsToMany`&&t.through?t.through.sourceKey.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})):t.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name,sourceColumnObj:e.source,targetColumnObj:e.target})),r.push({targetCubeName:a,joinKeys:e})}}return r}expandCalculatedMeasureDependencies(e,t){let n=new Set,r=[...t];for(;r.length>0;){let t=r.pop();if(n.has(t))continue;n.add(t);let[,i]=t.split(`.`);if(!e.measures||!e.measures[i])continue;let a=e.measures[i];if(a.type===`calculated`&&a.calculatedSql){let t=this.extractDependenciesFromTemplate(a.calculatedSql,e.name);for(let e of t)n.has(e)||r.push(e)}}return Array.from(n)}extractDependenciesFromTemplate(e,t){if(e.length>1e3)return[];let n=e.matchAll(/\{([^}]+)\}/g),r=[];for(let e of n){let n=e[1].trim();n.includes(`.`)?r.push(n):r.push(`${t}.${n}`)}return r}findHasManyJoinDef(e,t,n){if(!e.joins)return null;for(let[,r]of Object.entries(e.joins)){let e=O(r.targetCube,n);if(e&&e.name===t&&r.relationship===`hasMany`)return r}return null}findPropagatingFilters(e,t,n){let r=[];if(!e.filters)return r;let i=new Set;if(this.extractFilterCubeNamesToSet(e.filters,i),e.timeDimensions){for(let t of e.timeDimensions)if(t.dateRange){let[e]=t.dimension.split(`.`);e&&i.add(e)}}for(let a of i){if(a===t.name)continue;let i=n.get(a);if(i?.joins)for(let[,o]of Object.entries(i.joins)){let s=O(o.targetCube,n);if(s&&s.name===t.name&&o.relationship===`hasMany`){let t=this.extractFiltersForCube(e.filters,a),n=this.extractTimeDimensionFiltersForCube(e,a),s=[...t,...n];s.length>0&&o.on.length>0&&r.push({sourceCube:i,filters:s,joinConditions:o.on.map(e=>({source:e.source,target:e.target}))})}}}return r}extractFilterCubeNamesToSet(e,t){for(let n of e){if(`and`in n||`or`in n){let e=n.and||n.or||[];this.extractFilterCubeNamesToSet(e,t);continue}if(`member`in n){let[e]=n.member.split(`.`);e&&t.add(e)}}}extractFiltersForCube(e,t){let n=[];for(let r of e){if(`and`in r){let e=this.extractFiltersForCube(r.and||[],t);e.length>0&&n.push({and:e});continue}if(`or`in r){let e=r.or||[];if(this.allFiltersFromCube(e,t)){let r=this.extractFiltersForCube(e,t);r.length>0&&n.push({or:r})}continue}if(`member`in r){let[e]=r.member.split(`.`);e===t&&n.push(r)}}return n}allFiltersFromCube(e,t){for(let n of e){if(`and`in n){if(!this.allFiltersFromCube(n.and||[],t))return!1;continue}if(`or`in n){if(!this.allFiltersFromCube(n.or||[],t))return!1;continue}if(`member`in n){let[e]=n.member.split(`.`);if(e!==t)return!1}}return!0}extractTimeDimensionFiltersForCube(e,t){let n=[];if(!e.timeDimensions)return n;for(let r of e.timeDimensions){let[e]=r.dimension.split(`.`);e===t&&r.dateRange&&n.push({member:r.dimension,operator:`inDateRange`,values:Array.isArray(r.dateRange)?r.dateRange:[r.dateRange]})}return n}analyzePrimaryCubeSelection(e,t,n){if(e.length===1)return{selectedCube:e[0],reason:`single_cube`,explanation:`Only one cube is used in this query`};let r=[],i=(t.dimensions||[]).map(e=>e.split(`.`)[0]),a=new Map;for(let e of i)a.set(e,(a.get(e)||0)+1);let o=this.getResolver(n);for(let t of e){let i=n.get(t),s=a.get(t)||0,c=i?.joins?Object.keys(i.joins).length:0,l=o.canReachAll(t,e);r.push({cubeName:t,dimensionCount:s,joinCount:c,canReachAll:l})}if(t.dimensions&&t.dimensions.length>0){let e=Math.max(...r.map(e=>e.dimensionCount));if(e>0){let t=r.filter(t=>t.dimensionCount===e).sort((e,t)=>e.cubeName.localeCompare(t.cubeName));for(let e of t)if(e.canReachAll)return{selectedCube:e.cubeName,reason:`most_dimensions`,explanation:`Selected because it has ${e.dimensionCount} dimension${e.dimensionCount===1?``:`s`} in the query (defines the analytical grain)`,candidates:r}}}let s=r.filter(e=>e.canReachAll);if(s.length>0){let e=Math.max(...s.map(e=>e.joinCount)),t=s.filter(t=>t.joinCount===e).sort((e,t)=>e.cubeName.localeCompare(t.cubeName))[0];return{selectedCube:t.cubeName,reason:`most_connected`,explanation:`Selected because it has ${t.joinCount} join relationship${t.joinCount===1?``:`s`} and can reach all other cubes`,candidates:r}}return{selectedCube:[...e].sort()[0],reason:`alphabetical_fallback`,explanation:`Selected alphabetically as fallback (no cube could reach all others)`,candidates:r}}analyzeJoinPath(e,t,n,r){let i=this.getResolver(e),a=r?this.collectPathHintCubes(r):new Set,o=a.size>0?i.findPathPreferringDetailed(t,n,a):null,s=o?.selectedPath??i.findPath(t,n),c=[t];if(s)for(let e of s)c.push(e.toCube);if(!s||s.length===0)return{targetCube:n,pathFound:!1,error:`No join path found from '${t}' to '${n}'. Ensure the target cube has a relationship defined (belongsTo, hasOne, hasMany, or belongsToMany).`,visitedCubes:c,selection:this.buildJoinPathSelectionAnalysis(o)};let l=this.convertInternalPathToJoinPathSteps(s);return{targetCube:n,pathFound:!0,path:l,pathLength:l.length,visitedCubes:c,selection:this.buildJoinPathSelectionAnalysis(o)}}convertInternalPathToJoinPathSteps(e){return e.map(e=>{let t=e.reversed?Ce(e.joinDef.relationship):e.joinDef.relationship,n=we(t,e.joinDef.sqlJoinType),r=e.joinDef.on.map(e=>({sourceColumn:e.source.name,targetColumn:e.target.name})),i={fromCube:e.fromCube,toCube:e.toCube,relationship:t,joinType:n,joinColumns:r};if(e.reversed&&(i.reversed=!0),t===`belongsToMany`&&e.joinDef.through){let t=e.joinDef.through;i.junctionTable={tableName:t.table[Symbol.for(`drizzle:Name`)]||`junction_table`,sourceColumns:t.sourceKey.map(e=>e.target.name),targetColumns:t.targetKey.map(e=>e.source.name)}}return i})}buildJoinPathSelectionAnalysis(e){if(!e)return{strategy:`shortest`};let t=e.candidates.map((e,t)=>this.mapPreferredCandidate(e,t+1));return{strategy:e.strategy,preferredCubes:e.preferredCubes,selectedRank:e.selectedIndex>=0?e.selectedIndex+1:void 0,selectedScore:e.selectedIndex>=0?e.candidates[e.selectedIndex]?.score:void 0,candidates:t}}mapPreferredCandidate(e,t){return{rank:t,score:e.score,usesPreferredJoin:e.usesPreferredJoin,preferredCubesInPath:e.preferredCubesInPath,usesProcessed:e.usesProcessed,scoreBreakdown:e.scoreBreakdown,path:this.convertInternalPathToJoinPathSteps(e.path)}}generateWarnings(e,t){let n=[],r=this.checkFanOutNoDimensions(e,t);return r&&n.push(r),n}checkFanOutNoDimensions(e,t){if(!t||t.length===0||!e.measures||e.measures.length===0)return null;let n=new Set;for(let t of e.measures){let[e]=t.split(`.`);n.add(e)}if(n.size<2)return null;let r=e.dimensions&&e.dimensions.length>0,i=e.timeDimensions?.some(e=>e.granularity);return r||i?null:{code:`FAN_OUT_NO_DIMENSIONS`,message:`Query combines measures from multiple cubes with hasMany relationships but has no dimensions. Results are aggregated at the join key level, which may produce unexpected totals.`,severity:`warning`,cubes:[...n].sort(),measures:e.measures,suggestion:`Add a dimension to see per-group breakdowns, or add a time dimension with granularity.`}}},Qe=class{constructor(e){this.queryBuilder=e}buildPreAggregationCTE(e,t,n,r,i){let a=e.cube,o=a.sql(n),s=e.intermediateJoins&&e.intermediateJoins.length>0,c={};if(s&&e.intermediateJoins){let t=e.intermediateJoins[0].primaryJoinColumn;if(t){let e=t.name;c[e]=t}}else for(let t of e.joinKeys)if(t.targetColumnObj){c[t.targetColumn]=t.targetColumnObj;for(let[e,n]of Object.entries(a.dimensions||{}))n.sql===t.targetColumnObj&&e!==t.targetColumn&&(c[e]=u.sql`${t.targetColumnObj}`.as(e))}if(e.downstreamJoinKeys)for(let t of e.downstreamJoinKeys)for(let e of t.joinKeys)e.sourceColumnObj&&(c[e.sourceColumn]=e.sourceColumnObj);let l=a.name,d=new Map([[l,a]]),f=this.queryBuilder.buildResolvedMeasures(e.measures,d,n);for(let t of e.measures){let[,e]=t.split(`.`),n=f.get(t);n&&(c[e]=u.sql`${n()}`.as(e))}if(t.dimensions)for(let e of t.dimensions){let[t,r]=e.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let e=a.dimensions[r];c[r]=u.sql`${this.queryBuilder.buildMeasureExpression({sql:e.sql,type:`number`},n)}`.as(r)}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let t=a.dimensions[r];c[r]=u.sql`${this.queryBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n)}`.as(r)}}if(Object.keys(c).length===0)return null;let p=n.db.select(c).from(o.from);if(s&&e.intermediateJoins){let t=[...e.intermediateJoins].reverse();for(let e of t){let t=e.cube.sql(n),r=[(0,u.eq)(e.cteJoinColumn,e.joinDef.on[0]?.target)];e.securityFilter&&r.push(e.securityFilter),p=p.leftJoin(t.from,(0,u.and)(...r))}}let m=r?{...r,preAggregationCTEs:r.preAggregationCTEs?.filter(e=>e.cube.name!==a.name)}:void 0,h=this.queryBuilder.buildWhereConditions(a,t,n,m,i),g=[];if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]&&e.dateRange){let t=a.dimensions[r],i=this.queryBuilder.buildMeasureExpression({sql:t.sql,type:`number`},n),o=this.queryBuilder.buildDateRangeCondition(i,e.dateRange);o&&g.push(o)}}if(t.filters){for(let e of t.filters)if(!(`and`in e)&&!(`or`in e)&&`member`in e&&`operator`in e){let t=e,[r,i]=t.member.split(`.`);if(r===l&&a.dimensions&&a.dimensions[i]){let e=a.dimensions[i];if(t.operator===`inDateRange`){let r=this.queryBuilder.buildMeasureExpression({sql:e.sql,type:`number`},n),i=this.queryBuilder.buildDateRangeCondition(r,t.values);i&&g.push(i)}}}}if(e.propagatingFilters&&e.propagatingFilters.length>0)for(let t of e.propagatingFilters){let e=this.buildPropagatingFilterSubquery(t,n);e&&g.push(e)}let _=[];if(o.where&&_.push(o.where),_.push(...h,...g),_.length>0){let e=_.length===1?_[0]:(0,u.and)(..._);p=p.where(e)}let v=[],y=new Set,b=e=>{let t=e?.name||(typeof e==`string`?e:null);t&&!y.has(t)?(y.add(t),v.push(e)):t||v.push(e)};if(s&&e.intermediateJoins){let t=e.intermediateJoins[0];t.primaryJoinColumn&&b(t.primaryJoinColumn)}else for(let t of e.joinKeys)t.targetColumnObj&&b(t.targetColumnObj);if(e.downstreamJoinKeys)for(let t of e.downstreamJoinKeys)for(let e of t.joinKeys)e.sourceColumnObj&&b(e.sourceColumnObj);if(t.dimensions)for(let e of t.dimensions){let[t,r]=e.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let e=a.dimensions[r],t=k(e.sql,n);v.push(t)}}if(t.timeDimensions)for(let e of t.timeDimensions){let[t,r]=e.dimension.split(`.`);if(t===l&&a.dimensions&&a.dimensions[r]){let t=a.dimensions[r],i=this.queryBuilder.buildTimeDimensionExpression(t.sql,e.granularity,n);v.push(i)}}return v.length>0&&(p=p.groupBy(...v)),n.db.$with(e.cteAlias).as(p)}buildCTEJoinCondition(e,t,n){let r=n.preAggregationCTEs?.find(t=>t.cube.name===e.cube.name);if(!r)throw Error(`CTE info not found for cube ${e.cube.name}`);let i=[];if(r.intermediateJoins&&r.intermediateJoins.length>0){let e=r.intermediateJoins[0],a=this.resolveCTEJoinSourceColumn(r.joinKeys[0],r,n),o=u.sql`${u.sql.identifier(t)}.${u.sql.identifier(e.primaryJoinColumn.name)}`;i.push((0,u.eq)(a,o))}else for(let e of r.joinKeys){let a=this.resolveCTEJoinSourceColumn(e,r,n),o=u.sql`${u.sql.identifier(t)}.${u.sql.identifier(e.targetColumn)}`;i.push((0,u.eq)(a,o))}return i.length===1?i[0]:(0,u.and)(...i)}resolveCTEJoinSourceColumn(e,t,n){if(!e)throw Error(`Missing join key while building CTE join condition for '${t.cube.name}'`);let r=e.sourceColumnObj||u.sql.identifier(e.sourceColumn);if(!e.sourceColumnObj||!n.preAggregationCTEs)return r;for(let r of n.preAggregationCTEs)if(r.cube.name!==t.cube.name){for(let[t,n]of Object.entries(r.cube.dimensions||{}))if(typeof n.sql!=`function`&&n.sql===e.sourceColumnObj)return u.sql`${u.sql.identifier(r.cteAlias)}.${u.sql.identifier(t)}`}return r}buildPropagatingFilterSubquery(e,t){let n=e.sourceCube,r=n.sql(t),i=[];if(r.where&&i.push(r.where),e.preBuiltFilterSQL)i.push(e.preBuiltFilterSQL);else{let r={filters:e.filters},a=new Map([[n.name,n]]),o=this.queryBuilder.buildWhereConditions(a,r,t);i.push(...o)}if(i.length===0)return null;let a=i.length===1?i[0]:(0,u.and)(...i),o=e.joinConditions;if(o.length===1){let{source:e,target:n}=o[0];return u.sql`${n} IN ${t.db.select({pk:e}).from(r.from).where(a)}`}else{let e=(0,u.and)(...o.map(e=>(0,u.eq)(e.source,e.target)),a);return u.sql`EXISTS ${t.db.select({one:u.sql`1`}).from(r.from).where(e)}`}}};function $e(e,t,n){let r=[],i=et(new Date(e),n),a=et(new Date(t),n);for(;i<=a&&r.length<1e4;)r.push(new Date(i)),i=tt(i,n);return r}function et(e,t){let n=new Date(e);switch(t){case`second`:n.setUTCMilliseconds(0);break;case`minute`:n.setUTCSeconds(0,0);break;case`hour`:n.setUTCMinutes(0,0,0);break;case`day`:n.setUTCHours(0,0,0,0);break;case`week`:{let e=n.getUTCDay(),t=e===0?6:e-1;n.setUTCDate(n.getUTCDate()-t),n.setUTCHours(0,0,0,0);break}case`month`:n.setUTCDate(1),n.setUTCHours(0,0,0,0);break;case`quarter`:{let e=Math.floor(n.getUTCMonth()/3)*3;n.setUTCMonth(e,1),n.setUTCHours(0,0,0,0);break}case`year`:n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0);break}return n}function tt(e,t){let n=new Date(e);switch(t){case`second`:n.setUTCSeconds(n.getUTCSeconds()+1);break;case`minute`:n.setUTCMinutes(n.getUTCMinutes()+1);break;case`hour`:n.setUTCHours(n.getUTCHours()+1);break;case`day`:n.setUTCDate(n.getUTCDate()+1);break;case`week`:n.setUTCDate(n.getUTCDate()+7);break;case`month`:n.setUTCMonth(n.getUTCMonth()+1);break;case`quarter`:n.setUTCMonth(n.getUTCMonth()+3);break;case`year`:n.setUTCFullYear(n.getUTCFullYear()+1);break}return n}function nt(e){if(e instanceof Date)return e.toISOString();if(typeof e==`string`){let t=new Date(e);if(!isNaN(t.getTime()))return t.toISOString()}return String(e)}function rt(e,t){return t.length===0?`__all__`:t.map(t=>String(e[t]??``)).join(`|||`)}function it(e,t){let{timeDimensionKey:n,granularity:r,dateRange:i,fillValue:a,measures:o,dimensions:s}=t,c=$e(i[0],i[1],r);if(c.length===0)return e;let l=new Map;for(let t of e){let e=rt(t,s),r=nt(t[n]);l.has(e)||l.set(e,new Map),l.get(e).set(r,t)}l.size===0&&s.length===0&&l.set(`__all__`,new Map);let u=[];for(let[e,t]of l){let e=t.size>0?t.values().next().value:null;for(let r of c){let i=r.toISOString(),c=t.get(i);if(c)u.push(c);else{let t={[n]:i};if(e)for(let n of s)t[n]=e[n];for(let e of o)t[e]=a;u.push(t)}}}return u}function at(e){if(!e)return null;if(Array.isArray(e)){if(e.length<2)return null;let t=new Date(e[0]),n=new Date(e[1]);return isNaN(t.getTime())||isNaN(n.getTime())?null:[t,n]}let t=new Date(e);return isNaN(t.getTime())?null:[t,t]}function ot(e,t,n){if(!t.timeDimensions||t.timeDimensions.length===0)return e;let r=t.timeDimensions.filter(e=>{let t=e.fillMissingDates!==!1,n=e.granularity&&e.dateRange;return t&&n});if(r.length===0)return e;let i=t.fillMissingDatesValue===void 0?0:t.fillMissingDatesValue,a=new Set(t.timeDimensions.map(e=>e.dimension)),o=(t.dimensions||[]).filter(e=>!a.has(e)),s=e;for(let e of r){let t=at(e.dateRange);if(!t)continue;let r={timeDimensionKey:e.dimension,granularity:e.granularity,dateRange:t,fillValue:i,measures:n,dimensions:o};s=it(s,r)}return s}var st=class{dateTimeBuilder;constructor(e){this.dateTimeBuilder=new j(e)}hasComparison(e){return e.timeDimensions?.some(e=>e.compareDateRange&&e.compareDateRange.length>=2)??!1}getComparisonTimeDimension(e){return e.timeDimensions?.find(e=>e.compareDateRange&&e.compareDateRange.length>=2)}normalizePeriods(e){let t=[];for(let n=0;n<e.length;n++){let r=e[n],i,a,o;if(typeof r==`string`){let e=this.dateTimeBuilder.parseRelativeDateRange(r);if(e)i=e.start,a=e.end,o=r;else{let e=new Date(r);if(!isNaN(e.getTime()))i=new Date(e),i.setUTCHours(0,0,0,0),a=new Date(e),a.setUTCHours(23,59,59,999),o=r;else continue}}else{if(i=new Date(r[0]),a=new Date(r[1]),isNaN(i.getTime())||isNaN(a.getTime()))continue;/^\d{4}-\d{2}-\d{2}$/.test(r[1])&&a.setUTCHours(23,59,59,999),o=`${r[0]} - ${r[1]}`}t.push({start:i,end:a,label:o,index:n})}return t}createPeriodQuery(e,t){return{...e,timeDimensions:e.timeDimensions?.map(e=>e.compareDateRange?{...e,dateRange:[t.start.toISOString(),t.end.toISOString()],compareDateRange:void 0}:e)}}calculatePeriodDayIndex(e,t,n){let r=typeof e==`string`?new Date(e):e,i=t.getTime(),a=r.getTime();switch(n){case`second`:return Math.floor((a-i)/1e3);case`minute`:return Math.floor((a-i)/(1e3*60));case`hour`:return Math.floor((a-i)/(1e3*60*60));case`day`:return Math.floor((a-i)/(1e3*60*60*24));case`week`:return Math.floor((a-i)/(1e3*60*60*24*7));case`month`:{let e=t.getUTCFullYear(),n=t.getUTCMonth(),i=r.getUTCFullYear(),a=r.getUTCMonth();return(i-e)*12+(a-n)}case`quarter`:{let e=t.getUTCFullYear(),n=Math.floor(t.getUTCMonth()/3),i=r.getUTCFullYear(),a=Math.floor(r.getUTCMonth()/3);return(i-e)*4+(a-n)}case`year`:return r.getUTCFullYear()-t.getUTCFullYear();default:return Math.floor((a-i)/(1e3*60*60*24))}}addPeriodMetadata(e,t,n,r){return e.map(e=>{let i=e[n],a=0;if(i){let e=typeof i==`string`?new Date(i):i instanceof Date?i:null;e&&!isNaN(e.getTime())&&(a=this.calculatePeriodDayIndex(e,t.start,r))}return{...e,__period:t.label,__periodIndex:t.index,__periodDayIndex:a}})}mergeComparisonResults(e,t,n){let r=[],i={measures:{},dimensions:{},segments:{},timeDimensions:{}},a=e.map(e=>e.period);for(let{result:a,period:o}of e){let e=this.addPeriodMetadata(a.data,o,t.dimension,n);r.push(...e),i={measures:{...i.measures,...a.annotation.measures},dimensions:{...i.dimensions,...a.annotation.dimensions},segments:{...i.segments,...a.annotation.segments},timeDimensions:{...i.timeDimensions,...a.annotation.timeDimensions}}}let o={ranges:a.map(e=>[e.start.toISOString().split(`T`)[0],e.end.toISOString().split(`T`)[0]]),labels:a.map(e=>e.label),timeDimension:t.dimension,granularity:n};return{data:r,annotation:{...i,periods:o}}}sortComparisonResults(e,t){return[...e].sort((e,n)=>{let r=e.__periodIndex-n.__periodIndex;if(r!==0)return r;let i=e[t],a=n[t];return typeof i==`string`&&typeof a==`string`?new Date(i).getTime()-new Date(a).getTime():0})}},ct=class{filterBuilder;dateTimeBuilder;constructor(e){this.databaseAdapter=e,this.dateTimeBuilder=new j(e),this.filterBuilder=new Ue(e,this.dateTimeBuilder)}hasFunnel(e){return e.funnel!==void 0&&e.funnel.steps.length>=2}validateConfig(e,t){let n=[];if(e.steps.length<2&&n.push(`Funnel must have at least 2 steps`),typeof e.bindingKey==`string`){let[r,i]=e.bindingKey.split(`.`);if(!r||!i)n.push(`Invalid binding key format: ${e.bindingKey}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Binding key dimension not found: ${i} in cube ${r}`):n.push(`Binding key cube not found: ${r}`)}}else if(Array.isArray(e.bindingKey))for(let r of e.bindingKey){let e=t.get(r.cube);if(!e)n.push(`Binding key mapping cube not found: ${r.cube}`);else{let[,t]=r.dimension.split(`.`);e.dimensions?.[t]||n.push(`Binding key dimension not found: ${t} in cube ${r.cube}`)}}if(typeof e.timeDimension==`string`){let[r,i]=e.timeDimension.split(`.`);if(!r||!i)n.push(`Invalid time dimension format: ${e.timeDimension}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Time dimension not found: ${i} in cube ${r}`):n.push(`Time dimension cube not found: ${r}`)}}for(let r=0;r<e.steps.length;r++){let i=e.steps[r];if(i.name||n.push(`Step ${r} must have a name`),`cube`in i&&i.cube&&(t.get(i.cube)||n.push(`Step ${r} cube not found: ${i.cube}`)),i.filter){let a;`cube`in i&&i.cube?a=i.cube:typeof e.bindingKey==`string`&&([a]=e.bindingKey.split(`.`));let o=a?new Xe(t):null,s=Array.isArray(i.filter)?i.filter:[i.filter];for(let e of s)if(`member`in e){let[i,s]=e.member.split(`.`),c=t.get(i);if(!c)n.push(`Step ${r} filter cube not found: ${i}`);else if(c.dimensions?.[s]||(c.measures?.[s]?n.push(`Step ${r} filter '${i}.${s}' is a measure. Funnel step filters only support dimensions, not measures.`):n.push(`Step ${r} filter member not found: ${s} in cube ${i}`)),a&&i!==a&&o){let e=o.findPath(a,i);(!e||e.length===0)&&n.push(`Step ${r} filter '${i}.${s}' requires a join from '${a}' but no join path was found. Define a join relationship between these cubes.`)}}}i.timeToConvert&&r>0&&(/^P(?:\d+Y)?(?:\d+M)?(?:\d+D)?(?:T(?:\d+H)?(?:\d+M)?(?:\d+(?:\.\d+)?S)?)?$/.test(i.timeToConvert)||n.push(`Step ${r} timeToConvert must be ISO 8601 duration format: ${i.timeToConvert}`))}return{isValid:n.length===0,errors:n}}buildFunnelQuery(e,t,n){let r=this.resolveSteps(e,t,n),i=[];for(let e=0;e<r.length;e++){let t=e>0?i[e-1]:void 0;i.push(this.buildStepCTE(r[e],n,t))}let a=this.buildFunnelResultsCTE(i,r,e,n),o=this.buildAggregationCTE(a,i,r,e,n),s=[...i,a,o];return n.db.with(...s).select().from(o)}transformResult(e,t){if(!e||e.length===0)return[];let n=e[0],r=[],i=Number(n.step_0_count)||0;for(let e=0;e<t.steps.length;e++){let a=t.steps[e],o=Number(n[`step_${e}_count`])||0,s=e>0&&Number(n[`step_${e-1}_count`])||0,c={step:a.name,stepIndex:e,count:o,conversionRate:e===0?null:s>0?o/s:0,cumulativeConversionRate:i>0?o/i:0};t.includeTimeMetrics&&e>0&&(c.avgSecondsToConvert=n[`step_${e}_avg_seconds`]===null?null:Number(n[`step_${e}_avg_seconds`]),c.minSecondsToConvert=n[`step_${e}_min_seconds`]===null?null:Number(n[`step_${e}_min_seconds`]),c.maxSecondsToConvert=n[`step_${e}_max_seconds`]===null?null:Number(n[`step_${e}_max_seconds`]),n[`step_${e}_median_seconds`]!==void 0&&(c.medianSecondsToConvert=n[`step_${e}_median_seconds`]===null?null:Number(n[`step_${e}_median_seconds`])),n[`step_${e}_p90_seconds`]!==void 0&&(c.p90SecondsToConvert=n[`step_${e}_p90_seconds`]===null?null:Number(n[`step_${e}_p90_seconds`]))),r.push(c)}return r}extractFilterCubeNames(e){let t=new Set;if(!e.filter)return t;let n=Array.isArray(e.filter)?e.filter:[e.filter],r=e=>{if(`and`in e&&e.and)for(let t of e.and)r(t);else if(`or`in e&&e.or)for(let t of e.or)r(t);else if(`type`in e&&`filters`in e){let t=e;for(let e of t.filters||[])r(e)}else if(`member`in e){let[n]=e.member.split(`.`);t.add(n)}};for(let e of n)r(e);return t}resolveSteps(e,t,n){let r=new Xe(t);return e.steps.map((i,a)=>{let o=this.resolveCubeForStep(i,e,t),s=this.resolveBindingKey(e,o,n),c=this.resolveTimeDimension(e,o,n),l=this.buildStepFilters(i,o,t,n),u=this.extractFilterCubeNames(i),d=[];for(let e of u)if(e!==o.name){let n=t.get(e);if(n){let t=r.findPath(o.name,e);t&&t.length>0&&d.push({cube:n,joinPath:t})}}return{name:i.name,index:a,cube:o,bindingKeyExpr:s,timeExpr:c,filterConditions:l,timeToConvert:i.timeToConvert,joinedCubes:d}})}resolveCubeForStep(e,t,n){if(`cube`in e&&e.cube){let t=n.get(e.cube);if(!t)throw Error(`Cube not found for step: ${e.cube}`);return t}if(typeof t.bindingKey==`string`){let[e]=t.bindingKey.split(`.`),r=n.get(e);if(!r)throw Error(`Cube not found for binding key: ${t.bindingKey}`);return r}throw Error(`Cannot resolve cube for step - multi-cube funnel requires cube specification in each step`)}resolveBindingKey(e,t,n){if(typeof e.bindingKey==`string`){let[,r]=e.bindingKey.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Binding key dimension not found: ${e.bindingKey}`);return k(i.sql,n)}let r=e.bindingKey.find(e=>e.cube===t.name);if(!r)throw Error(`No binding key mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Binding key dimension not found: ${r.dimension}`);return k(a.sql,n)}resolveTimeDimension(e,t,n){if(typeof e.timeDimension==`string`){let[,r]=e.timeDimension.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Time dimension not found: ${e.timeDimension}`);return k(i.sql,n)}let r=e.timeDimension.find(e=>e.cube===t.name);if(!r)throw Error(`No time dimension mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Time dimension not found: ${r.dimension}`);return k(a.sql,n)}buildStepFilters(e,t,n,r){if(!e.filter)return[];let i=Array.isArray(e.filter)?e.filter:[e.filter],a=[];for(let e of i){let i=this.buildFilterCondition(e,t,n,r);i&&a.push(i)}return a}buildFilterCondition(e,t,n,r){let i=`and`in e||`or`in e,a=`type`in e&&`filters`in e&&(e.type===`and`||e.type===`or`);if(i||a){let i=[],o;if(a){let a=e;o=a.type===`and`;for(let e of a.filters||[]){let a=this.buildFilterCondition(e,t,n,r);a&&i.push(a)}}else{let a=e;o=`and`in a&&!!a.and;let s=a.and||a.or||[];for(let e of s){let a=this.buildFilterCondition(e,t,n,r);a&&i.push(a)}}return i.length===0?null:i.length===1?i[0]:o?(0,u.and)(...i):u.sql`(${u.sql.join(i,u.sql` OR `)})`}let o=e,[s,c]=o.member.split(`.`),l=o.dateRange!==void 0;if(o.operator!==`set`&&o.operator!==`notSet`&&!l&&(!o.values||o.values.length===0||o.values[0]===void 0||o.values[0]===``))return null;let d=n.get(s);if(!d)return null;if(s!==t.name){let e=new Xe(n).findPath(t.name,s);if(!e||e.length===0)return console.warn(`Funnel filter: Cannot filter by '${String(s).replace(/\n|\r/g,``)}.${String(c).replace(/\n|\r/g,``)}' in step using '${String(t.name).replace(/\n|\r/g,``)}'. No join path found. Filter will be skipped.`),null}let f=d.dimensions?.[c];if(!f)return null;let p=f.type===`time`?k(f.sql,r):typeof f.sql==`function`?f.sql(r):f.sql;return this.filterBuilder.buildFilterCondition(p,o.operator,o.values||[],f,o.dateRange)}buildStepCTE(e,t,n){return e.index===0?this.buildFirstStepCTE(e,t):this.buildSubsequentStepCTE(e,t,n)}buildFirstStepCTE(e,t){let n=`step_${e.index}`,r=e.cube.sql(t),i=[];r.where&&i.push(r.where),i.push(...e.filterConditions);let a=t.db.select({binding_key:u.sql`${e.bindingKeyExpr}`.as(`binding_key`),step_time:u.sql`MIN(${e.timeExpr})`.as(`step_time`)}).from(r.from);if(a=this.addCrossJoinsToQuery(a,e,t,i),i.length>0){let e=i.length===1?i[0]:(0,u.and)(...i);a=a.where(e)}return a=a.groupBy(e.bindingKeyExpr),t.db.$with(n).as(a)}buildSubsequentStepCTE(e,t,n){let r=`step_${e.index}`,i=`step_${e.index-1}`,a=e.cube.sql(t),o=[];a.where&&o.push(a.where),o.push(...e.filterConditions);let s=u.sql`${u.sql.identifier(i)}.step_time`,c=u.sql`${e.timeExpr} > ${s}`;if(e.timeToConvert){let t=this.databaseAdapter.buildDateAddInterval(s,e.timeToConvert);c=u.sql`${c} AND ${e.timeExpr} <= ${t}`}o.push(c);let l=t.db.select({binding_key:u.sql`${e.bindingKeyExpr}`.as(`binding_key`),step_time:u.sql`MIN(${e.timeExpr})`.as(`step_time`)}).from(a.from).innerJoin(n,u.sql`${e.bindingKeyExpr} = ${u.sql.identifier(i)}.binding_key`);if(l=this.addCrossJoinsToQuery(l,e,t,o),o.length>0){let e=o.length===1?o[0]:(0,u.and)(...o);l=l.where(e)}return l=l.groupBy(e.bindingKeyExpr),t.db.$with(r).as(l)}addCrossJoinsToQuery(e,t,n,r){if(t.joinedCubes.length===0)return e;for(let i of t.joinedCubes)for(let t of i.joinPath){let a=t.joinDef,o=[];for(let e of a.on)e.as?o.push(e.as(e.source,e.target)):o.push((0,u.eq)(e.source,e.target));let s=o.length===1?o[0]:(0,u.and)(...o),c=i.cube.sql(n);e=e.leftJoin(c.from,s),c.where&&r.push(c.where)}return e}buildFunnelResultsCTE(e,t,n,r){let i={binding_key:u.sql`s0.binding_key`,step_0_time:u.sql`s0.step_time`};for(let e=1;e<t.length;e++)i[`step_${e}_time`]=u.sql`s${u.sql.raw(String(e))}.step_time`;let a=u.sql`${u.sql.identifier(`step_0`)} s0`;for(let e=1;e<t.length;e++)a=u.sql`${a}
|
|
63
63
|
LEFT JOIN ${u.sql.identifier(`step_${e}`)} s${u.sql.raw(String(e))} ON s0.binding_key = s${u.sql.raw(String(e))}.binding_key`;let o=Object.entries(i).map(([e,t])=>u.sql`${t} AS ${u.sql.identifier(e)}`),s=u.sql`SELECT ${u.sql.join(o,u.sql`, `)} FROM ${a}`;return r.db.$with(`funnel_joined`).as(s)}buildAggregationCTE(e,t,n,r,i){let a={};a.step_0_count=u.sql`COUNT(*)`.as(`step_0_count`);for(let e=1;e<n.length;e++)a[`step_${e}_count`]=u.sql`COUNT(${u.sql.identifier(`step_${e}_time`)})`.as(`step_${e}_count`);if(r.includeTimeMetrics)for(let e=1;e<n.length;e++){let t=u.sql.identifier(`step_${e}_time`),n=u.sql.identifier(`step_${e-1}_time`),r=this.databaseAdapter.buildTimeDifferenceSeconds(u.sql`${t}`,u.sql`${n}`),i=u.sql`${t} IS NOT NULL`;if(a[`step_${e}_avg_seconds`]=this.databaseAdapter.buildConditionalAggregation(`avg`,r,i).as(`step_${e}_avg_seconds`),a[`step_${e}_min_seconds`]=this.databaseAdapter.buildConditionalAggregation(`min`,r,i).as(`step_${e}_min_seconds`),a[`step_${e}_max_seconds`]=this.databaseAdapter.buildConditionalAggregation(`max`,r,i).as(`step_${e}_max_seconds`),this.databaseAdapter.getCapabilities().supportsPercentileSubqueries){let n=this.databaseAdapter.buildPercentile(r,50);n&&(a[`step_${e}_median_seconds`]=u.sql`(SELECT ${n} FROM ${u.sql.identifier(`funnel_joined`)} WHERE ${t} IS NOT NULL)`.as(`step_${e}_median_seconds`));let i=this.databaseAdapter.buildPercentile(r,90);i&&(a[`step_${e}_p90_seconds`]=u.sql`(SELECT ${i} FROM ${u.sql.identifier(`funnel_joined`)} WHERE ${t} IS NOT NULL)`.as(`step_${e}_p90_seconds`))}}let o=i.db.select(a).from(e);return i.db.$with(`funnel_metrics`).as(o)}},lt=class{filterBuilder;dateTimeBuilder;databaseAdapter;constructor(e){this.databaseAdapter=e,this.dateTimeBuilder=new j(e),this.filterBuilder=new Ue(e,this.dateTimeBuilder)}hasFlow(e){return e.flow!==void 0&&e.flow.startingStep!==void 0&&e.flow.eventDimension!==void 0}validateConfig(e,t){let n=[],r=[],i=this.databaseAdapter.getEngineType(),a=this.databaseAdapter.getCapabilities().supportsLateralSubqueriesInCTE;if(i===`sqlite`)return n.push(`Flow queries are not supported on SQLite. Use PostgreSQL or MySQL for flow analysis.`),{isValid:!1,errors:n,warnings:r};if(typeof e.bindingKey==`string`){let[r,i]=e.bindingKey.split(`.`);if(!r||!i)n.push(`Invalid binding key format: ${e.bindingKey}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Binding key dimension not found: ${i} in cube ${r}`):n.push(`Binding key cube not found: ${r}`)}}else if(Array.isArray(e.bindingKey))for(let r of e.bindingKey){let e=t.get(r.cube);if(!e)n.push(`Binding key mapping cube not found: ${r.cube}`);else{let[,t]=r.dimension.split(`.`);e.dimensions?.[t]||n.push(`Binding key dimension not found: ${t} in cube ${r.cube}`)}}if(typeof e.timeDimension==`string`){let[r,i]=e.timeDimension.split(`.`);if(!r||!i)n.push(`Invalid time dimension format: ${e.timeDimension}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Time dimension not found: ${i} in cube ${r}`):n.push(`Time dimension cube not found: ${r}`)}}if(e.eventDimension){let[r,i]=e.eventDimension.split(`.`);if(!r||!i)n.push(`Invalid event dimension format: ${e.eventDimension}. Expected 'CubeName.dimensionName'`);else{let e=t.get(r);e?e.dimensions?.[i]||n.push(`Event dimension not found: ${i} in cube ${r}`):n.push(`Event dimension cube not found: ${r}`)}}else n.push(`Event dimension is required for flow analysis`);return e.startingStep?(e.startingStep.filter||n.push(`Starting step must have at least one filter`),e.startingStep.name||r.push(`Starting step has no name - using default`)):n.push(`Starting step is required for flow analysis`),(e.stepsBefore<0||e.stepsBefore>5)&&n.push(`stepsBefore must be between 0 and 5, got: ${e.stepsBefore}`),(e.stepsAfter<0||e.stepsAfter>5)&&n.push(`stepsAfter must be between 0 and 5, got: ${e.stepsAfter}`),(e.stepsBefore>=4||e.stepsAfter>=4)&&r.push(`High step depth (4-5) may impact query performance on large datasets`),e.joinStrategy&&![`auto`,`lateral`,`window`].includes(e.joinStrategy)?n.push(`Invalid joinStrategy: ${e.joinStrategy}`):e.joinStrategy===`lateral`&&!a&&n.push(`Lateral joins are not supported on this database`),{isValid:n.length===0,errors:n,warnings:r}}buildFlowQuery(e,t,n){if(this.databaseAdapter.getEngineType()===`sqlite`)throw Error(`Flow queries are not supported on SQLite. Use PostgreSQL or MySQL for flow analysis.`);let r=this.databaseAdapter.getCapabilities().supportsLateralSubqueriesInCTE,i=e.joinStrategy??`auto`,a=i===`lateral`||i===`auto`&&r;if(i===`lateral`&&!r)throw Error(`Lateral joins with CTE references are not supported on this database`);let o={...e,stepsBefore:e.outputMode===`sunburst`?0:e.stepsBefore},s=this.resolveFlowConfig(o,t,n),c=[],l=this.buildStartingEntitiesCTE(o,s,n);c.push(l);let u=a?this.buildBeforeCTEsLateral(o,s,n):this.buildBeforeCTEsWindow(o,s,n);c.push(...u);let d=a?this.buildAfterCTEsLateral(o,s,n):this.buildAfterCTEsWindow(o,s,n);c.push(...d);let f=this.buildNodesAggregationCTE(o,n);c.push(f);let p=this.buildLinksAggregationCTE(o,n);c.push(p);let m=this.buildFinalResultCTE(n);return c.push(m),n.db.with(...c).select().from(m)}transformResult(e){if(!e||e.length===0)return{nodes:[],links:[]};let t=[],n=[];for(let r of e){let e=r.record_type;e===`node`?t.push({id:String(r.id),name:String(r.name),layer:Number(r.layer),value:Number(r.value)}):e===`link`&&n.push({source:String(r.source_id),target:String(r.target_id),value:Number(r.value)})}return t.sort((e,t)=>e.layer-t.layer),{nodes:t,links:n}}resolveFlowConfig(e,t,n){let r=this.resolveCube(e,t);return{cube:r,cubeBase:r.sql(n),bindingKeyExpr:this.resolveBindingKey(e,r,n),timeExpr:this.resolveTimeDimension(e,r,n),eventExpr:this.resolveEventDimension(e,r,n),startingStepFilters:this.buildStartingStepFilters(e,r,n)}}resolveCube(e,t){let n;if(typeof e.bindingKey==`string`)[n]=e.bindingKey.split(`.`);else if(Array.isArray(e.bindingKey)&&e.bindingKey.length>0)n=e.bindingKey[0].cube;else throw Error(`Cannot resolve cube for flow query`);let r=t.get(n);if(!r)throw Error(`Cube not found: ${n}`);return r}resolveBindingKey(e,t,n){if(typeof e.bindingKey==`string`){let[,r]=e.bindingKey.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Binding key dimension not found: ${e.bindingKey}`);return k(i.sql,n)}let r=e.bindingKey.find(e=>e.cube===t.name);if(!r)throw Error(`No binding key mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Binding key dimension not found: ${r.dimension}`);return k(a.sql,n)}resolveTimeDimension(e,t,n){if(typeof e.timeDimension==`string`){let[,r]=e.timeDimension.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Time dimension not found: ${e.timeDimension}`);return k(i.sql,n)}let r=e.timeDimension.find(e=>e.cube===t.name);if(!r)throw Error(`No time dimension mapping found for cube: ${t.name}`);let[,i]=r.dimension.split(`.`),a=t.dimensions?.[i];if(!a)throw Error(`Time dimension not found: ${r.dimension}`);return k(a.sql,n)}resolveEventDimension(e,t,n){let[,r]=e.eventDimension.split(`.`),i=t.dimensions?.[r];if(!i)throw Error(`Event dimension not found: ${e.eventDimension}`);return k(i.sql,n)}buildStartingStepFilters(e,t,n){if(!e.startingStep.filter)return[];let r=Array.isArray(e.startingStep.filter)?e.startingStep.filter:[e.startingStep.filter],i=[];for(let e of r){let r=this.buildFilterCondition(e,t,n);r&&i.push(r)}return i}buildFilterCondition(e,t,n){if(`and`in e||`or`in e){let r=e,i=[],a=r.and||r.or||[];for(let e of a){let r=this.buildFilterCondition(e,t,n);r&&i.push(r)}return i.length===0?null:i.length===1?i[0]:`and`in e?(0,u.and)(...i):u.sql`(${u.sql.join(i,u.sql` OR `)})`}if(`type`in e&&`filters`in e){let r=e,i=[];for(let e of r.filters||[]){let r=this.buildFilterCondition(e,t,n);r&&i.push(r)}return i.length===0?null:i.length===1?i[0]:r.type===`and`?(0,u.and)(...i):u.sql`(${u.sql.join(i,u.sql` OR `)})`}let r=e,[,i]=r.member.split(`.`),a=t.dimensions?.[i];if(!a)return null;let o=a.type===`time`?k(a.sql,n):typeof a.sql==`function`?a.sql(n):a.sql;return this.filterBuilder.buildFilterCondition(o,r.operator,r.values||[],a,r.dateRange)}buildStartingEntitiesCTE(e,t,n){let{cubeBase:r,bindingKeyExpr:i,timeExpr:a,eventExpr:o,startingStepFilters:s}=t,c=[];r.where&&c.push(r.where),c.push(...s);let l=n.db.select({binding_key:u.sql`${i}`.as(`binding_key`),start_time:u.sql`MIN(${a})`.as(`start_time`),event_type:u.sql`${o}`.as(`event_type`),event_path:u.sql`${o}`.as(`event_path`)}).from(r.from);if(c.length>0){let e=c.length===1?c[0]:(0,u.and)(...c);l=l.where(e)}return l=l.groupBy(i,o),e.entityLimit&&(l=l.limit(e.entityLimit)),n.db.$with(`starting_entities`).as(l)}buildBeforeCTEsLateral(e,t,n){let{cubeBase:r,bindingKeyExpr:i,timeExpr:a,eventExpr:o}=t,s=[],c=e.outputMode===`sunburst`;for(let t=1;t<=e.stepsBefore;t++){let e=t===1?`starting_entities`:`before_step_${t-1}`,l=t===1?`start_time`:`step_time`,d=`before_step_${t}`,f=[];r.where&&f.push(r.where),f.push(u.sql`${i} = ${u.sql.identifier(e)}.binding_key`,u.sql`${a} < ${u.sql.identifier(e)}.${u.sql.identifier(l)}`);let p=f.length===1?f[0]:(0,u.and)(...f),m=c?u.sql`${o} || ${`→`} || ${u.sql.identifier(e)}.event_path`:u.sql`${o}`,h=n.db.select({binding_key:u.sql`${i}`.as(`binding_key`),step_time:u.sql`${a}`.as(`step_time`),event_type:u.sql`${o}`.as(`event_type`),event_path:m.as(`event_path`)}).from(r.from).where(p).orderBy(u.sql`${a} DESC`).limit(1),g=n.db.$with(d).as(n.db.select({binding_key:u.sql`e.binding_key`.as(`binding_key`),step_time:u.sql`e.step_time`.as(`step_time`),event_type:u.sql`e.event_type`.as(`event_type`),event_path:u.sql`e.event_path`.as(`event_path`)}).from(u.sql`${u.sql.identifier(e)}`).crossJoinLateral(h.as(`e`)));s.push(g)}return s}buildAfterCTEsLateral(e,t,n){let{cubeBase:r,bindingKeyExpr:i,timeExpr:a,eventExpr:o}=t,s=[],c=e.outputMode===`sunburst`;for(let t=1;t<=e.stepsAfter;t++){let e=t===1?`starting_entities`:`after_step_${t-1}`,l=t===1?`start_time`:`step_time`,d=`after_step_${t}`,f=[];r.where&&f.push(r.where),f.push(u.sql`${i} = ${u.sql.identifier(e)}.binding_key`,u.sql`${a} > ${u.sql.identifier(e)}.${u.sql.identifier(l)}`);let p=f.length===1?f[0]:(0,u.and)(...f),m=c?u.sql`${u.sql.identifier(e)}.event_path || ${`→`} || ${o}`:u.sql`${o}`,h=n.db.select({binding_key:u.sql`${i}`.as(`binding_key`),step_time:u.sql`${a}`.as(`step_time`),event_type:u.sql`${o}`.as(`event_type`),event_path:m.as(`event_path`)}).from(r.from).where(p).orderBy(u.sql`${a} ASC`).limit(1),g=n.db.$with(d).as(n.db.select({binding_key:u.sql`e.binding_key`.as(`binding_key`),step_time:u.sql`e.step_time`.as(`step_time`),event_type:u.sql`e.event_type`.as(`event_type`),event_path:u.sql`e.event_path`.as(`event_path`)}).from(u.sql`${u.sql.identifier(e)}`).crossJoinLateral(h.as(`e`)));s.push(g)}return s}buildBeforeCTEsWindow(e,t,n){let{cubeBase:r,bindingKeyExpr:i,timeExpr:a,eventExpr:o}=t,s=[],c=e.outputMode===`sunburst`;for(let t=1;t<=e.stepsBefore;t++){let e=t===1?`starting_entities`:`before_step_${t-1}`,l=t===1?`start_time`:`step_time`,d=`before_step_${t}`,f=[];r.where&&f.push(r.where),f.push(u.sql`${a} < ${u.sql.identifier(e)}.${u.sql.identifier(l)}`);let p=f.length===1?f[0]:(0,u.and)(...f),m=c?u.sql`${o} || ${`→`} || ${u.sql.identifier(e)}.event_path`:u.sql`${o}`,h=n.db.select({binding_key:u.sql`${i}`.as(`binding_key`),step_time:u.sql`${a}`.as(`step_time`),event_type:u.sql`${o}`.as(`event_type`),event_path:m.as(`event_path`),rn:u.sql`ROW_NUMBER() OVER (PARTITION BY ${i} ORDER BY ${a} DESC)`.as(`rn`)}).from(r.from).innerJoin(u.sql`${u.sql.identifier(e)}`,u.sql`${i} = ${u.sql.identifier(e)}.binding_key`).where(p),g=n.db.select({binding_key:u.sql`binding_key`.as(`binding_key`),step_time:u.sql`step_time`.as(`step_time`),event_type:u.sql`event_type`.as(`event_type`),event_path:u.sql`event_path`.as(`event_path`)}).from(h.as(`ranked`)).where(u.sql`rn = 1`);s.push(n.db.$with(d).as(g))}return s}buildAfterCTEsWindow(e,t,n){let{cubeBase:r,bindingKeyExpr:i,timeExpr:a,eventExpr:o}=t,s=[],c=e.outputMode===`sunburst`;for(let t=1;t<=e.stepsAfter;t++){let e=t===1?`starting_entities`:`after_step_${t-1}`,l=t===1?`start_time`:`step_time`,d=`after_step_${t}`,f=[];r.where&&f.push(r.where),f.push(u.sql`${a} > ${u.sql.identifier(e)}.${u.sql.identifier(l)}`);let p=f.length===1?f[0]:(0,u.and)(...f),m=c?u.sql`${u.sql.identifier(e)}.event_path || ${`→`} || ${o}`:u.sql`${o}`,h=n.db.select({binding_key:u.sql`${i}`.as(`binding_key`),step_time:u.sql`${a}`.as(`step_time`),event_type:u.sql`${o}`.as(`event_type`),event_path:m.as(`event_path`),rn:u.sql`ROW_NUMBER() OVER (PARTITION BY ${i} ORDER BY ${a} ASC)`.as(`rn`)}).from(r.from).innerJoin(u.sql`${u.sql.identifier(e)}`,u.sql`${i} = ${u.sql.identifier(e)}.binding_key`).where(p),g=n.db.select({binding_key:u.sql`binding_key`.as(`binding_key`),step_time:u.sql`step_time`.as(`step_time`),event_type:u.sql`event_type`.as(`event_type`),event_path:u.sql`event_path`.as(`event_path`)}).from(h.as(`ranked`)).where(u.sql`rn = 1`);s.push(n.db.$with(d).as(g))}return s}buildNodesAggregationCTE(e,t){let n=[],r=e.outputMode===`sunburst`;for(let t=e.stepsBefore;t>=1;t--){let e=-t,i=`before_step_${t}`;r?n.push(u.sql`
|
|
64
64
|
SELECT
|
|
65
65
|
${u.sql.raw(`'before_${t}_'`)} || event_path AS node_id,
|
package/dist/server/index.js
CHANGED
|
@@ -3037,8 +3037,9 @@ var F = class e {
|
|
|
3037
3037
|
let a = [], o = e instanceof Map ? e : new Map([[e.name, e]]), s = /* @__PURE__ */ new Set();
|
|
3038
3038
|
if (t.filters && t.filters.length > 0) for (let e of t.filters) {
|
|
3039
3039
|
if (i && "member" in e) {
|
|
3040
|
-
let [t] = e.member.split(".");
|
|
3041
|
-
if (
|
|
3040
|
+
let [t] = e.member.split("."), n = o.has(t);
|
|
3041
|
+
if (r?.preAggregationCTEs && r.preAggregationCTEs.some((e) => e.cube.name === t)) continue;
|
|
3042
|
+
if (n && i.has(t) && !s.has(t)) {
|
|
3042
3043
|
let e = i.get(t);
|
|
3043
3044
|
a.push(...e), s.add(t);
|
|
3044
3045
|
continue;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "drizzle-cube",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.49",
|
|
4
4
|
"description": "Drizzle ORM-first semantic layer with Cube.js compatibility. Type-safe analytics and dashboards with SQL injection protection.",
|
|
5
5
|
"main": "./dist/server/index.js",
|
|
6
6
|
"types": "./dist/server/index.d.ts",
|