@514labs/moose-lib 0.6.284-ci-8-g9790d0a6 → 0.6.284-ci-5-g1643505d

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.
@@ -1,4 +1,4 @@
1
- export { A as Aggregated, h as Api, i as ApiConfig, ag as ConsumerConfig, C as ConsumptionApi, e as DeadLetter, D as DeadLetterModel, f as DeadLetterQueue, l as ETLPipeline, m as ETLPipelineConfig, E as EgressConfig, F as FrameworkApp, I as IngestApi, g as IngestConfig, j as IngestPipeline, ak as IngestPipelineConfig, L as LifeCycle, M as MaterializedView, al as MaterializedViewConfig, a as OlapConfig, O as OlapTable, b as S3QueueTableSettings, S as SimpleAggregated, k as SqlResource, c as Stream, d as StreamConfig, T as Task, aj as TaskConfig, ai as TaskContext, ah as TransformConfig, V as View, n as WebApp, o as WebAppConfig, p as WebAppHandler, W as Workflow, x as getApi, w as getApis, v as getIngestApi, u as getIngestApis, z as getSqlResource, y as getSqlResources, t as getStream, s as getStreams, r as getTable, q as getTables, J as getWebApp, H as getWebApps, G as getWorkflow, B as getWorkflows } from '../index-BtkwFbT9.mjs';
1
+ export { A as Aggregated, h as Api, i as ApiConfig, ag as ConsumerConfig, C as ConsumptionApi, e as DeadLetter, D as DeadLetterModel, f as DeadLetterQueue, l as ETLPipeline, m as ETLPipelineConfig, E as EgressConfig, F as FrameworkApp, I as IngestApi, g as IngestConfig, j as IngestPipeline, ak as IngestPipelineConfig, L as LifeCycle, M as MaterializedView, al as MaterializedViewConfig, a as OlapConfig, O as OlapTable, b as S3QueueTableSettings, S as SimpleAggregated, k as SqlResource, c as Stream, d as StreamConfig, T as Task, aj as TaskConfig, ai as TaskContext, ah as TransformConfig, V as View, n as WebApp, o as WebAppConfig, p as WebAppHandler, W as Workflow, x as getApi, w as getApis, ap as getCustomView, ao as getCustomViews, v as getIngestApi, u as getIngestApis, an as getMaterializedView, am as getMaterializedViews, z as getSqlResource, y as getSqlResources, t as getStream, s as getStreams, r as getTable, q as getTables, J as getWebApp, H as getWebApps, G as getWorkflow, B as getWorkflows } from '../index-KhGbXtkS.mjs';
2
2
  import 'typia';
3
3
  import 'typia/src/schemas/json/IJsonSchemaCollection';
4
4
  import 'node:stream';
@@ -1,4 +1,4 @@
1
- export { A as Aggregated, h as Api, i as ApiConfig, ag as ConsumerConfig, C as ConsumptionApi, e as DeadLetter, D as DeadLetterModel, f as DeadLetterQueue, l as ETLPipeline, m as ETLPipelineConfig, E as EgressConfig, F as FrameworkApp, I as IngestApi, g as IngestConfig, j as IngestPipeline, ak as IngestPipelineConfig, L as LifeCycle, M as MaterializedView, al as MaterializedViewConfig, a as OlapConfig, O as OlapTable, b as S3QueueTableSettings, S as SimpleAggregated, k as SqlResource, c as Stream, d as StreamConfig, T as Task, aj as TaskConfig, ai as TaskContext, ah as TransformConfig, V as View, n as WebApp, o as WebAppConfig, p as WebAppHandler, W as Workflow, x as getApi, w as getApis, v as getIngestApi, u as getIngestApis, z as getSqlResource, y as getSqlResources, t as getStream, s as getStreams, r as getTable, q as getTables, J as getWebApp, H as getWebApps, G as getWorkflow, B as getWorkflows } from '../index-BtkwFbT9.js';
1
+ export { A as Aggregated, h as Api, i as ApiConfig, ag as ConsumerConfig, C as ConsumptionApi, e as DeadLetter, D as DeadLetterModel, f as DeadLetterQueue, l as ETLPipeline, m as ETLPipelineConfig, E as EgressConfig, F as FrameworkApp, I as IngestApi, g as IngestConfig, j as IngestPipeline, ak as IngestPipelineConfig, L as LifeCycle, M as MaterializedView, al as MaterializedViewConfig, a as OlapConfig, O as OlapTable, b as S3QueueTableSettings, S as SimpleAggregated, k as SqlResource, c as Stream, d as StreamConfig, T as Task, aj as TaskConfig, ai as TaskContext, ah as TransformConfig, V as View, n as WebApp, o as WebAppConfig, p as WebAppHandler, W as Workflow, x as getApi, w as getApis, ap as getCustomView, ao as getCustomViews, v as getIngestApi, u as getIngestApis, an as getMaterializedView, am as getMaterializedViews, z as getSqlResource, y as getSqlResources, t as getStream, s as getStreams, r as getTable, q as getTables, J as getWebApp, H as getWebApps, G as getWorkflow, B as getWorkflows } from '../index-KhGbXtkS.js';
2
2
  import 'typia';
