@dataform/core
Advanced tools
Comparing version 1.4.1 to 1.4.2
/// <amd-module name="@dataform/core/adapters/bigquery" /> | ||
import { IAdapter } from "@dataform/core/adapters"; | ||
import { Adapter } from "@dataform/core/adapters/base"; | ||
import { Tasks } from "@dataform/core/tasks"; | ||
import { dataform } from "@dataform/protos"; | ||
import { Tasks } from "../tasks"; | ||
import { Adapter } from "./base"; | ||
import { IAdapter } from "./index"; | ||
export declare class BigQueryAdapter extends Adapter implements IAdapter { | ||
private project; | ||
constructor(project: dataform.IProjectConfig); | ||
private dataformCoreVersion; | ||
constructor(project: dataform.IProjectConfig, dataformCoreVersion: string); | ||
resolveTarget(target: dataform.ITarget): string; | ||
@@ -10,0 +11,0 @@ publishTasks(table: dataform.ITable, runConfig: dataform.IRunConfig, tableMetadata: dataform.ITableMetadata): Tasks; |
@@ -7,3 +7,3 @@ (function (factory) { | ||
else if (typeof define === "function" && define.amd) { | ||
define("@dataform/core/adapters/bigquery", ["require", "exports", "@dataform/protos", "@dataform/core/tasks", "@dataform/core/adapters/base"], factory); | ||
define("@dataform/core/adapters/bigquery", ["require", "exports", "@dataform/core/adapters/base", "@dataform/core/tasks", "@dataform/protos"], factory); | ||
} | ||
@@ -13,9 +13,10 @@ })(function (require, exports) { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const protos_1 = require("@dataform/protos"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
class BigQueryAdapter extends base_1.Adapter { | ||
constructor(project) { | ||
constructor(project, dataformCoreVersion) { | ||
super(); | ||
this.project = project; | ||
this.dataformCoreVersion = dataformCoreVersion; | ||
} | ||
@@ -74,2 +75,2 @@ resolveTarget(target) { | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bigquery.js","sourceRoot":"","sources":["../../../../../core/adapters/bigquery.ts"],"names":[],"mappings":"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","sourcesContent":["import { dataform } from \"@dataform/protos\";\nimport { Task, Tasks } from \"../tasks\";\nimport { Adapter } from \"./base\";\nimport { IAdapter } from \"./index\";\n\nexport class BigQueryAdapter extends Adapter implements IAdapter {\n  private project: dataform.IProjectConfig;\n\n  constructor(project: dataform.IProjectConfig) {\n    super();\n    this.project = project;\n  }\n\n  public resolveTarget(target: dataform.ITarget) {\n    return `\\`${\n      this.project.gcloudProjectId ? `${this.project.gcloudProjectId}.` : \"\"\n    }${target.schema || this.project.defaultSchema}.${target.name}\\``;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop views/tables first if they exist.\n    if (tableMetadata && tableMetadata.type != this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type == \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type == \"view\") {\n        tasks.add(Task.statement(this.createOrReplace(table)));\n      } else {\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.add(Task.statement(this.createOrReplace(table)));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const tasks = Tasks.create();\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n    tasks.add(Task.statement(this.createOrReplaceView(target, assertion.query)));\n    tasks.add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n    return tasks;\n  }\n\n  public createEmptyIfNotExists(table: dataform.ITable) {\n    return `create ${this.baseTableType(table.type)} if not exists ${this.resolveTarget(\n      table.target\n    )} ${\n      table.bigquery && table.bigquery.partitionBy\n        ? `partition by ${table.bigquery.partitionBy}`\n        : \"\"\n    } as ${this.where(table.query, \"false\")}`;\n  }\n\n  public createOrReplace(table: dataform.ITable) {\n    return `create or replace ${this.baseTableType(table.type)} ${this.resolveTarget(\n      table.target\n    )} ${\n      table.bigquery && table.bigquery.partitionBy\n        ? `partition by ${table.bigquery.partitionBy}`\n        : \"\"\n    } as ${table.query}`;\n  }\n\n  public createOrReplaceView(target: dataform.ITarget, query: string) {\n    return `\n      create or replace view ${this.resolveTarget(target)} as ${query}`;\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)}`;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bigquery.js","sourceRoot":"","sources":["../../../../../core/adapters/bigquery.ts"],"names":[],"mappings":"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","sourcesContent":["import { IAdapter } from \"@dataform/core/adapters\";\nimport { Adapter } from \"@dataform/core/adapters/base\";\nimport { Task, Tasks } from \"@dataform/core/tasks\";\nimport { dataform } from \"@dataform/protos\";\n\nexport class BigQueryAdapter extends Adapter implements IAdapter {\n  constructor(private project: dataform.IProjectConfig, private dataformCoreVersion: string) {\n    super();\n  }\n\n  public resolveTarget(target: dataform.ITarget) {\n    return `\\`${\n      this.project.gcloudProjectId ? `${this.project.gcloudProjectId}.` : \"\"\n    }${target.schema || this.project.defaultSchema}.${target.name}\\``;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop views/tables first if they exist.\n    if (tableMetadata && tableMetadata.type != this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type == \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type == \"view\") {\n        tasks.add(Task.statement(this.createOrReplace(table)));\n      } else {\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.add(Task.statement(this.createOrReplace(table)));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const tasks = Tasks.create();\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n    tasks.add(Task.statement(this.createOrReplaceView(target, assertion.query)));\n    tasks.add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n    return tasks;\n  }\n\n  public createEmptyIfNotExists(table: dataform.ITable) {\n    return `create ${this.baseTableType(table.type)} if not exists ${this.resolveTarget(\n      table.target\n    )} ${\n      table.bigquery && table.bigquery.partitionBy\n        ? `partition by ${table.bigquery.partitionBy}`\n        : \"\"\n    } as ${this.where(table.query, \"false\")}`;\n  }\n\n  public createOrReplace(table: dataform.ITable) {\n    return `create or replace ${this.baseTableType(table.type)} ${this.resolveTarget(\n      table.target\n    )} ${\n      table.bigquery && table.bigquery.partitionBy\n        ? `partition by ${table.bigquery.partitionBy}`\n        : \"\"\n    } as ${table.query}`;\n  }\n\n  public createOrReplaceView(target: dataform.ITarget, query: string) {\n    return `\n      create or replace view ${this.resolveTarget(target)} as ${query}`;\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)}`;\n  }\n}\n"]} |
@@ -12,3 +12,3 @@ /// <amd-module name="@dataform/core/adapters/index" /> | ||
} | ||
export declare type AdapterConstructor<T extends IAdapter> = new (projectConfig: dataform.IProjectConfig) => T; | ||
export declare type AdapterConstructor<T extends IAdapter> = new (projectConfig: dataform.IProjectConfig, dataformCoreVersion: string) => T; | ||
export declare enum WarehouseType { | ||
@@ -30,2 +30,2 @@ BIGQUERY = "bigquery", | ||
export declare function register(warehouseType: string, c: AdapterConstructor<IAdapter>): void; | ||
export declare function create(projectConfig: dataform.IProjectConfig): IAdapter; | ||
export declare function create(projectConfig: dataform.IProjectConfig, dataformCoreVersion: string): IAdapter; |
@@ -69,7 +69,7 @@ (function (factory) { | ||
exports.register = register; | ||
function create(projectConfig) { | ||
function create(projectConfig, dataformCoreVersion) { | ||
if (!registry[projectConfig.warehouse]) { | ||
throw new Error(`Unsupported warehouse: ${projectConfig.warehouse}`); | ||
} | ||
return new registry[projectConfig.warehouse](projectConfig); | ||
return new registry[projectConfig.warehouse](projectConfig, dataformCoreVersion); | ||
} | ||
@@ -83,2 +83,2 @@ exports.create = create; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb3JlL2FkYXB0ZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBQUEsK0RBQW1FO0lBQ25FLCtEQUFtRTtJQUNuRSxpRUFBcUU7SUFDckUsK0VBQW1GO0lBdUJuRixJQUFZLGFBTVg7SUFORCxXQUFZLGFBQWE7UUFDdkIsc0NBQXFCLENBQUE7UUFDckIsc0NBQXFCLENBQUE7UUFDckIsc0NBQXFCLENBQUE7UUFDckIsd0NBQXVCLENBQUE7UUFDdkIsc0RBQXFDLENBQUE7SUFDdkMsQ0FBQyxFQU5XLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBTXhCO0lBRUQsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsYUFBYSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFFeEYsU0FBZ0IsY0FBYyxDQUFDLGFBQTRCO1FBQ3pELE9BQU8sc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3JDLE9BQU8sQ0FBQyxLQUFLLGFBQWEsQ0FBQztRQUM3QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFKRCx3Q0FJQztJQUVELE1BQU0sOEJBQThCLEdBQW9DO1FBQ3RFLFdBQVc7UUFDWCxhQUFhO0tBQ2QsQ0FBQztJQUNGLE1BQU0sMEJBQTBCLEdBQWdDO1FBQzlELE1BQU07UUFDTixNQUFNO1FBQ04sVUFBVTtRQUNWLFVBQVU7UUFDVixjQUFjO0tBQ2YsQ0FBQztJQUNGLE1BQU0sK0JBQStCLEdBQXFDO1FBQ3hFLFdBQVc7UUFDWCxVQUFVO1FBQ1YsVUFBVTtRQUNWLE1BQU07UUFDTixjQUFjO1FBQ2QsV0FBVztLQUNaLENBQUM7SUFDRixNQUFNLDZCQUE2QixHQUE0QztRQUM3RSxRQUFRO1FBQ1IsTUFBTTtRQUNOLFVBQVU7UUFDVixVQUFVO1FBQ1YsVUFBVTtLQUNYLENBQUM7SUFFVyxRQUFBLHNCQUFzQixHQUFHO1FBQ3BDLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFFLDhCQUE4QjtRQUN4RCxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsRUFBRSwwQkFBMEI7UUFDcEQsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLEVBQUUsMEJBQTBCO1FBQ3BELENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxFQUFFLCtCQUErQjtRQUMxRCxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLDZCQUE2QjtLQUNoRSxDQUFDO0lBRUYsTUFBTSxRQUFRLEdBQThELEVBQUUsQ0FBQztJQUUvRSxTQUFnQixRQUFRLENBQUMsYUFBcUIsRUFBRSxDQUErQjtRQUM3RSxRQUFRLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFGRCw0QkFFQztJQUVELFNBQWdCLE1BQU0sQ0FBQyxhQUFzQztRQUMzRCxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsRUFBRTtZQUN0QyxNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixhQUFhLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztTQUN0RTtRQUNELE9BQU8sSUFBSSxRQUFRLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFMRCx3QkFLQztJQUVELFFBQVEsQ0FBQyxVQUFVLEVBQUUsMEJBQWUsQ0FBQyxDQUFDO0lBSXRDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsMEJBQWUsQ0FBQyxDQUFDO0lBQ3RDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsMEJBQWUsQ0FBQyxDQUFDO0lBQ3RDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsNEJBQWdCLENBQUMsQ0FBQztJQUN4QyxRQUFRLENBQUMsa0JBQWtCLEVBQUUsMENBQXVCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJpZ1F1ZXJ5QWRhcHRlciB9IGZyb20gXCJAZGF0YWZvcm0vY29yZS9hZGFwdGVycy9iaWdxdWVyeVwiO1xuaW1wb3J0IHsgUmVkc2hpZnRBZGFwdGVyIH0gZnJvbSBcIkBkYXRhZm9ybS9jb3JlL2FkYXB0ZXJzL3JlZHNoaWZ0XCI7XG5pbXBvcnQgeyBTbm93Zmxha2VBZGFwdGVyIH0gZnJvbSBcIkBkYXRhZm9ybS9jb3JlL2FkYXB0ZXJzL3Nub3dmbGFrZVwiO1xuaW1wb3J0IHsgU1FMRGF0YVdhcmVob3VzZUFkYXB0ZXIgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvYWRhcHRlcnMvc3FsZGF0YXdhcmVob3VzZVwiO1xuaW1wb3J0IHsgVGFza3MgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvdGFza3NcIjtcbmltcG9ydCB7IGRhdGFmb3JtIH0gZnJvbSBcIkBkYXRhZm9ybS9wcm90b3NcIjtcblxuZXhwb3J0IGludGVyZmFjZSBJQWRhcHRlciB7XG4gIHJlc29sdmVUYXJnZXQodGFyZ2V0OiBkYXRhZm9ybS5JVGFyZ2V0KTogc3RyaW5nO1xuICBub3JtYWxpemVJZGVudGlmaWVyKGlkZW50aWZpZXI6IHN0cmluZyk6IHN0cmluZztcblxuICBwdWJsaXNoVGFza3MoXG4gICAgdGFibGU6IGRhdGFmb3JtLklUYWJsZSxcbiAgICBydW5Db25maWc6IGRhdGFmb3JtLklSdW5Db25maWcsXG4gICAgdGFibGVNZXRhZGF0YTogZGF0YWZvcm0uSVRhYmxlTWV0YWRhdGFcbiAgKTogVGFza3M7XG4gIGFzc2VydFRhc2tzKGFzc2VydGlvbjogZGF0YWZvcm0uSUFzc2VydGlvbiwgcHJvamVjdENvbmZpZzogZGF0YWZvcm0uSVByb2plY3RDb25maWcpOiBUYXNrcztcblxuICBkcm9wSWZFeGlzdHModGFyZ2V0OiBkYXRhZm9ybS5JVGFyZ2V0LCB0eXBlOiBzdHJpbmcpOiBzdHJpbmc7XG4gIGJhc2VUYWJsZVR5cGUodHlwZTogc3RyaW5nKTogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBBZGFwdGVyQ29uc3RydWN0b3I8VCBleHRlbmRzIElBZGFwdGVyPiA9IG5ldyAoXG4gIHByb2plY3RDb25maWc6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnXG4pID0+IFQ7XG5cbmV4cG9ydCBlbnVtIFdhcmVob3VzZVR5cGUge1xuICBCSUdRVUVSWSA9IFwiYmlncXVlcnlcIixcbiAgUE9TVEdSRVMgPSBcInBvc3RncmVzXCIsXG4gIFJFRFNISUZUID0gXCJyZWRzaGlmdFwiLFxuICBTTk9XRkxBS0UgPSBcInNub3dmbGFrZVwiLFxuICBTUUxEQVRBV0FSRUhPVVNFID0gXCJzcWxkYXRhd2FyZWhvdXNlXCJcbn1cblxuY29uc3QgQ0FOQ0VMTEFUSU9OX1NVUFBPUlRFRCA9IFtXYXJlaG91c2VUeXBlLkJJR1FVRVJZLCBXYXJlaG91c2VUeXBlLlNRTERBVEFXQVJFSE9VU0VdO1xuXG5leHBvcnQgZnVuY3Rpb24gc3VwcG9ydHNDYW5jZWwod2FyZWhvdXNlVHlwZTogV2FyZWhvdXNlVHlwZSkge1xuICByZXR1cm4gQ0FOQ0VMTEFUSU9OX1NVUFBPUlRFRC5zb21lKHcgPT4ge1xuICAgIHJldHVybiB3ID09PSB3YXJlaG91c2VUeXBlO1xuICB9KTtcbn1cblxuY29uc3QgcmVxdWlyZWRCaWdRdWVyeVdhcmVob3VzZVByb3BzOiBBcnJheTxrZXlvZiBkYXRhZm9ybS5JQmlnUXVlcnk+ID0gW1xuICBcInByb2plY3RJZFwiLFxuICBcImNyZWRlbnRpYWxzXCJcbl07XG5jb25zdCByZXF1aXJlZEpkYmNXYXJlaG91c2VQcm9wczogQXJyYXk8a2V5b2YgZGF0YWZvcm0uSUpEQkM+ID0gW1xuICBcImhvc3RcIixcbiAgXCJwb3J0XCIsXG4gIFwidXNlcm5hbWVcIixcbiAgXCJwYXNzd29yZFwiLFxuICBcImRhdGFiYXNlTmFtZVwiXG5dO1xuY29uc3QgcmVxdWlyZWRTbm93Zmxha2VXYXJlaG91c2VQcm9wczogQXJyYXk8a2V5b2YgZGF0YWZvcm0uSVNub3dmbGFrZT4gPSBbXG4gIFwiYWNjb3VudElkXCIsXG4gIFwidXNlcm5hbWVcIixcbiAgXCJwYXNzd29yZFwiLFxuICBcInJvbGVcIixcbiAgXCJkYXRhYmFzZU5hbWVcIixcbiAgXCJ3YXJlaG91c2VcIlxuXTtcbmNvbnN0IHJlcXVpcmVkU1FMRGF0YVdhcmVob3VzZVByb3BzOiBBcnJheTxrZXlvZiBkYXRhZm9ybS5JU1FMRGF0YVdhcmVob3VzZT4gPSBbXG4gIFwic2VydmVyXCIsXG4gIFwicG9ydFwiLFxuICBcInVzZXJuYW1lXCIsXG4gIFwicGFzc3dvcmRcIixcbiAgXCJkYXRhYmFzZVwiXG5dO1xuXG5leHBvcnQgY29uc3QgcmVxdWlyZWRXYXJlaG91c2VQcm9wcyA9IHtcbiAgW1dhcmVob3VzZVR5cGUuQklHUVVFUlldOiByZXF1aXJlZEJpZ1F1ZXJ5V2FyZWhvdXNlUHJvcHMsXG4gIFtXYXJlaG91c2VUeXBlLlBPU1RHUkVTXTogcmVxdWlyZWRKZGJjV2FyZWhvdXNlUHJvcHMsXG4gIFtXYXJlaG91c2VUeXBlLlJFRFNISUZUXTogcmVxdWlyZWRKZGJjV2FyZWhvdXNlUHJvcHMsXG4gIFtXYXJlaG91c2VUeXBlLlNOT1dGTEFLRV06IHJlcXVpcmVkU25vd2ZsYWtlV2FyZWhvdXNlUHJvcHMsXG4gIFtXYXJlaG91c2VUeXBlLlNRTERBVEFXQVJFSE9VU0VdOiByZXF1aXJlZFNRTERhdGFXYXJlaG91c2VQcm9wc1xufTtcblxuY29uc3QgcmVnaXN0cnk6IHsgW3dhcmVob3VzZVR5cGU6IHN0cmluZ106IEFkYXB0ZXJDb25zdHJ1Y3RvcjxJQWRhcHRlcj4gfSA9IHt9O1xuXG5leHBvcnQgZnVuY3Rpb24gcmVnaXN0ZXIod2FyZWhvdXNlVHlwZTogc3RyaW5nLCBjOiBBZGFwdGVyQ29uc3RydWN0b3I8SUFkYXB0ZXI+KSB7XG4gIHJlZ2lzdHJ5W3dhcmVob3VzZVR5cGVdID0gYztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZShwcm9qZWN0Q29uZmlnOiBkYXRhZm9ybS5JUHJvamVjdENvbmZpZyk6IElBZGFwdGVyIHtcbiAgaWYgKCFyZWdpc3RyeVtwcm9qZWN0Q29uZmlnLndhcmVob3VzZV0pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYFVuc3VwcG9ydGVkIHdhcmVob3VzZTogJHtwcm9qZWN0Q29uZmlnLndhcmVob3VzZX1gKTtcbiAgfVxuICByZXR1cm4gbmV3IHJlZ2lzdHJ5W3Byb2plY3RDb25maWcud2FyZWhvdXNlXShwcm9qZWN0Q29uZmlnKTtcbn1cblxucmVnaXN0ZXIoXCJiaWdxdWVyeVwiLCBCaWdRdWVyeUFkYXB0ZXIpO1xuLy8gVE9ETzogVGhlIHJlZHNoaWZ0IGNsaWVudCBsaWJyYXJ5IGhhcHBlbnMgdG8gd29yayB3ZWxsIGZvciBwb3N0Z3JlcywgYnV0IHdlIHNob3VsZCBwcm9iYWJseVxuLy8gbm90IGJlIHJlbHlpbmcgb24gdGhhdCBiZWhhdmlvdXIuIEF0IHNvbWUgcG9pbnQgd2Ugc2hvdWxkIHJlcGxhY2UgdGhpcyB3aXRoIGEgZmlyc3QtY2xhc3Ncbi8vIFBvc3RncmVzQWRhcHRlci5cbnJlZ2lzdGVyKFwicG9zdGdyZXNcIiwgUmVkc2hpZnRBZGFwdGVyKTtcbnJlZ2lzdGVyKFwicmVkc2hpZnRcIiwgUmVkc2hpZnRBZGFwdGVyKTtcbnJlZ2lzdGVyKFwic25vd2ZsYWtlXCIsIFNub3dmbGFrZUFkYXB0ZXIpO1xucmVnaXN0ZXIoXCJzcWxkYXRhd2FyZWhvdXNlXCIsIFNRTERhdGFXYXJlaG91c2VBZGFwdGVyKTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb3JlL2FkYXB0ZXJzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBQUEsK0RBQW1FO0lBQ25FLCtEQUFtRTtJQUNuRSxpRUFBcUU7SUFDckUsK0VBQW1GO0lBd0JuRixJQUFZLGFBTVg7SUFORCxXQUFZLGFBQWE7UUFDdkIsc0NBQXFCLENBQUE7UUFDckIsc0NBQXFCLENBQUE7UUFDckIsc0NBQXFCLENBQUE7UUFDckIsd0NBQXVCLENBQUE7UUFDdkIsc0RBQXFDLENBQUE7SUFDdkMsQ0FBQyxFQU5XLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBTXhCO0lBRUQsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsYUFBYSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFFeEYsU0FBZ0IsY0FBYyxDQUFDLGFBQTRCO1FBQ3pELE9BQU8sc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3JDLE9BQU8sQ0FBQyxLQUFLLGFBQWEsQ0FBQztRQUM3QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFKRCx3Q0FJQztJQUVELE1BQU0sOEJBQThCLEdBQW9DO1FBQ3RFLFdBQVc7UUFDWCxhQUFhO0tBQ2QsQ0FBQztJQUNGLE1BQU0sMEJBQTBCLEdBQWdDO1FBQzlELE1BQU07UUFDTixNQUFNO1FBQ04sVUFBVTtRQUNWLFVBQVU7UUFDVixjQUFjO0tBQ2YsQ0FBQztJQUNGLE1BQU0sK0JBQStCLEdBQXFDO1FBQ3hFLFdBQVc7UUFDWCxVQUFVO1FBQ1YsVUFBVTtRQUNWLE1BQU07UUFDTixjQUFjO1FBQ2QsV0FBVztLQUNaLENBQUM7SUFDRixNQUFNLDZCQUE2QixHQUE0QztRQUM3RSxRQUFRO1FBQ1IsTUFBTTtRQUNOLFVBQVU7UUFDVixVQUFVO1FBQ1YsVUFBVTtLQUNYLENBQUM7SUFFVyxRQUFBLHNCQUFzQixHQUFHO1FBQ3BDLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFFLDhCQUE4QjtRQUN4RCxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsRUFBRSwwQkFBMEI7UUFDcEQsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLEVBQUUsMEJBQTBCO1FBQ3BELENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxFQUFFLCtCQUErQjtRQUMxRCxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLDZCQUE2QjtLQUNoRSxDQUFDO0lBRUYsTUFBTSxRQUFRLEdBQThELEVBQUUsQ0FBQztJQUUvRSxTQUFnQixRQUFRLENBQUMsYUFBcUIsRUFBRSxDQUErQjtRQUM3RSxRQUFRLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFGRCw0QkFFQztJQUVELFNBQWdCLE1BQU0sQ0FDcEIsYUFBc0MsRUFDdEMsbUJBQTJCO1FBRTNCLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3RDLE1BQU0sSUFBSSxLQUFLLENBQUMsMEJBQTBCLGFBQWEsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO1NBQ3RFO1FBQ0QsT0FBTyxJQUFJLFFBQVEsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLENBQUMsYUFBYSxFQUFFLG1CQUFtQixDQUFDLENBQUM7SUFDbkYsQ0FBQztJQVJELHdCQVFDO0lBRUQsUUFBUSxDQUFDLFVBQVUsRUFBRSwwQkFBZSxDQUFDLENBQUM7SUFJdEMsUUFBUSxDQUFDLFVBQVUsRUFBRSwwQkFBZSxDQUFDLENBQUM7SUFDdEMsUUFBUSxDQUFDLFVBQVUsRUFBRSwwQkFBZSxDQUFDLENBQUM7SUFDdEMsUUFBUSxDQUFDLFdBQVcsRUFBRSw0QkFBZ0IsQ0FBQyxDQUFDO0lBQ3hDLFFBQVEsQ0FBQyxrQkFBa0IsRUFBRSwwQ0FBdUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmlnUXVlcnlBZGFwdGVyIH0gZnJvbSBcIkBkYXRhZm9ybS9jb3JlL2FkYXB0ZXJzL2JpZ3F1ZXJ5XCI7XG5pbXBvcnQgeyBSZWRzaGlmdEFkYXB0ZXIgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvYWRhcHRlcnMvcmVkc2hpZnRcIjtcbmltcG9ydCB7IFNub3dmbGFrZUFkYXB0ZXIgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvYWRhcHRlcnMvc25vd2ZsYWtlXCI7XG5pbXBvcnQgeyBTUUxEYXRhV2FyZWhvdXNlQWRhcHRlciB9IGZyb20gXCJAZGF0YWZvcm0vY29yZS9hZGFwdGVycy9zcWxkYXRhd2FyZWhvdXNlXCI7XG5pbXBvcnQgeyBUYXNrcyB9IGZyb20gXCJAZGF0YWZvcm0vY29yZS90YXNrc1wiO1xuaW1wb3J0IHsgZGF0YWZvcm0gfSBmcm9tIFwiQGRhdGFmb3JtL3Byb3Rvc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIElBZGFwdGVyIHtcbiAgcmVzb2x2ZVRhcmdldCh0YXJnZXQ6IGRhdGFmb3JtLklUYXJnZXQpOiBzdHJpbmc7XG4gIG5vcm1hbGl6ZUlkZW50aWZpZXIoaWRlbnRpZmllcjogc3RyaW5nKTogc3RyaW5nO1xuXG4gIHB1Ymxpc2hUYXNrcyhcbiAgICB0YWJsZTogZGF0YWZvcm0uSVRhYmxlLFxuICAgIHJ1bkNvbmZpZzogZGF0YWZvcm0uSVJ1bkNvbmZpZyxcbiAgICB0YWJsZU1ldGFkYXRhOiBkYXRhZm9ybS5JVGFibGVNZXRhZGF0YVxuICApOiBUYXNrcztcbiAgYXNzZXJ0VGFza3MoYXNzZXJ0aW9uOiBkYXRhZm9ybS5JQXNzZXJ0aW9uLCBwcm9qZWN0Q29uZmlnOiBkYXRhZm9ybS5JUHJvamVjdENvbmZpZyk6IFRhc2tzO1xuXG4gIGRyb3BJZkV4aXN0cyh0YXJnZXQ6IGRhdGFmb3JtLklUYXJnZXQsIHR5cGU6IHN0cmluZyk6IHN0cmluZztcbiAgYmFzZVRhYmxlVHlwZSh0eXBlOiBzdHJpbmcpOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIEFkYXB0ZXJDb25zdHJ1Y3RvcjxUIGV4dGVuZHMgSUFkYXB0ZXI+ID0gbmV3IChcbiAgcHJvamVjdENvbmZpZzogZGF0YWZvcm0uSVByb2plY3RDb25maWcsXG4gIGRhdGFmb3JtQ29yZVZlcnNpb246IHN0cmluZ1xuKSA9PiBUO1xuXG5leHBvcnQgZW51bSBXYXJlaG91c2VUeXBlIHtcbiAgQklHUVVFUlkgPSBcImJpZ3F1ZXJ5XCIsXG4gIFBPU1RHUkVTID0gXCJwb3N0Z3Jlc1wiLFxuICBSRURTSElGVCA9IFwicmVkc2hpZnRcIixcbiAgU05PV0ZMQUtFID0gXCJzbm93Zmxha2VcIixcbiAgU1FMREFUQVdBUkVIT1VTRSA9IFwic3FsZGF0YXdhcmVob3VzZVwiXG59XG5cbmNvbnN0IENBTkNFTExBVElPTl9TVVBQT1JURUQgPSBbV2FyZWhvdXNlVHlwZS5CSUdRVUVSWSwgV2FyZWhvdXNlVHlwZS5TUUxEQVRBV0FSRUhPVVNFXTtcblxuZXhwb3J0IGZ1bmN0aW9uIHN1cHBvcnRzQ2FuY2VsKHdhcmVob3VzZVR5cGU6IFdhcmVob3VzZVR5cGUpIHtcbiAgcmV0dXJuIENBTkNFTExBVElPTl9TVVBQT1JURUQuc29tZSh3ID0+IHtcbiAgICByZXR1cm4gdyA9PT0gd2FyZWhvdXNlVHlwZTtcbiAgfSk7XG59XG5cbmNvbnN0IHJlcXVpcmVkQmlnUXVlcnlXYXJlaG91c2VQcm9wczogQXJyYXk8a2V5b2YgZGF0YWZvcm0uSUJpZ1F1ZXJ5PiA9IFtcbiAgXCJwcm9qZWN0SWRcIixcbiAgXCJjcmVkZW50aWFsc1wiXG5dO1xuY29uc3QgcmVxdWlyZWRKZGJjV2FyZWhvdXNlUHJvcHM6IEFycmF5PGtleW9mIGRhdGFmb3JtLklKREJDPiA9IFtcbiAgXCJob3N0XCIsXG4gIFwicG9ydFwiLFxuICBcInVzZXJuYW1lXCIsXG4gIFwicGFzc3dvcmRcIixcbiAgXCJkYXRhYmFzZU5hbWVcIlxuXTtcbmNvbnN0IHJlcXVpcmVkU25vd2ZsYWtlV2FyZWhvdXNlUHJvcHM6IEFycmF5PGtleW9mIGRhdGFmb3JtLklTbm93Zmxha2U+ID0gW1xuICBcImFjY291bnRJZFwiLFxuICBcInVzZXJuYW1lXCIsXG4gIFwicGFzc3dvcmRcIixcbiAgXCJyb2xlXCIsXG4gIFwiZGF0YWJhc2VOYW1lXCIsXG4gIFwid2FyZWhvdXNlXCJcbl07XG5jb25zdCByZXF1aXJlZFNRTERhdGFXYXJlaG91c2VQcm9wczogQXJyYXk8a2V5b2YgZGF0YWZvcm0uSVNRTERhdGFXYXJlaG91c2U+ID0gW1xuICBcInNlcnZlclwiLFxuICBcInBvcnRcIixcbiAgXCJ1c2VybmFtZVwiLFxuICBcInBhc3N3b3JkXCIsXG4gIFwiZGF0YWJhc2VcIlxuXTtcblxuZXhwb3J0IGNvbnN0IHJlcXVpcmVkV2FyZWhvdXNlUHJvcHMgPSB7XG4gIFtXYXJlaG91c2VUeXBlLkJJR1FVRVJZXTogcmVxdWlyZWRCaWdRdWVyeVdhcmVob3VzZVByb3BzLFxuICBbV2FyZWhvdXNlVHlwZS5QT1NUR1JFU106IHJlcXVpcmVkSmRiY1dhcmVob3VzZVByb3BzLFxuICBbV2FyZWhvdXNlVHlwZS5SRURTSElGVF06IHJlcXVpcmVkSmRiY1dhcmVob3VzZVByb3BzLFxuICBbV2FyZWhvdXNlVHlwZS5TTk9XRkxBS0VdOiByZXF1aXJlZFNub3dmbGFrZVdhcmVob3VzZVByb3BzLFxuICBbV2FyZWhvdXNlVHlwZS5TUUxEQVRBV0FSRUhPVVNFXTogcmVxdWlyZWRTUUxEYXRhV2FyZWhvdXNlUHJvcHNcbn07XG5cbmNvbnN0IHJlZ2lzdHJ5OiB7IFt3YXJlaG91c2VUeXBlOiBzdHJpbmddOiBBZGFwdGVyQ29uc3RydWN0b3I8SUFkYXB0ZXI+IH0gPSB7fTtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyKHdhcmVob3VzZVR5cGU6IHN0cmluZywgYzogQWRhcHRlckNvbnN0cnVjdG9yPElBZGFwdGVyPikge1xuICByZWdpc3RyeVt3YXJlaG91c2VUeXBlXSA9IGM7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGUoXG4gIHByb2plY3RDb25maWc6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnLFxuICBkYXRhZm9ybUNvcmVWZXJzaW9uOiBzdHJpbmdcbik6IElBZGFwdGVyIHtcbiAgaWYgKCFyZWdpc3RyeVtwcm9qZWN0Q29uZmlnLndhcmVob3VzZV0pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYFVuc3VwcG9ydGVkIHdhcmVob3VzZTogJHtwcm9qZWN0Q29uZmlnLndhcmVob3VzZX1gKTtcbiAgfVxuICByZXR1cm4gbmV3IHJlZ2lzdHJ5W3Byb2plY3RDb25maWcud2FyZWhvdXNlXShwcm9qZWN0Q29uZmlnLCBkYXRhZm9ybUNvcmVWZXJzaW9uKTtcbn1cblxucmVnaXN0ZXIoXCJiaWdxdWVyeVwiLCBCaWdRdWVyeUFkYXB0ZXIpO1xuLy8gVE9ETzogVGhlIHJlZHNoaWZ0IGNsaWVudCBsaWJyYXJ5IGhhcHBlbnMgdG8gd29yayB3ZWxsIGZvciBwb3N0Z3JlcywgYnV0IHdlIHNob3VsZCBwcm9iYWJseVxuLy8gbm90IGJlIHJlbHlpbmcgb24gdGhhdCBiZWhhdmlvdXIuIEF0IHNvbWUgcG9pbnQgd2Ugc2hvdWxkIHJlcGxhY2UgdGhpcyB3aXRoIGEgZmlyc3QtY2xhc3Ncbi8vIFBvc3RncmVzQWRhcHRlci5cbnJlZ2lzdGVyKFwicG9zdGdyZXNcIiwgUmVkc2hpZnRBZGFwdGVyKTtcbnJlZ2lzdGVyKFwicmVkc2hpZnRcIiwgUmVkc2hpZnRBZGFwdGVyKTtcbnJlZ2lzdGVyKFwic25vd2ZsYWtlXCIsIFNub3dmbGFrZUFkYXB0ZXIpO1xucmVnaXN0ZXIoXCJzcWxkYXRhd2FyZWhvdXNlXCIsIFNRTERhdGFXYXJlaG91c2VBZGFwdGVyKTtcbiJdfQ== |
/// <amd-module name="@dataform/core/adapters/redshift" /> | ||
import { IAdapter } from "@dataform/core/adapters"; | ||
import { Adapter } from "@dataform/core/adapters/base"; | ||
import { Tasks } from "@dataform/core/tasks"; | ||
import { dataform } from "@dataform/protos"; | ||
import { Tasks } from "../tasks"; | ||
import { Adapter } from "./base"; | ||
import { IAdapter } from "./index"; | ||
export declare class RedshiftAdapter extends Adapter implements IAdapter { | ||
private project; | ||
constructor(project: dataform.IProjectConfig); | ||
private dataformCoreVersion; | ||
constructor(project: dataform.IProjectConfig, dataformCoreVersion: string); | ||
resolveTarget(target: dataform.ITarget): string; | ||
publishTasks(table: dataform.ITable, runConfig: dataform.IRunConfig, tableMetadata: dataform.ITableMetadata): Tasks; | ||
assertTasks(assertion: dataform.IAssertion, projectConfig: dataform.IProjectConfig): Tasks; | ||
createOrReplaceView(target: dataform.ITarget, query: string, bind?: boolean): string; | ||
createOrReplaceView(target: dataform.ITarget, query: string, bind: boolean): string; | ||
createOrReplace(table: dataform.ITable): Tasks; | ||
@@ -14,0 +15,0 @@ createTable(table: dataform.ITable, target: dataform.ITarget): string; |
@@ -7,3 +7,3 @@ (function (factory) { | ||
else if (typeof define === "function" && define.amd) { | ||
define("@dataform/core/adapters/redshift", ["require", "exports", "@dataform/protos", "@dataform/core/tasks", "@dataform/core/adapters/base"], factory); | ||
define("@dataform/core/adapters/redshift", ["require", "exports", "@dataform/core/adapters/base", "@dataform/core/tasks", "@dataform/protos", "semver"], factory); | ||
} | ||
@@ -13,9 +13,11 @@ })(function (require, exports) { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const protos_1 = require("@dataform/protos"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
const semver = require("semver"); | ||
class RedshiftAdapter extends base_1.Adapter { | ||
constructor(project) { | ||
constructor(project, dataformCoreVersion) { | ||
super(); | ||
this.project = project; | ||
this.dataformCoreVersion = dataformCoreVersion; | ||
} | ||
@@ -50,6 +52,6 @@ resolveTarget(target) { | ||
return tasks_1.Tasks.create() | ||
.add(tasks_1.Task.statement(this.createOrReplaceView(target, assertion.query))) | ||
.add(tasks_1.Task.statement(this.createOrReplaceView(target, assertion.query, true))) | ||
.add(tasks_1.Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`)); | ||
} | ||
createOrReplaceView(target, query, bind = false) { | ||
createOrReplaceView(target, query, bind) { | ||
const createQuery = `create or replace view ${this.resolveTarget(target)} as ${query}`; | ||
@@ -63,5 +65,8 @@ if (bind) { | ||
if (table.type === "view") { | ||
const isBindDefined = table.redshift && table.redshift.hasOwnProperty("bind"); | ||
const bindDefaultValue = semver.gte(this.dataformCoreVersion, "1.4.1") ? false : true; | ||
const bind = isBindDefined ? table.redshift.bind : bindDefaultValue; | ||
return (tasks_1.Tasks.create() | ||
.add(tasks_1.Task.statement(this.dropIfExists(table.target, this.baseTableType(table.type)))) | ||
.add(tasks_1.Task.statement(this.createOrReplaceView(table.target, table.query, table.redshift && table.redshift.bind)))); | ||
.add(tasks_1.Task.statement(this.createOrReplaceView(table.target, table.query, bind)))); | ||
} | ||
@@ -97,2 +102,2 @@ const tempTableTarget = protos_1.dataform.Target.create({ | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"redshift.js","sourceRoot":"","sources":["../../../../../core/adapters/redshift.ts"],"names":[],"mappings":"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","sourcesContent":["import { dataform } from \"@dataform/protos\";\nimport { Task, Tasks } from \"../tasks\";\nimport { Adapter } from \"./base\";\nimport { IAdapter } from \"./index\";\n\nexport class RedshiftAdapter extends Adapter implements IAdapter {\n  private project: dataform.IProjectConfig;\n\n  constructor(project: dataform.IProjectConfig) {\n    super();\n    this.project = project;\n  }\n\n  public resolveTarget(target: dataform.ITarget) {\n    return `\"${target.schema}\".\"${target.name}\"`;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop the existing view or table if we are changing it's type.\n    if (tableMetadata && tableMetadata.type !== this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type === \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type === \"view\") {\n        tasks.addAll(this.createOrReplace(table));\n      } else {\n        // The table exists, insert new rows.\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.addAll(this.createOrReplace(table));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n    return Tasks.create()\n      .add(Task.statement(this.createOrReplaceView(target, assertion.query)))\n      .add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n  }\n\n  public createOrReplaceView(target: dataform.ITarget, query: string, bind = false) {\n    const createQuery = `create or replace view ${this.resolveTarget(target)} as ${query}`;\n    if (bind) {\n      return createQuery;\n    }\n    return `${createQuery} with no schema binding`;\n  }\n\n  public createOrReplace(table: dataform.ITable) {\n    if (table.type === \"view\") {\n      return (\n        Tasks.create()\n          // Drop the view in case we are changing the number of column(s) (or their types).\n          .add(Task.statement(this.dropIfExists(table.target, this.baseTableType(table.type))))\n          .add(\n            Task.statement(\n              this.createOrReplaceView(\n                table.target,\n                table.query,\n                table.redshift && table.redshift.bind\n              )\n            )\n          )\n      );\n    }\n    const tempTableTarget = dataform.Target.create({\n      schema: table.target.schema,\n      name: table.target.name + \"_temp\"\n    });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(tempTableTarget, this.baseTableType(table.type))))\n      .add(Task.statement(this.createTable(table, tempTableTarget)))\n      .add(Task.statement(this.dropIfExists(table.target, \"table\")))\n      .add(\n        Task.statement(\n          `alter table ${this.resolveTarget(tempTableTarget)} rename to \"${table.target.name}\"`\n        )\n      );\n  }\n\n  public createTable(table: dataform.ITable, target: dataform.ITarget) {\n    if (table.redshift) {\n      let query = `create table ${this.resolveTarget(target)}`;\n\n      if (table.redshift.distStyle && table.redshift.distKey) {\n        query = `${query} diststyle ${table.redshift.distStyle} distkey (${table.redshift.distKey})`;\n      }\n      if (table.redshift.sortStyle && table.redshift.sortKeys) {\n        query = `${query} ${table.redshift.sortStyle} sortkey (${table.redshift.sortKeys.join(\n          \", \"\n        )})`;\n      }\n\n      return `${query} as ${table.query}`;\n    }\n\n    return `create table ${this.resolveTarget(target)} as ${table.query}`;\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)} cascade`;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"redshift.js","sourceRoot":"","sources":["../../../../../core/adapters/redshift.ts"],"names":[],"mappings":"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","sourcesContent":["import { IAdapter } from \"@dataform/core/adapters\";\nimport { Adapter } from \"@dataform/core/adapters/base\";\nimport { Task, Tasks } from \"@dataform/core/tasks\";\nimport { dataform } from \"@dataform/protos\";\nimport * as semver from \"semver\";\n\nexport class RedshiftAdapter extends Adapter implements IAdapter {\n  constructor(private project: dataform.IProjectConfig, private dataformCoreVersion: string) {\n    super();\n  }\n\n  public resolveTarget(target: dataform.ITarget) {\n    return `\"${target.schema}\".\"${target.name}\"`;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop the existing view or table if we are changing it's type.\n    if (tableMetadata && tableMetadata.type !== this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type === \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type === \"view\") {\n        tasks.addAll(this.createOrReplace(table));\n      } else {\n        // The table exists, insert new rows.\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.addAll(this.createOrReplace(table));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n    return Tasks.create()\n      .add(Task.statement(this.createOrReplaceView(target, assertion.query, true)))\n      .add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n  }\n\n  public createOrReplaceView(target: dataform.ITarget, query: string, bind: boolean) {\n    const createQuery = `create or replace view ${this.resolveTarget(target)} as ${query}`;\n    if (bind) {\n      return createQuery;\n    }\n    return `${createQuery} with no schema binding`;\n  }\n\n  public createOrReplace(table: dataform.ITable) {\n    if (table.type === \"view\") {\n      const isBindDefined = table.redshift && table.redshift.hasOwnProperty(\"bind\");\n      const bindDefaultValue = semver.gte(this.dataformCoreVersion, \"1.4.1\") ? false : true;\n      const bind = isBindDefined ? table.redshift.bind : bindDefaultValue;\n      return (\n        Tasks.create()\n          // Drop the view in case we are changing the number of column(s) (or their types).\n          .add(Task.statement(this.dropIfExists(table.target, this.baseTableType(table.type))))\n          .add(Task.statement(this.createOrReplaceView(table.target, table.query, bind)))\n      );\n    }\n    const tempTableTarget = dataform.Target.create({\n      schema: table.target.schema,\n      name: table.target.name + \"_temp\"\n    });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(tempTableTarget, this.baseTableType(table.type))))\n      .add(Task.statement(this.createTable(table, tempTableTarget)))\n      .add(Task.statement(this.dropIfExists(table.target, \"table\")))\n      .add(\n        Task.statement(\n          `alter table ${this.resolveTarget(tempTableTarget)} rename to \"${table.target.name}\"`\n        )\n      );\n  }\n\n  public createTable(table: dataform.ITable, target: dataform.ITarget) {\n    if (table.redshift) {\n      let query = `create table ${this.resolveTarget(target)}`;\n\n      if (table.redshift.distStyle && table.redshift.distKey) {\n        query = `${query} diststyle ${table.redshift.distStyle} distkey (${table.redshift.distKey})`;\n      }\n      if (table.redshift.sortStyle && table.redshift.sortKeys) {\n        query = `${query} ${table.redshift.sortStyle} sortkey (${table.redshift.sortKeys.join(\n          \", \"\n        )})`;\n      }\n\n      return `${query} as ${table.query}`;\n    }\n\n    return `create table ${this.resolveTarget(target)} as ${table.query}`;\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)} cascade`;\n  }\n}\n"]} |
/// <amd-module name="@dataform/core/adapters/snowflake" /> | ||
import { IAdapter } from "@dataform/core/adapters"; | ||
import { Adapter } from "@dataform/core/adapters/base"; | ||
import { Tasks } from "@dataform/core/tasks"; | ||
import { dataform } from "@dataform/protos"; | ||
import { Tasks } from "../tasks"; | ||
import { Adapter } from "./base"; | ||
import { IAdapter } from "./index"; | ||
export declare class SnowflakeAdapter extends Adapter implements IAdapter { | ||
private project; | ||
constructor(project: dataform.IProjectConfig); | ||
private dataformCoreVersion; | ||
constructor(project: dataform.IProjectConfig, dataformCoreVersion: string); | ||
resolveTarget(target: dataform.ITarget): string; | ||
@@ -10,0 +11,0 @@ normalizeIdentifier(identifier: string): string; |
@@ -7,3 +7,3 @@ (function (factory) { | ||
else if (typeof define === "function" && define.amd) { | ||
define("@dataform/core/adapters/snowflake", ["require", "exports", "@dataform/protos", "@dataform/core/tasks", "@dataform/core/adapters/base"], factory); | ||
define("@dataform/core/adapters/snowflake", ["require", "exports", "@dataform/core/adapters/base", "@dataform/core/tasks", "@dataform/protos"], factory); | ||
} | ||
@@ -13,9 +13,10 @@ })(function (require, exports) { | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const protos_1 = require("@dataform/protos"); | ||
const tasks_1 = require("@dataform/core/tasks"); | ||
const base_1 = require("@dataform/core/adapters/base"); | ||
class SnowflakeAdapter extends base_1.Adapter { | ||
constructor(project) { | ||
constructor(project, dataformCoreVersion) { | ||
super(); | ||
this.project = project; | ||
this.dataformCoreVersion = dataformCoreVersion; | ||
} | ||
@@ -67,2 +68,2 @@ resolveTarget(target) { | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25vd2ZsYWtlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vY29yZS9hZGFwdGVycy9zbm93Zmxha2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFBQSw2Q0FBNEM7SUFDNUMsZ0RBQXVDO0lBQ3ZDLHVEQUFpQztJQUdqQyxNQUFhLGdCQUFpQixTQUFRLGNBQU87UUFHM0MsWUFBWSxPQUFnQztZQUMxQyxLQUFLLEVBQUUsQ0FBQztZQUNSLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3pCLENBQUM7UUFFTSxhQUFhLENBQUMsTUFBd0I7WUFDM0MsT0FBTyxJQUFJLE1BQU0sQ0FBQyxNQUFNLE1BQU0sTUFBTSxDQUFDLElBQUksR0FBRyxDQUFDO1FBQy9DLENBQUM7UUFFTSxtQkFBbUIsQ0FBQyxVQUFrQjtZQUMzQyxPQUFPLFVBQVUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNsQyxDQUFDO1FBRU0sWUFBWSxDQUNqQixLQUFzQixFQUN0QixTQUE4QixFQUM5QixhQUFzQztZQUV0QyxNQUFNLEtBQUssR0FBRyxhQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7WUFFN0IsSUFBSSxhQUFhLElBQUksYUFBYSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRTtnQkFDekUsS0FBSyxDQUFDLEdBQUcsQ0FDUCxZQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FDcEYsQ0FBQzthQUNIO1lBQ0QsSUFBSSxLQUFLLENBQUMsSUFBSSxJQUFJLGFBQWEsRUFBRTtnQkFDL0IsSUFBSSxTQUFTLENBQUMsV0FBVyxJQUFJLENBQUMsYUFBYSxJQUFJLGFBQWEsQ0FBQyxJQUFJLElBQUksTUFBTSxFQUFFO29CQUMzRSxLQUFLLENBQUMsR0FBRyxDQUFDLFlBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7aUJBQ3hEO3FCQUFNO29CQUVMLEtBQUssQ0FBQyxHQUFHLENBQ1AsWUFBSSxDQUFDLFNBQVMsQ0FDWixJQUFJLENBQUMsVUFBVSxDQUNiLEtBQUssQ0FBQyxNQUFNLEVBQ1osYUFBYSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQ3JDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLGdCQUFnQixJQUFJLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUMvRCxDQUNGLENBQ0YsQ0FBQztpQkFDSDthQUNGO2lCQUFNO2dCQUNMLEtBQUssQ0FBQyxHQUFHLENBQUMsWUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUN4RDtZQUNELE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUVNLFdBQVcsQ0FDaEIsU0FBOEIsRUFDOUIsYUFBc0M7WUFFdEMsTUFBTSxLQUFLLEdBQUcsYUFBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQzdCLE1BQU0sTUFBTSxHQUNWLFNBQVMsQ0FBQyxNQUFNO2dCQUNoQixpQkFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUM7b0JBQ3JCLE1BQU0sRUFBRSxhQUFhLENBQUMsZUFBZTtvQkFDckMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxJQUFJO2lCQUNyQixDQUFDLENBQUM7WUFDTCxLQUFLLENBQUMsR0FBRyxDQUFDLFlBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzdFLEtBQUssQ0FBQyxHQUFHLENBQUMsWUFBSSxDQUFDLFNBQVMsQ0FBQyxtQ0FBbUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztZQUMzRixPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFFTSxtQkFBbUIsQ0FBQyxNQUF3QixFQUFFLEtBQWE7WUFDaEUsT0FBTzsrQkFDb0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztRQUN0RSxDQUFDO1FBRU0sZUFBZSxDQUFDLEtBQXNCO1lBQzNDLE9BQU8scUJBQXFCLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLElBQUksSUFBSSxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUN6RixLQUFLLENBQUMsTUFBTSxDQUNiLE9BQU8sS0FBSyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3hCLENBQUM7S0FDRjtJQTNFRCw0Q0EyRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkYXRhZm9ybSB9IGZyb20gXCJAZGF0YWZvcm0vcHJvdG9zXCI7XG5pbXBvcnQgeyBUYXNrLCBUYXNrcyB9IGZyb20gXCIuLi90YXNrc1wiO1xuaW1wb3J0IHsgQWRhcHRlciB9IGZyb20gXCIuL2Jhc2VcIjtcbmltcG9ydCB7IElBZGFwdGVyIH0gZnJvbSBcIi4vaW5kZXhcIjtcblxuZXhwb3J0IGNsYXNzIFNub3dmbGFrZUFkYXB0ZXIgZXh0ZW5kcyBBZGFwdGVyIGltcGxlbWVudHMgSUFkYXB0ZXIge1xuICBwcml2YXRlIHByb2plY3Q6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnO1xuXG4gIGNvbnN0cnVjdG9yKHByb2plY3Q6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLnByb2plY3QgPSBwcm9qZWN0O1xuICB9XG5cbiAgcHVibGljIHJlc29sdmVUYXJnZXQodGFyZ2V0OiBkYXRhZm9ybS5JVGFyZ2V0KSB7XG4gICAgcmV0dXJuIGBcIiR7dGFyZ2V0LnNjaGVtYX1cIi5cIiR7dGFyZ2V0Lm5hbWV9XCJgO1xuICB9XG5cbiAgcHVibGljIG5vcm1hbGl6ZUlkZW50aWZpZXIoaWRlbnRpZmllcjogc3RyaW5nKSB7XG4gICAgcmV0dXJuIGlkZW50aWZpZXIudG9VcHBlckNhc2UoKTtcbiAgfVxuXG4gIHB1YmxpYyBwdWJsaXNoVGFza3MoXG4gICAgdGFibGU6IGRhdGFmb3JtLklUYWJsZSxcbiAgICBydW5Db25maWc6IGRhdGFmb3JtLklSdW5Db25maWcsXG4gICAgdGFibGVNZXRhZGF0YTogZGF0YWZvcm0uSVRhYmxlTWV0YWRhdGFcbiAgKTogVGFza3Mge1xuICAgIGNvbnN0IHRhc2tzID0gVGFza3MuY3JlYXRlKCk7XG4gICAgLy8gRHJvcCB0aGUgZXhpc3RpbmcgdmlldyBvciB0YWJsZSBpZiB3ZSBhcmUgY2hhbmdpbmcgaXQncyB0eXBlLlxuICAgIGlmICh0YWJsZU1ldGFkYXRhICYmIHRhYmxlTWV0YWRhdGEudHlwZSAhPSB0aGlzLmJhc2VUYWJsZVR5cGUodGFibGUudHlwZSkpIHtcbiAgICAgIHRhc2tzLmFkZChcbiAgICAgICAgVGFzay5zdGF0ZW1lbnQodGhpcy5kcm9wSWZFeGlzdHModGFibGUudGFyZ2V0LCB0aGlzLm9wcG9zaXRlVGFibGVUeXBlKHRhYmxlLnR5cGUpKSlcbiAgICAgICk7XG4gICAgfVxuICAgIGlmICh0YWJsZS50eXBlID09IFwiaW5jcmVtZW50YWxcIikge1xuICAgICAgaWYgKHJ1bkNvbmZpZy5mdWxsUmVmcmVzaCB8fCAhdGFibGVNZXRhZGF0YSB8fCB0YWJsZU1ldGFkYXRhLnR5cGUgPT0gXCJ2aWV3XCIpIHtcbiAgICAgICAgdGFza3MuYWRkKFRhc2suc3RhdGVtZW50KHRoaXMuY3JlYXRlT3JSZXBsYWNlKHRhYmxlKSkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gVGhlIHRhYmxlIGV4aXN0cywgaW5zZXJ0IG5ldyByb3dzLlxuICAgICAgICB0YXNrcy5hZGQoXG4gICAgICAgICAgVGFzay5zdGF0ZW1lbnQoXG4gICAgICAgICAgICB0aGlzLmluc2VydEludG8oXG4gICAgICAgICAgICAgIHRhYmxlLnRhcmdldCxcbiAgICAgICAgICAgICAgdGFibGVNZXRhZGF0YS5maWVsZHMubWFwKGYgPT4gZi5uYW1lKSxcbiAgICAgICAgICAgICAgdGhpcy53aGVyZSh0YWJsZS5pbmNyZW1lbnRhbFF1ZXJ5IHx8IHRhYmxlLnF1ZXJ5LCB0YWJsZS53aGVyZSlcbiAgICAgICAgICAgIClcbiAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIHRhc2tzLmFkZChUYXNrLnN0YXRlbWVudCh0aGlzLmNyZWF0ZU9yUmVwbGFjZSh0YWJsZSkpKTtcbiAgICB9XG4gICAgcmV0dXJuIHRhc2tzO1xuICB9XG5cbiAgcHVibGljIGFzc2VydFRhc2tzKFxuICAgIGFzc2VydGlvbjogZGF0YWZvcm0uSUFzc2VydGlvbixcbiAgICBwcm9qZWN0Q29uZmlnOiBkYXRhZm9ybS5JUHJvamVjdENvbmZpZ1xuICApOiBUYXNrcyB7XG4gICAgY29uc3QgdGFza3MgPSBUYXNrcy5jcmVhdGUoKTtcbiAgICBjb25zdCB0YXJnZXQgPVxuICAgICAgYXNzZXJ0aW9uLnRhcmdldCB8fFxuICAgICAgZGF0YWZvcm0uVGFyZ2V0LmNyZWF0ZSh7XG4gICAgICAgIHNjaGVtYTogcHJvamVjdENvbmZpZy5hc3NlcnRpb25TY2hlbWEsXG4gICAgICAgIG5hbWU6IGFzc2VydGlvbi5uYW1lXG4gICAgICB9KTtcbiAgICB0YXNrcy5hZGQoVGFzay5zdGF0ZW1lbnQodGhpcy5jcmVhdGVPclJlcGxhY2VWaWV3KHRhcmdldCwgYXNzZXJ0aW9uLnF1ZXJ5KSkpO1xuICAgIHRhc2tzLmFkZChUYXNrLmFzc2VydGlvbihgc2VsZWN0IHN1bSgxKSBhcyByb3dfY291bnQgZnJvbSAke3RoaXMucmVzb2x2ZVRhcmdldCh0YXJnZXQpfWApKTtcbiAgICByZXR1cm4gdGFza3M7XG4gIH1cblxuICBwdWJsaWMgY3JlYXRlT3JSZXBsYWNlVmlldyh0YXJnZXQ6IGRhdGFmb3JtLklUYXJnZXQsIHF1ZXJ5OiBzdHJpbmcpIHtcbiAgICByZXR1cm4gYFxuICAgICAgY3JlYXRlIG9yIHJlcGxhY2UgdmlldyAke3RoaXMucmVzb2x2ZVRhcmdldCh0YXJnZXQpfSBhcyAke3F1ZXJ5fWA7XG4gIH1cblxuICBwdWJsaWMgY3JlYXRlT3JSZXBsYWNlKHRhYmxlOiBkYXRhZm9ybS5JVGFibGUpIHtcbiAgICByZXR1cm4gYGNyZWF0ZSBvciByZXBsYWNlICR7dGhpcy5iYXNlVGFibGVUeXBlKHRhYmxlLnR5cGUgfHwgXCJ0YWJsZVwiKX0gJHt0aGlzLnJlc29sdmVUYXJnZXQoXG4gICAgICB0YWJsZS50YXJnZXRcbiAgICApfSBhcyAke3RhYmxlLnF1ZXJ5fWA7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25vd2ZsYWtlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vY29yZS9hZGFwdGVycy9zbm93Zmxha2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7SUFDQSx1REFBdUQ7SUFDdkQsZ0RBQW1EO0lBQ25ELDZDQUE0QztJQUU1QyxNQUFhLGdCQUFpQixTQUFRLGNBQU87UUFDM0MsWUFBb0IsT0FBZ0MsRUFBVSxtQkFBMkI7WUFDdkYsS0FBSyxFQUFFLENBQUM7WUFEVSxZQUFPLEdBQVAsT0FBTyxDQUF5QjtZQUFVLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBUTtRQUV6RixDQUFDO1FBRU0sYUFBYSxDQUFDLE1BQXdCO1lBQzNDLE9BQU8sSUFBSSxNQUFNLENBQUMsTUFBTSxNQUFNLE1BQU0sQ0FBQyxJQUFJLEdBQUcsQ0FBQztRQUMvQyxDQUFDO1FBRU0sbUJBQW1CLENBQUMsVUFBa0I7WUFDM0MsT0FBTyxVQUFVLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDbEMsQ0FBQztRQUVNLFlBQVksQ0FDakIsS0FBc0IsRUFDdEIsU0FBOEIsRUFDOUIsYUFBc0M7WUFFdEMsTUFBTSxLQUFLLEdBQUcsYUFBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBRTdCLElBQUksYUFBYSxJQUFJLGFBQWEsQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ3pFLEtBQUssQ0FBQyxHQUFHLENBQ1AsWUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQ3BGLENBQUM7YUFDSDtZQUNELElBQUksS0FBSyxDQUFDLElBQUksSUFBSSxhQUFhLEVBQUU7Z0JBQy9CLElBQUksU0FBUyxDQUFDLFdBQVcsSUFBSSxDQUFDLGFBQWEsSUFBSSxhQUFhLENBQUMsSUFBSSxJQUFJLE1BQU0sRUFBRTtvQkFDM0UsS0FBSyxDQUFDLEdBQUcsQ0FBQyxZQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO2lCQUN4RDtxQkFBTTtvQkFFTCxLQUFLLENBQUMsR0FBRyxDQUNQLFlBQUksQ0FBQyxTQUFTLENBQ1osSUFBSSxDQUFDLFVBQVUsQ0FDYixLQUFLLENBQUMsTUFBTSxFQUNaLGFBQWEsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUNyQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxnQkFBZ0IsSUFBSSxLQUFLLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FDL0QsQ0FDRixDQUNGLENBQUM7aUJBQ0g7YUFDRjtpQkFBTTtnQkFDTCxLQUFLLENBQUMsR0FBRyxDQUFDLFlBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDeEQ7WUFDRCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFFTSxXQUFXLENBQ2hCLFNBQThCLEVBQzlCLGFBQXNDO1lBRXRDLE1BQU0sS0FBSyxHQUFHLGFBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUM3QixNQUFNLE1BQU0sR0FDVixTQUFTLENBQUMsTUFBTTtnQkFDaEIsaUJBQVEsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDO29CQUNyQixNQUFNLEVBQUUsYUFBYSxDQUFDLGVBQWU7b0JBQ3JDLElBQUksRUFBRSxTQUFTLENBQUMsSUFBSTtpQkFDckIsQ0FBQyxDQUFDO1lBQ0wsS0FBSyxDQUFDLEdBQUcsQ0FBQyxZQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM3RSxLQUFLLENBQUMsR0FBRyxDQUFDLFlBQUksQ0FBQyxTQUFTLENBQUMsbUNBQW1DLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDM0YsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRU0sbUJBQW1CLENBQUMsTUFBd0IsRUFBRSxLQUFhO1lBQ2hFLE9BQU87K0JBQ29CLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7UUFDdEUsQ0FBQztRQUVNLGVBQWUsQ0FBQyxLQUFzQjtZQUMzQyxPQUFPLHFCQUFxQixJQUFJLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxJQUFJLElBQUksT0FBTyxDQUFDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FDekYsS0FBSyxDQUFDLE1BQU0sQ0FDYixPQUFPLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN4QixDQUFDO0tBQ0Y7SUF4RUQsNENBd0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUFkYXB0ZXIgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvYWRhcHRlcnNcIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvYWRhcHRlcnMvYmFzZVwiO1xuaW1wb3J0IHsgVGFzaywgVGFza3MgfSBmcm9tIFwiQGRhdGFmb3JtL2NvcmUvdGFza3NcIjtcbmltcG9ydCB7IGRhdGFmb3JtIH0gZnJvbSBcIkBkYXRhZm9ybS9wcm90b3NcIjtcblxuZXhwb3J0IGNsYXNzIFNub3dmbGFrZUFkYXB0ZXIgZXh0ZW5kcyBBZGFwdGVyIGltcGxlbWVudHMgSUFkYXB0ZXIge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHByb2plY3Q6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnLCBwcml2YXRlIGRhdGFmb3JtQ29yZVZlcnNpb246IHN0cmluZykge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBwdWJsaWMgcmVzb2x2ZVRhcmdldCh0YXJnZXQ6IGRhdGFmb3JtLklUYXJnZXQpIHtcbiAgICByZXR1cm4gYFwiJHt0YXJnZXQuc2NoZW1hfVwiLlwiJHt0YXJnZXQubmFtZX1cImA7XG4gIH1cblxuICBwdWJsaWMgbm9ybWFsaXplSWRlbnRpZmllcihpZGVudGlmaWVyOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gaWRlbnRpZmllci50b1VwcGVyQ2FzZSgpO1xuICB9XG5cbiAgcHVibGljIHB1Ymxpc2hUYXNrcyhcbiAgICB0YWJsZTogZGF0YWZvcm0uSVRhYmxlLFxuICAgIHJ1bkNvbmZpZzogZGF0YWZvcm0uSVJ1bkNvbmZpZyxcbiAgICB0YWJsZU1ldGFkYXRhOiBkYXRhZm9ybS5JVGFibGVNZXRhZGF0YVxuICApOiBUYXNrcyB7XG4gICAgY29uc3QgdGFza3MgPSBUYXNrcy5jcmVhdGUoKTtcbiAgICAvLyBEcm9wIHRoZSBleGlzdGluZyB2aWV3IG9yIHRhYmxlIGlmIHdlIGFyZSBjaGFuZ2luZyBpdCdzIHR5cGUuXG4gICAgaWYgKHRhYmxlTWV0YWRhdGEgJiYgdGFibGVNZXRhZGF0YS50eXBlICE9IHRoaXMuYmFzZVRhYmxlVHlwZSh0YWJsZS50eXBlKSkge1xuICAgICAgdGFza3MuYWRkKFxuICAgICAgICBUYXNrLnN0YXRlbWVudCh0aGlzLmRyb3BJZkV4aXN0cyh0YWJsZS50YXJnZXQsIHRoaXMub3Bwb3NpdGVUYWJsZVR5cGUodGFibGUudHlwZSkpKVxuICAgICAgKTtcbiAgICB9XG4gICAgaWYgKHRhYmxlLnR5cGUgPT0gXCJpbmNyZW1lbnRhbFwiKSB7XG4gICAgICBpZiAocnVuQ29uZmlnLmZ1bGxSZWZyZXNoIHx8ICF0YWJsZU1ldGFkYXRhIHx8IHRhYmxlTWV0YWRhdGEudHlwZSA9PSBcInZpZXdcIikge1xuICAgICAgICB0YXNrcy5hZGQoVGFzay5zdGF0ZW1lbnQodGhpcy5jcmVhdGVPclJlcGxhY2UodGFibGUpKSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBUaGUgdGFibGUgZXhpc3RzLCBpbnNlcnQgbmV3IHJvd3MuXG4gICAgICAgIHRhc2tzLmFkZChcbiAgICAgICAgICBUYXNrLnN0YXRlbWVudChcbiAgICAgICAgICAgIHRoaXMuaW5zZXJ0SW50byhcbiAgICAgICAgICAgICAgdGFibGUudGFyZ2V0LFxuICAgICAgICAgICAgICB0YWJsZU1ldGFkYXRhLmZpZWxkcy5tYXAoZiA9PiBmLm5hbWUpLFxuICAgICAgICAgICAgICB0aGlzLndoZXJlKHRhYmxlLmluY3JlbWVudGFsUXVlcnkgfHwgdGFibGUucXVlcnksIHRhYmxlLndoZXJlKVxuICAgICAgICAgICAgKVxuICAgICAgICAgIClcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgdGFza3MuYWRkKFRhc2suc3RhdGVtZW50KHRoaXMuY3JlYXRlT3JSZXBsYWNlKHRhYmxlKSkpO1xuICAgIH1cbiAgICByZXR1cm4gdGFza3M7XG4gIH1cblxuICBwdWJsaWMgYXNzZXJ0VGFza3MoXG4gICAgYXNzZXJ0aW9uOiBkYXRhZm9ybS5JQXNzZXJ0aW9uLFxuICAgIHByb2plY3RDb25maWc6IGRhdGFmb3JtLklQcm9qZWN0Q29uZmlnXG4gICk6IFRhc2tzIHtcbiAgICBjb25zdCB0YXNrcyA9IFRhc2tzLmNyZWF0ZSgpO1xuICAgIGNvbnN0IHRhcmdldCA9XG4gICAgICBhc3NlcnRpb24udGFyZ2V0IHx8XG4gICAgICBkYXRhZm9ybS5UYXJnZXQuY3JlYXRlKHtcbiAgICAgICAgc2NoZW1hOiBwcm9qZWN0Q29uZmlnLmFzc2VydGlvblNjaGVtYSxcbiAgICAgICAgbmFtZTogYXNzZXJ0aW9uLm5hbWVcbiAgICAgIH0pO1xuICAgIHRhc2tzLmFkZChUYXNrLnN0YXRlbWVudCh0aGlzLmNyZWF0ZU9yUmVwbGFjZVZpZXcodGFyZ2V0LCBhc3NlcnRpb24ucXVlcnkpKSk7XG4gICAgdGFza3MuYWRkKFRhc2suYXNzZXJ0aW9uKGBzZWxlY3Qgc3VtKDEpIGFzIHJvd19jb3VudCBmcm9tICR7dGhpcy5yZXNvbHZlVGFyZ2V0KHRhcmdldCl9YCkpO1xuICAgIHJldHVybiB0YXNrcztcbiAgfVxuXG4gIHB1YmxpYyBjcmVhdGVPclJlcGxhY2VWaWV3KHRhcmdldDogZGF0YWZvcm0uSVRhcmdldCwgcXVlcnk6IHN0cmluZykge1xuICAgIHJldHVybiBgXG4gICAgICBjcmVhdGUgb3IgcmVwbGFjZSB2aWV3ICR7dGhpcy5yZXNvbHZlVGFyZ2V0KHRhcmdldCl9IGFzICR7cXVlcnl9YDtcbiAgfVxuXG4gIHB1YmxpYyBjcmVhdGVPclJlcGxhY2UodGFibGU6IGRhdGFmb3JtLklUYWJsZSkge1xuICAgIHJldHVybiBgY3JlYXRlIG9yIHJlcGxhY2UgJHt0aGlzLmJhc2VUYWJsZVR5cGUodGFibGUudHlwZSB8fCBcInRhYmxlXCIpfSAke3RoaXMucmVzb2x2ZVRhcmdldChcbiAgICAgIHRhYmxlLnRhcmdldFxuICAgICl9IGFzICR7dGFibGUucXVlcnl9YDtcbiAgfVxufVxuIl19 |
@@ -7,2 +7,5 @@ /// <amd-module name="@dataform/core/adapters/sqldatawarehouse" /> | ||
export declare class SQLDataWarehouseAdapter extends Adapter implements IAdapter { | ||
private project; | ||
private dataformCoreVersion; | ||
constructor(project: dataform.IProjectConfig, dataformCoreVersion: string); | ||
resolveTarget(target: dataform.ITarget): string; | ||
@@ -9,0 +12,0 @@ publishTasks(table: dataform.ITable, runConfig: dataform.IRunConfig, tableMetadata: dataform.ITableMetadata): Tasks; |
@@ -16,2 +16,7 @@ (function (factory) { | ||
class SQLDataWarehouseAdapter extends base_1.Adapter { | ||
constructor(project, dataformCoreVersion) { | ||
super(); | ||
this.project = project; | ||
this.dataformCoreVersion = dataformCoreVersion; | ||
} | ||
resolveTarget(target) { | ||
@@ -84,2 +89,2 @@ return `"${target.schema}"."${target.name}"`; | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sqldatawarehouse.js","sourceRoot":"","sources":["../../../../../core/adapters/sqldatawarehouse.ts"],"names":[],"mappings":"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","sourcesContent":["import { Adapter } from \"@dataform/core/adapters/base\";\nimport { IAdapter } from \"@dataform/core/adapters/index\";\nimport { Task, Tasks } from \"@dataform/core/tasks\";\nimport { dataform } from \"@dataform/protos\";\n\nexport class SQLDataWarehouseAdapter extends Adapter implements IAdapter {\n  public resolveTarget(target: dataform.ITarget) {\n    return `\"${target.schema}\".\"${target.name}\"`;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop the existing view or table if we are changing its type.\n    if (tableMetadata && tableMetadata.type !== this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type === \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type === \"view\") {\n        tasks.addAll(this.createOrReplace(table, !!tableMetadata));\n      } else {\n        // The table exists, insert new rows.\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.addAll(this.createOrReplace(table, !!tableMetadata));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(target, \"view\")))\n      .add(\n        Task.statement(`\n        create view ${this.resolveTarget(target)}\n        as ${assertion.query}`)\n      )\n      .add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    if (type === \"view\") {\n      return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)} `;\n    }\n    return `if object_id ('${this.resolveTarget(\n      target\n    )}','U') is not null drop table ${this.resolveTarget(target)}`;\n  }\n\n  private createOrReplace(table: dataform.ITable, alreadyExists: boolean) {\n    if (table.type === \"view\") {\n      return Tasks.create().add(\n        Task.statement(\n          `${alreadyExists ? \"alter\" : \"create\"} view ${this.resolveTarget(table.target)} as ${\n            table.query\n          }`\n        )\n      );\n    }\n    const tempTableTarget = dataform.Target.create({\n      schema: table.target.schema,\n      name: table.target.name + \"_temp\"\n    });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(tempTableTarget, this.baseTableType(table.type))))\n      .add(Task.statement(this.createTable(table, tempTableTarget)))\n      .add(Task.statement(this.dropIfExists(table.target, \"table\")))\n      .add(\n        Task.statement(\n          `rename object ${this.resolveTarget(tempTableTarget)} to ${table.target.name} `\n        )\n      );\n  }\n\n  private createTable(table: dataform.ITable, target: dataform.ITarget) {\n    const distribution =\n      table.sqlDataWarehouse && table.sqlDataWarehouse.distribution\n        ? table.sqlDataWarehouse.distribution\n        : \"ROUND_ROBIN\"; // default\n    return `create table ${this.resolveTarget(target)}\n     with(\n       distribution = ${distribution}\n     ) \n     as ${table.query}`;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sqldatawarehouse.js","sourceRoot":"","sources":["../../../../../core/adapters/sqldatawarehouse.ts"],"names":[],"mappings":"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","sourcesContent":["import { Adapter } from \"@dataform/core/adapters/base\";\nimport { IAdapter } from \"@dataform/core/adapters/index\";\nimport { Task, Tasks } from \"@dataform/core/tasks\";\nimport { dataform } from \"@dataform/protos\";\n\nexport class SQLDataWarehouseAdapter extends Adapter implements IAdapter {\n  constructor(private project: dataform.IProjectConfig, private dataformCoreVersion: string) {\n    super();\n  }\n\n  public resolveTarget(target: dataform.ITarget) {\n    return `\"${target.schema}\".\"${target.name}\"`;\n  }\n\n  public publishTasks(\n    table: dataform.ITable,\n    runConfig: dataform.IRunConfig,\n    tableMetadata: dataform.ITableMetadata\n  ): Tasks {\n    const tasks = Tasks.create();\n    // Drop the existing view or table if we are changing its type.\n    if (tableMetadata && tableMetadata.type !== this.baseTableType(table.type)) {\n      tasks.add(\n        Task.statement(this.dropIfExists(table.target, this.oppositeTableType(table.type)))\n      );\n    }\n    if (table.type === \"incremental\") {\n      if (runConfig.fullRefresh || !tableMetadata || tableMetadata.type === \"view\") {\n        tasks.addAll(this.createOrReplace(table, !!tableMetadata));\n      } else {\n        // The table exists, insert new rows.\n        tasks.add(\n          Task.statement(\n            this.insertInto(\n              table.target,\n              tableMetadata.fields.map(f => f.name),\n              this.where(table.incrementalQuery || table.query, table.where)\n            )\n          )\n        );\n      }\n    } else {\n      tasks.addAll(this.createOrReplace(table, !!tableMetadata));\n    }\n    return tasks;\n  }\n\n  public assertTasks(\n    assertion: dataform.IAssertion,\n    projectConfig: dataform.IProjectConfig\n  ): Tasks {\n    const target =\n      assertion.target ||\n      dataform.Target.create({\n        schema: projectConfig.assertionSchema,\n        name: assertion.name\n      });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(target, \"view\")))\n      .add(\n        Task.statement(`\n        create view ${this.resolveTarget(target)}\n        as ${assertion.query}`)\n      )\n      .add(Task.assertion(`select sum(1) as row_count from ${this.resolveTarget(target)}`));\n  }\n\n  public dropIfExists(target: dataform.ITarget, type: string) {\n    if (type === \"view\") {\n      return `drop ${this.baseTableType(type)} if exists ${this.resolveTarget(target)} `;\n    }\n    return `if object_id ('${this.resolveTarget(\n      target\n    )}','U') is not null drop table ${this.resolveTarget(target)}`;\n  }\n\n  private createOrReplace(table: dataform.ITable, alreadyExists: boolean) {\n    if (table.type === \"view\") {\n      return Tasks.create().add(\n        Task.statement(\n          `${alreadyExists ? \"alter\" : \"create\"} view ${this.resolveTarget(table.target)} as ${\n            table.query\n          }`\n        )\n      );\n    }\n    const tempTableTarget = dataform.Target.create({\n      schema: table.target.schema,\n      name: table.target.name + \"_temp\"\n    });\n\n    return Tasks.create()\n      .add(Task.statement(this.dropIfExists(tempTableTarget, this.baseTableType(table.type))))\n      .add(Task.statement(this.createTable(table, tempTableTarget)))\n      .add(Task.statement(this.dropIfExists(table.target, \"table\")))\n      .add(\n        Task.statement(\n          `rename object ${this.resolveTarget(tempTableTarget)} to ${table.target.name} `\n        )\n      );\n  }\n\n  private createTable(table: dataform.ITable, target: dataform.ITarget) {\n    const distribution =\n      table.sqlDataWarehouse && table.sqlDataWarehouse.distribution\n        ? table.sqlDataWarehouse.distribution\n        : \"ROUND_ROBIN\"; // default\n    return `create table ${this.resolveTarget(target)}\n     with(\n       distribution = ${distribution}\n     ) \n     as ${table.query}`;\n  }\n}\n"]} |
{ | ||
"version": "1.4.1", | ||
"version": "1.4.2", | ||
"homepage": "https://github.com/dataform-co/dataform", | ||
@@ -24,7 +24,8 @@ "license": "MIT", | ||
"dependencies": { | ||
"@dataform/protos": "1.4.1", | ||
"@dataform/sqlx": "1.4.1", | ||
"@dataform/protos": "1.4.2", | ||
"@dataform/sqlx": "1.4.2", | ||
"protobufjs": "^6.8.8", | ||
"tarjan-graph": "^2.0.0" | ||
"tarjan-graph": "^2.0.0", | ||
"semver": "^5.6.0" | ||
} | ||
} |
Sorry, the diff of this file is too big to display
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
303925
2532
5
+ Addedsemver@^5.6.0
+ Added@dataform/protos@1.4.2(transitive)
+ Added@dataform/sqlx@1.4.2(transitive)
+ Addedsemver@5.7.2(transitive)
- Removed@dataform/protos@1.4.1(transitive)
- Removed@dataform/sqlx@1.4.1(transitive)
Updated@dataform/protos@1.4.2
Updated@dataform/sqlx@1.4.2