n8n/packages/cli/src/databases/migrations/postgresdb/1589476000887-WebhookModel.ts

34 lines
1.3 KiB
TypeScript
Raw Normal View History

import { MigrationInterface, QueryRunner } from 'typeorm';
2020-05-30 16:03:58 -07:00
import config from '@/config';
2020-05-27 16:32:49 -07:00
export class WebhookModel1589476000887 implements MigrationInterface {
name = 'WebhookModel1589476000887';
2020-06-10 06:58:57 -07:00
async up(queryRunner: QueryRunner): Promise<void> {
let tablePrefix = config.getEnv('database.tablePrefix');
2020-06-23 03:43:40 -07:00
const tablePrefixIndex = tablePrefix;
const schema = config.getEnv('database.postgresdb.schema');
2020-05-27 16:32:49 -07:00
if (schema) {
tablePrefix = schema + '.' + tablePrefix;
}
await queryRunner.query(`SET search_path TO ${schema};`);
await queryRunner.query(
`CREATE TABLE IF NOT EXISTS ${tablePrefix}webhook_entity ("workflowId" integer NOT NULL, "webhookPath" character varying NOT NULL, "method" character varying NOT NULL, "node" character varying NOT NULL, CONSTRAINT "PK_${tablePrefixIndex}b21ace2e13596ccd87dc9bf4ea6" PRIMARY KEY ("webhookPath", "method"))`,
undefined,
);
2020-05-27 16:32:49 -07:00
}
2020-06-10 06:58:57 -07:00
async down(queryRunner: QueryRunner): Promise<void> {
let tablePrefix = config.getEnv('database.tablePrefix');
const schema = config.getEnv('database.postgresdb.schema');
2020-05-27 16:32:49 -07:00
if (schema) {
tablePrefix = schema + '.' + tablePrefix;
}
await queryRunner.query(`SET search_path TO ${schema};`);
2020-06-10 06:58:57 -07:00
await queryRunner.query(`DROP TABLE ${tablePrefix}webhook_entity`, undefined);
}
2020-05-27 16:32:49 -07:00
}