3
3
  import 'typia/src/schemas/json/IJsonSchemaCollection';
4
4
  import 'node:stream';
@@ -401,8 +401,12 @@ __export(dmv2_exports, {
401
401
  Workflow: () => Workflow,
402
402
  getApi: () => getApi,
403
403
  getApis: () => getApis,
404
+ getCustomView: () => getCustomView,
405
+ getCustomViews: () => getCustomViews,
404
406
  getIngestApi: () => getIngestApi,
405
407
  getIngestApis: () => getIngestApis,
408
+ getMaterializedView: () => getMaterializedView,
409
+ getMaterializedViews: () => getMaterializedViews,
406
410
  getSqlResource: () => getSqlResource,
407
411
  getSqlResources: () => getSqlResources,
408
412
  getStream: () => getStream,
@@ -601,16 +605,6 @@ function emptyIfUndefined(value) {
601
605
  return value === void 0 ? "" : value;
602
606
  }
603
607
 
604
- // src/blocks/helpers.ts
605
- function dropView(name) {
606
- return `DROP VIEW IF EXISTS ${quoteIdentifier(name)}`.trim();
607
- }
608
- function createMaterializedView(options) {
609
- return `CREATE MATERIALIZED VIEW IF NOT EXISTS ${quoteIdentifier(options.name)}
610
- TO ${quoteIdentifier(options.destinationTable)}
611
- AS ${options.select}`.trim();
612
- }
613
-
614
608
  // src/dmv2/internal.ts
615
609
  var import_process = __toESM(require("process"));
616
610
 
@@ -661,7 +655,9 @@ var moose_internal = {
661
655
  apis: /* @__PURE__ */ new Map(),
662
656
  sqlResources: /* @__PURE__ */ new Map(),
663
657
  workflows: /* @__PURE__ */ new Map(),
664
- webApps: /* @__PURE__ */ new Map()
658
+ webApps: /* @__PURE__ */ new Map(),
659
+ materializedViews: /* @__PURE__ */ new Map(),
660
+ customViews: /* @__PURE__ */ new Map()
665
661
  };
666
662
  var defaultRetentionPeriod = 60 * 60 * 24 * 7;
667
663
  var getMooseInternal = () => globalThis.moose_internal;
@@ -2290,6 +2286,67 @@ var ETLPipeline = class {
2290
2286
  }
2291
2287
  };
2292
2288
 
2289
+ // src/dmv2/sdk/materializedView.ts
2290
+ var requireTargetTableName = (tableName) => {
2291
+ if (typeof tableName === "string") {
2292
+ return tableName;
2293
+ } else {
2294
+ throw new Error("Name of targetTable is not specified.");
2295
+ }
2296
+ };
2297
+ var MaterializedView = class {
2298
+ /** @internal */
2299
+ kind = "MaterializedView";
2300
+ /** The name of the materialized view */
2301
+ name;
2302
+ /** The target OlapTable instance where the materialized data is stored. */
2303
+ targetTable;
2304
+ /** The SELECT SQL statement */
2305
+ selectSql;
2306
+ /** Names of source tables that the SELECT reads from */
2307
+ sourceTables;
2308
+ /** @internal Source file path where this MV was defined */
2309
+ sourceFile;
2310
+ constructor(options, targetSchema, targetColumns) {
2311
+ let selectStatement = options.selectStatement;
2312
+ if (typeof selectStatement !== "string") {
2313
+ selectStatement = toStaticQuery(selectStatement);
2314
+ }
2315
+ if (targetSchema === void 0 || targetColumns === void 0) {
2316
+ throw new Error(
2317
+ "Supply the type param T so that the schema is inserted by the compiler plugin."
2318
+ );
2319
+ }
2320
+ const targetTable = options.targetTable instanceof OlapTable ? options.targetTable : new OlapTable(
2321
+ requireTargetTableName(
2322
+ options.targetTable?.name ?? options.tableName
2323
+ ),
2324
+ {
2325
+ orderByFields: options.targetTable?.orderByFields ?? options.orderByFields,
2326
+ engine: options.targetTable?.engine ?? options.engine ?? "MergeTree" /* MergeTree */
2327
+ },
2328
+ targetSchema,
2329
+ targetColumns
2330
+ );
2331
+ if (targetTable.name === options.materializedViewName) {
2332
+ throw new Error(
2333
+ "Materialized view name cannot be the same as the target table name."
2334
+ );
2335
+ }
2336
+ this.name = options.materializedViewName;
2337
+ this.targetTable = targetTable;
2338
+ this.selectSql = selectStatement;
2339
+ this.sourceTables = options.selectTables.map((t) => t.name);
2340
+ const stack = new Error().stack;
2341
+ this.sourceFile = getSourceFileFromStack(stack);
2342
+ const materializedViews = getMooseInternal().materializedViews;
2343
+ if (!isClientOnlyMode() && materializedViews.has(this.name)) {
2344
+ throw new Error(`MaterializedView with name ${this.name} already exists`);
2345
+ }
2346
+ materializedViews.set(this.name, this);
2347
+ }
2348
+ };
2349
+
2293
2350
  // src/dmv2/sdk/sqlResource.ts
2294
2351
  var SqlResource = class {
2295
2352
  /** @internal */
@@ -2344,66 +2401,18 @@ var SqlResource = class {
2344
2401
  }
2345
2402
  };
2346
2403
 
2347
- // src/dmv2/sdk/materializedView.ts
2348
- var requireTargetTableName = (tableName) => {
2349
- if (typeof tableName === "string") {
2350
- return tableName;
2351
- } else {
2352
- throw new Error("Name of targetTable is not specified.");
2353
- }
2354
- };
2355
- var MaterializedView = class extends SqlResource {
2356
- /** The target OlapTable instance where the materialized data is stored. */
2357
- targetTable;
2358
- constructor(options, targetSchema, targetColumns) {
2359
- let selectStatement = options.selectStatement;
2360
- if (typeof selectStatement !== "string") {
2361
- selectStatement = toStaticQuery(selectStatement);
2362
- }
2363
- if (targetSchema === void 0 || targetColumns === void 0) {
2364
- throw new Error(
2365
- "Supply the type param T so that the schema is inserted by the compiler plugin."
2366
- );
2367
- }
2368
- const targetTable = options.targetTable instanceof OlapTable ? options.targetTable : new OlapTable(
2369
- requireTargetTableName(
2370
- options.targetTable?.name ?? options.tableName
2371
- ),
2372
- {
2373
- orderByFields: options.targetTable?.orderByFields ?? options.orderByFields,
2374
- engine: options.targetTable?.engine ?? options.engine ?? "MergeTree" /* MergeTree */
2375
- },
2376
- targetSchema,
2377
- targetColumns
2378
- );
2379
- if (targetTable.name === options.materializedViewName) {
2380
- throw new Error(
2381
- "Materialized view name cannot be the same as the target table name."
2382
- );
2383
- }
2384
- super(
2385
- options.materializedViewName,
2386
- [
2387
- createMaterializedView({
2388
- name: options.materializedViewName,
2389
- destinationTable: targetTable.name,
2390
- select: selectStatement
2391
- })
2392
- // Population is now handled automatically by Rust infrastructure
2393
- // based on table engine type and whether this is a new or updated view
2394
- ],
2395
- [dropView(options.materializedViewName)],
2396
- {
2397
- pullsDataFrom: options.selectTables,
2398
- pushesDataTo: [targetTable]
2399
- }
2400
- );
2401
- this.targetTable = targetTable;
2402
- }
2403
- };
2404
-
2405
2404
  // src/dmv2/sdk/view.ts
2406
- var View = class extends SqlResource {
2405
+ var View = class {
2406
+ /** @internal */
2407
+ kind = "CustomView";
2408
+ /** The name of the view */
2409
+ name;
2410
+ /** The SELECT SQL statement that defines the view */
2411
+ selectSql;
2412
+ /** Names of source tables/views that the SELECT reads from */
2413
+ sourceTables;
2414
+ /** @internal Source file path where this view was defined */
2415
+ sourceFile;
2407
2416
  /**
2408
2417
  * Creates a new View instance.
2409
2418
  * @param name The name of the view to be created.
@@ -2414,17 +2423,16 @@ var View = class extends SqlResource {
2414
2423
  if (typeof selectStatement !== "string") {
2415
2424
  selectStatement = toStaticQuery(selectStatement);
2416
2425
  }
2417
- super(
2418
- name,
2419
- [
2420
- `CREATE VIEW IF NOT EXISTS ${name}
2421
- AS ${selectStatement}`.trim()
2422
- ],
2423
- [dropView(name)],
2424
- {
2425
- pullsDataFrom: baseTables
2426
- }
2427
- );
2426
+ this.name = name;
2427
+ this.selectSql = selectStatement;
2428
+ this.sourceTables = baseTables.map((t) => t.name);
2429
+ const stack = new Error().stack;
2430
+ this.sourceFile = getSourceFileFromStack(stack);
2431
+ const customViews = getMooseInternal().customViews;
2432
+ if (!isClientOnlyMode() && customViews.has(this.name)) {
2433
+ throw new Error(`View with name ${this.name} already exists`);
2434
+ }
2435
+ customViews.set(this.name, this);
2428
2436
  }
2429
2437
  };
2430
2438
 
@@ -2613,6 +2621,18 @@ function getWebApps() {
2613
2621
  function getWebApp(name) {
2614
2622
  return getMooseInternal().webApps.get(name);
2615
2623
  }
2624
+ function getMaterializedViews() {
2625
+ return getMooseInternal().materializedViews;
2626
+ }
2627
+ function getMaterializedView(name) {
2628
+ return getMooseInternal().materializedViews.get(name);
2629
+ }
2630
+ function getCustomViews() {
2631
+ return getMooseInternal().customViews;
2632
+ }
2633
+ function getCustomView(name) {
2634
+ return getMooseInternal().customViews.get(name);
2635
+ }
2616
2636
  // Annotate the CommonJS export names for ESM import in node:
2617
2637
  0 && (module.exports = {
2618
2638
  Api,
@@ -2632,8 +2652,12 @@ function getWebApp(name) {
2632
2652
  Workflow,
2633
2653
  getApi,
2634
2654
  getApis,
2655
+ getCustomView,
2656
+ getCustomViews,
2635
2657
  getIngestApi,
2636
2658
  getIngestApis,
2659
+ getMaterializedView,
2660
+ getMaterializedViews,
2637
2661
  getSqlResource,
2638
2662
  getSqlResources,
2639
2663
  getStream,