@payloadcms/db-postgres 0.1.0-beta.11 → 0.1.0-beta.13

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../src/connect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAW/C,eAAO,MAAM,OAAO,EAAE,OA4FrB,CAAA"}
1
+ {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../src/connect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAW/C,eAAO,MAAM,OAAO,EAAE,OAqGrB,CAAA"}
package/dist/connect.js CHANGED
@@ -81,7 +81,9 @@ const connect = async function connect(payload) {
81
81
  // Migration table def in order to use query using drizzle
82
82
  const migrationsSchema = (0, _pgcore.pgTable)('payload_migrations', {
83
83
  name: (0, _pgcore.varchar)('name'),
84
- batch: (0, _pgcore.numeric)('batch')
84
+ batch: (0, _pgcore.numeric)('batch'),
85
+ created_at: (0, _pgcore.timestamp)('created_at'),
86
+ updated_at: (0, _pgcore.timestamp)('updated_at')
85
87
  });
86
88
  const devPush = await this.drizzle.select().from(migrationsSchema).where((0, _drizzleorm.eq)(migrationsSchema.batch, '-1'));
87
89
  if (!devPush.length) {
@@ -89,7 +91,11 @@ const connect = async function connect(payload) {
89
91
  name: 'dev',
90
92
  batch: '-1'
91
93
  });
94
+ } else {
95
+ await this.drizzle.update(migrationsSchema).set({
96
+ updated_at: new Date()
97
+ }).where((0, _drizzleorm.eq)(migrationsSchema.batch, '-1'));
92
98
  }
93
99
  };
94
100
 
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb25uZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29ubmVjdCB9IGZyb20gJ3BheWxvYWQvZGF0YWJhc2UnXG5cbmltcG9ydCB7IHB1c2hTY2hlbWEgfSBmcm9tICdkcml6emxlLWtpdC91dGlscydcbmltcG9ydCB7IGVxLCBzcWwgfSBmcm9tICdkcml6emxlLW9ybSdcbmltcG9ydCB7IGRyaXp6bGUgfSBmcm9tICdkcml6emxlLW9ybS9ub2RlLXBvc3RncmVzJ1xuaW1wb3J0IHsganNvbmIsIG51bWVyaWMsIHBnVGFibGUsIHZhcmNoYXIgfSBmcm9tICdkcml6emxlLW9ybS9wZy1jb3JlJ1xuaW1wb3J0IHsgUG9vbCB9IGZyb20gJ3BnJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgY29uc3QgY29ubmVjdDogQ29ubmVjdCA9IGFzeW5jIGZ1bmN0aW9uIGNvbm5lY3QodGhpczogUG9zdGdyZXNBZGFwdGVyLCBwYXlsb2FkKSB7XG4gIHRoaXMuc2NoZW1hID0ge1xuICAgIC4uLnRoaXMudGFibGVzLFxuICAgIC4uLnRoaXMucmVsYXRpb25zLFxuICAgIC4uLnRoaXMuZW51bXMsXG4gIH1cblxuICB0cnkge1xuICAgIHRoaXMucG9vbCA9IG5ldyBQb29sKHRoaXMuY2xpZW50KVxuICAgIGF3YWl0IHRoaXMucG9vbC5jb25uZWN0KClcblxuICAgIHRoaXMuZHJpenpsZSA9IGRyaXp6bGUodGhpcy5wb29sLCB7IHNjaGVtYTogdGhpcy5zY2hlbWEgfSlcbiAgICBpZiAocHJvY2Vzcy5lbnYuUEFZTE9BRF9EUk9QX0RBVEFCQVNFID09PSAndHJ1ZScpIHtcbiAgICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuaW5mbygnLS0tLSBEUk9QUElORyBUQUJMRVMgLS0tLScpXG4gICAgICBhd2FpdCB0aGlzLmRyaXp6bGUuZXhlY3V0ZShzcWxgZHJvcCBzY2hlbWEgcHVibGljIGNhc2NhZGU7XFxuY3JlYXRlIHNjaGVtYSBwdWJsaWM7YClcbiAgICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuaW5mbygnLS0tLSBEUk9QUEVEIFRBQkxFUyAtLS0tJylcbiAgICB9XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHBheWxvYWQubG9nZ2VyLmVycm9yKGBFcnJvcjogY2Fubm90IGNvbm5lY3QgdG8gUG9zdGdyZXMuIERldGFpbHM6ICR7ZXJyLm1lc3NhZ2V9YCwgZXJyKVxuICAgIHByb2Nlc3MuZXhpdCgxKVxuICB9XG5cbiAgdGhpcy5wYXlsb2FkLmxvZ2dlci5pbmZvKCdDb25uZWN0ZWQgdG8gUG9zdGdyZXMgc3VjY2Vzc2Z1bGx5JylcblxuICAvLyBPbmx5IHB1c2ggc2NoZW1hIGlmIG5vdCBpbiBwcm9kdWN0aW9uXG4gIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gJ3Byb2R1Y3Rpb24nIHx8IHByb2Nlc3MuZW52LlBBWUxPQURfTUlHUkFUSU5HID09PSAndHJ1ZScpIHJldHVyblxuXG4gIC8vIFRoaXMgd2lsbCBwcm9tcHQgaWYgY2xhcmlmaWNhdGlvbnMgYXJlIG5lZWRlZCBmb3IgRHJpenpsZSB0byBwdXNoIG5ldyBzY2hlbWFcbiAgY29uc3QgeyBhcHBseSwgaGFzRGF0YUxvc3MsIHN0YXRlbWVudHNUb0V4ZWN1dGUsIHdhcm5pbmdzIH0gPSBhd2FpdCBwdXNoU2NoZW1hKFxuICAgIHRoaXMuc2NoZW1hLFxuICAgIHRoaXMuZHJpenpsZSxcbiAgKVxuXG4gIC8vIHRoaXMucGF5bG9hZC5sb2dnZXIuZGVidWcoe1xuICAvLyAgIGhhc0RhdGFMb3NzLFxuICAvLyAgIG1zZzogJ1NjaGVtYSBwdXNoIHJlc3VsdHMnLFxuICAvLyAgIHN0YXRlbWVudHNUb0V4ZWN1dGUsXG4gIC8vICAgd2FybmluZ3MsXG4gIC8vIH0pXG5cbiAgaWYgKHdhcm5pbmdzLmxlbmd0aCkge1xuICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuaW5mbyh7XG4gICAgICBtc2c6IGBXYXJuaW5ncyBkZXRlY3RlZCBkdXJpbmcgc2NoZW1hIHB1c2g6ICR7d2FybmluZ3Muam9pbignXFxuJyl9YCxcbiAgICAgIHdhcm5pbmdzLFxuICAgIH0pXG5cbiAgICBpZiAoaGFzRGF0YUxvc3MpIHtcbiAgICAgIHRoaXMucGF5bG9hZC5sb2dnZXIuaW5mbyh7XG4gICAgICAgIG1zZzogJ0RBVEEgTE9TUyBXQVJOSU5HOiBQb3NzaWJsZSBkYXRhIGxvc3MgZGV0ZWN0ZWQgaWYgc2NoZW1hIGlzIHB1c2hlZC4nLFxuICAgICAgfSlcbiAgICB9XG5cbiAgICBjb25zdCB7IGNvbmZpcm06IGFjY2VwdFdhcm5pbmdzIH0gPSBhd2FpdCBwcm9tcHRzKFxuICAgICAge1xuICAgICAgICBuYW1lOiAnY29uZmlybScsXG4gICAgICAgIGluaXRpYWw6IGZhbHNlLFxuICAgICAgICBtZXNzYWdlOiAnQWNjZXB0IHdhcm5pbmdzIGFuZCBwdXNoIHNjaGVtYSB0byBkYXRhYmFzZT8nLFxuICAgICAgICB0eXBlOiAnY29uZmlybScsXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBvbkNhbmNlbDogKCkgPT4ge1xuICAgICAgICAgIHByb2Nlc3MuZXhpdCgwKVxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICApXG5cbiAgICAvLyBFeGl0IGlmIHVzZXIgZG9lcyBub3QgYWNjZXB0IHdhcm5pbmdzLlxuICAgIC8vIFE6IElzIHRoaXMgdGhlIHJpZ2h0IHR5cGUgb2YgZXhpdCBmb3IgdGhpcyBpbnRlcmFjdGlvbj9cbiAgICBpZiAoIWFjY2VwdFdhcm5pbmdzKSB7XG4gICAgICBwcm9jZXNzLmV4aXQoMClcbiAgICB9XG4gIH1cblxuICBhd2FpdCBhcHBseSgpXG5cbiAgLy8gTWlncmF0aW9uIHRhYmxlIGRlZiBpbiBvcmRlciB0byB1c2UgcXVlcnkgdXNpbmcgZHJpenpsZVxuICBjb25zdCBtaWdyYXRpb25zU2NoZW1hID0gcGdUYWJsZSgncGF5bG9hZF9taWdyYXRpb25zJywge1xuICAgIG5hbWU6IHZhcmNoYXIoJ25hbWUnKSxcbiAgICBiYXRjaDogbnVtZXJpYygnYmF0Y2gnKSxcbiAgfSlcblxuICBjb25zdCBkZXZQdXNoID0gYXdhaXQgdGhpcy5kcml6emxlXG4gICAgLnNlbGVjdCgpXG4gICAgLmZyb20obWlncmF0aW9uc1NjaGVtYSlcbiAgICAud2hlcmUoZXEobWlncmF0aW9uc1NjaGVtYS5iYXRjaCwgJy0xJykpXG5cbiAgaWYgKCFkZXZQdXNoLmxlbmd0aCkge1xuICAgIGF3YWl0IHRoaXMuZHJpenpsZS5pbnNlcnQobWlncmF0aW9uc1NjaGVtYSkudmFsdWVzKHtcbiAgICAgIG5hbWU6ICdkZXYnLFxuICAgICAgYmF0Y2g6ICctMScsXG4gICAgfSlcbiAgfVxufVxuIl0sIm5hbWVzIjpbImNvbm5lY3QiLCJwYXlsb2FkIiwic2NoZW1hIiwidGFibGVzIiwicmVsYXRpb25zIiwiZW51bXMiLCJwb29sIiwiUG9vbCIsImNsaWVudCIsImRyaXp6bGUiLCJwcm9jZXNzIiwiZW52IiwiUEFZTE9BRF9EUk9QX0RBVEFCQVNFIiwibG9nZ2VyIiwiaW5mbyIsImV4ZWN1dGUiLCJzcWwiLCJlcnIiLCJlcnJvciIsIm1lc3NhZ2UiLCJleGl0IiwiTk9ERV9FTlYiLCJQQVlMT0FEX01JR1JBVElORyIsImFwcGx5IiwiaGFzRGF0YUxvc3MiLCJzdGF0ZW1lbnRzVG9FeGVjdXRlIiwid2FybmluZ3MiLCJwdXNoU2NoZW1hIiwibGVuZ3RoIiwibXNnIiwiam9pbiIsImNvbmZpcm0iLCJhY2NlcHRXYXJuaW5ncyIsInByb21wdHMiLCJuYW1lIiwiaW5pdGlhbCIsInR5cGUiLCJvbkNhbmNlbCIsIm1pZ3JhdGlvbnNTY2hlbWEiLCJwZ1RhYmxlIiwidmFyY2hhciIsImJhdGNoIiwibnVtZXJpYyIsImRldlB1c2giLCJzZWxlY3QiLCJmcm9tIiwid2hlcmUiLCJlcSIsImluc2VydCIsInZhbHVlcyJdLCJtYXBwaW5ncyI6Ijs7OzsrQkFXYUE7OztlQUFBQTs7O3VCQVRjOzRCQUNIOzhC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
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/connect.ts"],"sourcesContent":["import type { Connect } from 'payload/database'\n\nimport { pushSchema } from 'drizzle-kit/utils'\nimport { eq, sql } from 'drizzle-orm'\nimport { drizzle } from 'drizzle-orm/node-postgres'\nimport { numeric, pgTable, timestamp, varchar } from 'drizzle-orm/pg-core'\nimport { Pool } from 'pg'\nimport prompts from 'prompts'\n\nimport type { PostgresAdapter } from './types'\n\nexport const connect: Connect = async function connect(this: PostgresAdapter, payload) {\n  this.schema = {\n    ...this.tables,\n    ...this.relations,\n    ...this.enums,\n  }\n\n  try {\n    this.pool = new Pool(this.client)\n    await this.pool.connect()\n\n    this.drizzle = drizzle(this.pool, { schema: this.schema })\n    if (process.env.PAYLOAD_DROP_DATABASE === 'true') {\n      this.payload.logger.info('---- DROPPING TABLES ----')\n      await this.drizzle.execute(sql`drop schema public cascade;\\ncreate schema public;`)\n      this.payload.logger.info('---- DROPPED TABLES ----')\n    }\n  } catch (err) {\n    payload.logger.error(`Error: cannot connect to Postgres. Details: ${err.message}`, err)\n    process.exit(1)\n  }\n\n  this.payload.logger.info('Connected to Postgres successfully')\n\n  // Only push schema if not in production\n  if (process.env.NODE_ENV === 'production' || process.env.PAYLOAD_MIGRATING === 'true') return\n\n  // This will prompt if clarifications are needed for Drizzle to push new schema\n  const { apply, hasDataLoss, statementsToExecute, warnings } = await pushSchema(\n    this.schema,\n    this.drizzle,\n  )\n\n  // this.payload.logger.debug({\n  //   hasDataLoss,\n  //   msg: 'Schema push results',\n  //   statementsToExecute,\n  //   warnings,\n  // })\n\n  if (warnings.length) {\n    this.payload.logger.info({\n      msg: `Warnings detected during schema push: ${warnings.join('\\n')}`,\n      warnings,\n    })\n\n    if (hasDataLoss) {\n      this.payload.logger.info({\n        msg: 'DATA LOSS WARNING: Possible data loss detected if schema is pushed.',\n      })\n    }\n\n    const { confirm: acceptWarnings } = await prompts(\n      {\n        name: 'confirm',\n        initial: false,\n        message: 'Accept warnings and push schema to database?',\n        type: 'confirm',\n      },\n      {\n        onCancel: () => {\n          process.exit(0)\n        },\n      },\n    )\n\n    // Exit if user does not accept warnings.\n    // Q: Is this the right type of exit for this interaction?\n    if (!acceptWarnings) {\n      process.exit(0)\n    }\n  }\n\n  await apply()\n\n  // Migration table def in order to use query using drizzle\n  const migrationsSchema = pgTable('payload_migrations', {\n    name: varchar('name'),\n    batch: numeric('batch'),\n    created_at: timestamp('created_at'),\n    updated_at: timestamp('updated_at'),\n  })\n\n  const devPush = await this.drizzle\n    .select()\n    .from(migrationsSchema)\n    .where(eq(migrationsSchema.batch, '-1'))\n\n  if (!devPush.length) {\n    await this.drizzle.insert(migrationsSchema).values({\n      name: 'dev',\n      batch: '-1',\n    })\n  } else {\n    await this.drizzle\n      .update(migrationsSchema)\n      .set({\n        updated_at: new Date(),\n      })\n      .where(eq(migrationsSchema.batch, '-1'))\n  }\n}\n"],"names":["connect","payload","schema","tables","relations","enums","pool","Pool","client","drizzle","process","env","PAYLOAD_DROP_DATABASE","logger","info","execute","sql","err","error","message","exit","NODE_ENV","PAYLOAD_MIGRATING","apply","hasDataLoss","statementsToExecute","warnings","pushSchema","length","msg","join","confirm","acceptWarnings","prompts","name","initial","type","onCancel","migrationsSchema","pgTable","varchar","batch","numeric","created_at","timestamp","updated_at","devPush","select","from","where","eq","insert","values","update","set","Date"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"createMigration.d.ts","sourceRoot":"","sources":["../src/createMigration.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAqDvD,eAAO,MAAM,eAAe,EAAE,eAwD7B,CAAA"}
1
+ {"version":3,"file":"createMigration.d.ts","sourceRoot":"","sources":["../src/createMigration.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAoDvD,eAAO,MAAM,eAAe,EAAE,eA4E7B,CAAA"}
@@ -10,6 +10,7 @@ Object.defineProperty(exports, "createMigration", {
10
10
  });
11
11
  const _utils = require("drizzle-kit/utils");
12
12
  const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
13
+ const _prompts = /*#__PURE__*/ _interop_require_default(require("prompts"));
13
14
  function _interop_require_default(obj) {
14
15
  return obj && obj.__esModule ? obj : {
15
16
  default: obj
@@ -70,6 +71,21 @@ const createMigration = async function createMigration(payload, migrationName) {
70
71
  const drizzleJsonAfter = (0, _utils.generateDrizzleJson)(this.schema);
71
72
  const sqlStatementsUp = await (0, _utils.generateMigration)(drizzleJsonBefore, drizzleJsonAfter);
72
73
  const sqlStatementsDown = await (0, _utils.generateMigration)(drizzleJsonAfter, drizzleJsonBefore);
74
+ if (!sqlStatementsUp.length && !sqlStatementsDown.length) {
75
+ const { confirm: shouldCreateBlankMigration } = await (0, _prompts.default)({
76
+ name: 'confirm',
77
+ initial: false,
78
+ message: 'No schema changes detected. Would you like to create a blank migration file?',
79
+ type: 'confirm'
80
+ }, {
81
+ onCancel: ()=>{
82
+ process.exit(0);
83
+ }
84
+ });
85
+ if (!shouldCreateBlankMigration) {
86
+ process.exit(0);
87
+ }
88
+ }
73
89
  // write schema
74
90
  _fs.default.writeFileSync(`${filePath}.json`, JSON.stringify(drizzleJsonAfter, null, 2));
75
91
  // write migration
@@ -79,4 +95,4 @@ const createMigration = async function createMigration(payload, migrationName) {
79
95
  });
80
96
  };
81
97
 
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVNaWdyYXRpb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcmVzdHJpY3RlZC1zeW50YXgsIG5vLWF3YWl0LWluLWxvb3AgKi9cbmltcG9ydCB0eXBlIHsgRHJpenpsZVNuYXBzaG90SlNPTiB9IGZyb20gJ2RyaXp6bGUta2l0L3V0aWxzJ1xuaW1wb3J0IHR5cGUgeyBDcmVhdGVNaWdyYXRpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgeyBnZW5lcmF0ZURyaXp6bGVKc29uLCBnZW5lcmF0ZU1pZ3JhdGlvbiB9IGZyb20gJ2RyaXp6bGUta2l0L3V0aWxzJ1xuaW1wb3J0IGZzIGZyb20gJ2ZzJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IG1pZ3JhdGlvblRhYmxlRXhpc3RzIH0gZnJvbSAnLi91dGlsaXRpZXMvbWlncmF0aW9uVGFibGVFeGlzdHMnXG5cbmNvbnN0IG1pZ3JhdGlvblRlbXBsYXRlID0gKFxuICB1cFNRTD86IHN0cmluZyxcbiAgZG93blNRTD86IHN0cmluZyxcbikgPT4gYGltcG9ydCB7IE1pZ3JhdGVVcEFyZ3MsIE1pZ3JhdGVEb3duQXJncyB9IGZyb20gJ0BwYXlsb2FkY21zL2RiLXBvc3RncmVzJ1xuaW1wb3J0IHsgc3FsIH0gZnJvbSAnZHJpenpsZS1vcm0nXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB1cCh7IHBheWxvYWQgfTogTWlncmF0ZVVwQXJncyk6IFByb21pc2U8dm9pZD4ge1xuJHtcbiAgdXBTUUxcbiAgICA/IGBhd2FpdCBwYXlsb2FkLmRiLmRyaXp6bGUuZXhlY3V0ZShzcWxcXGBcblxuJHt1cFNRTH1cXGApO1xuYFxuICAgIDogJy8vIE1pZ3JhdGlvbiBjb2RlJ1xufVxufTtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRvd24oeyBwYXlsb2FkIH06IE1pZ3JhdGVEb3duQXJncyk6IFByb21pc2U8dm9pZD4ge1xuJHtcbiAgZG93blNRTFxuICAgID8gYGF3YWl0IHBheWxvYWQuZGIuZHJpenpsZS5leGVjdXRlKHNxbFxcYFxuXG4ke2Rvd25TUUx9XFxgKTtcbmBcbiAgICA6ICcvLyBNaWdyYXRpb24gY29kZSdcbn1cbn07XG5gXG5cbmNvbnN0IGdldERlZmF1bHREcml6emxlU25hcHNob3QgPSAoKTogRHJpenpsZVNuYXBzaG90SlNPTiA9PiAoe1xuICBpZDogJzAwMDAwMDAwLTAwMDAtMDAwMC0wMDAwLTAwMDAwMDAwMDAwMCcsXG4gIF9tZXRhOiB7XG4gICAgY29sdW1uczoge30sXG4gICAgc2NoZW1hczoge30sXG4gICAgdGFibGVzOiB7fSxcbiAgfSxcbiAgZGlhbGVjdDogJ3BnJyxcbiAgZW51bXM6IHt9LFxuICBwcmV2SWQ6ICcwMDAwMDAwMC0wMDAwLTAwMDAtMDAwMC0wMDAwMDAwMDAwMCcsXG4gIHNjaGVtYXM6IHt9LFxuICB0YWJsZXM6IHt9LFxuICB2ZXJzaW9uOiAnNScsXG59KVxuXG5leHBvcnQgY29uc3QgY3JlYXRlTWlncmF0aW9uOiBDcmVhdGVNaWdyYXRpb24gPSBhc3luYyBmdW5jdGlvbiBjcmVhdGVNaWdyYXRpb24oXG4gIHRoaXM6IFBvc3RncmVzQWRhcHRlcixcbiAgcGF5bG9hZCxcbiAgbWlncmF0aW9uTmFtZSxcbikge1xuICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiAnQ3JlYXRpbmcgbmV3IG1pZ3JhdGlvbi4uLicgfSlcbiAgY29uc3QgZGlyID0gcGF5bG9hZC5kYi5taWdyYXRpb25EaXJcbiAgaWYgKCFmcy5leGlzdHNTeW5jKGRpcikpIHtcbiAgICBmcy5ta2RpclN5bmMoZGlyKVxuICB9XG5cbiAgY29uc3QgW3l5eW1tZGQsIGhobW1zc10gPSBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCkuc3BsaXQoJ1QnKVxuICBjb25zdCBmb3JtYXR0ZWREYXRlID0geXl5bW1kZC5yZXBsYWNlKC9cXEQvZywgJycpXG4gIGNvbnN0IGZvcm1hdHRlZFRpbWUgPSBoaG1tc3Muc3BsaXQoJy4nKVswXS5yZXBsYWNlKC9cXEQvZywgJycpXG5cbiAgY29uc3QgdGltZXN0YW1wID0gYCR7Zm9ybWF0dGVkRGF0ZX1fJHtmb3JtYXR0ZWRUaW1lfWBcblxuICBjb25zdCBmaWxlTmFtZSA9IG1pZ3JhdGlvbk5hbWVcbiAgICA/IGAke3RpbWVzdGFtcH1fJHttaWdyYXRpb25OYW1lLnJlcGxhY2UoL1xcVy9nLCAnXycpfWBcbiAgICA6IGAke3RpbWVzdGFtcH1gXG5cbiAgY29uc3QgZmlsZVBhdGggPSBgJHtkaXJ9LyR7ZmlsZU5hbWV9YFxuXG4gIGxldCBkcml6emxlSnNvbkJlZm9yZSA9IGdldERlZmF1bHREcml6emxlU25hcHNob3QoKVxuXG4gIC8vIEdldCBsYXRlc3QgbWlncmF0aW9uIHNuYXBzaG90XG4gIGNvbnN0IGxhdGVzdFNuYXBzaG90ID0gZnNcbiAgICAucmVhZGRpclN5bmMoZGlyKVxuICAgIC5maWx0ZXIoKGZpbGUpID0+IGZpbGUuZW5kc1dpdGgoJy5qc29uJykpXG4gICAgLnNvcnQoKVxuICAgIC5yZXZlcnNlKCk/LlswXVxuXG4gIGlmIChsYXRlc3RTbmFwc2hvdCkge1xuICAgIGNvbnN0IGxhdGVzdFNuYXBzaG90SlNPTiA9IEpTT04ucGFyc2UoXG4gICAgICBmcy5yZWFkRmlsZVN5bmMoYCR7ZGlyfS8ke2xhdGVzdFNuYXBzaG90fWAsICd1dGY4JyksXG4gICAgKSBhcyBEcml6emxlU25hcHNob3RKU09OXG5cbiAgICBkcml6emxlSnNvbkJlZm9yZSA9IGxhdGVzdFNuYXBzaG90SlNPTlxuICB9XG5cbiAgY29uc3QgZHJpenpsZUpzb25BZnRlciA9IGdlbmVyYXRlRHJpenpsZUpzb24odGhpcy5zY2hlbWEpXG4gIGNvbnN0IHNxbFN0YXRlbWVudHNVcCA9IGF3YWl0IGdlbmVyYXRlTWlncmF0aW9uKGRyaXp6bGVKc29uQmVmb3JlLCBkcml6emxlSnNvbkFmdGVyKVxuICBjb25zdCBzcWxTdGF0ZW1lbnRzRG93biA9IGF3YWl0IGdlbmVyYXRlTWlncmF0aW9uKGRyaXp6bGVKc29uQWZ0ZXIsIGRyaXp6bGVKc29uQmVmb3JlKVxuXG4gIC8vIHdyaXRlIHNjaGVtYVxuICBmcy53cml0ZUZpbGVTeW5jKGAke2ZpbGVQYXRofS5qc29uYCwgSlNPTi5zdHJpbmdpZnkoZHJpenpsZUpzb25BZnRlciwgbnVsbCwgMikpXG5cbiAgLy8gd3JpdGUgbWlncmF0aW9uXG4gIGZzLndyaXRlRmlsZVN5bmMoXG4gICAgYCR7ZmlsZVBhdGh9LnRzYCxcbiAgICBtaWdyYXRpb25UZW1wbGF0ZShcbiAgICAgIHNxbFN0YXRlbWVudHNVcC5sZW5ndGggPyBzcWxTdGF0ZW1lbnRzVXA/LmpvaW4oJ1xcbicpIDogdW5kZWZpbmVkLFxuICAgICAgc3FsU3RhdGVtZW50c0Rvd24ubGVuZ3RoID8gc3FsU3RhdGVtZW50c0Rvd24/LmpvaW4oJ1xcbicpIDogdW5kZWZpbmVkLFxuICAgICksXG4gIClcbiAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGlvbiBjcmVhdGVkIGF0ICR7ZmlsZVBhdGh9LnRzYCB9KVxufVxuIl0sIm5hbWVzIjpbImNyZWF0ZU1pZ3JhdGlvbiIsIm1pZ3JhdGlvblRlbXBsYXRlIiwidXBTUUwiLCJkb3duU1FMIiwiZ2V0RGVmYXVsdERyaXp6bGVTbmFwc2hvdCIsImlkIiwiX21ldGEiLCJjb2x1bW5zIiwic2NoZW1hcyIsInRhYmxlcyIsImRpYWxlY3QiLCJlbnVtcyIsInByZXZJZCIsInZlcnNpb24iLCJwYXlsb2FkIiwibWlncmF0aW9uTmFtZSIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJkaXIiLCJkYiIsIm1pZ3JhdGlvbkRpciIsImZzIiwiZXhpc3RzU3luYyIsIm1rZGlyU3luYyIsInl5eW1tZGQiLCJoaG1tc3MiLCJEYXRlIiwidG9JU09TdHJpbmciLCJzcGxpdCIsImZvcm1hdHRlZERhdGUiLCJyZXBsYWNlIiwiZm9ybWF0dGVkVGltZSIsInRpbWVzdGFtcCIsImZpbGVOYW1lIiwiZmlsZVBhdGgiLCJkcml6emxlSnNvbkJlZm9yZSIsImxhdGVzdFNuYXBzaG90IiwicmVhZGRpclN5bmMiLCJmaWx0ZXIiLCJmaWxlIiwiZW5kc1dpdGgiLCJzb3J0IiwicmV2ZXJzZSIsImxhdGVzdFNuYXBzaG90SlNPTiIsIkpTT04iLCJwYXJzZSIsInJlYWRGaWxlU3luYyIsImRyaXp6bGVKc29uQWZ0ZXIiLCJnZW5lcmF0ZURyaXp6bGVKc29uIiwic2NoZW1hIiwic3FsU3RhdGVtZW50c1VwIiwiZ2VuZXJhdGVNaWdyYXRpb24iLCJzcWxTdGF0ZW1lbnRzRG93biIsIndyaXRlRmlsZVN5bmMiLCJzdHJpbmdpZnkiLCJsZW5ndGgiLCJqb2luIiwidW5kZWZpbmVkIl0sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7Ozs7K0JBdUQ1Q0E7OztlQUFBQTs7O3VCQW5EMEM7MkRBQ3hDOzs7Ozs7QUFNZixNQUFNQyxvQkFBb0IsQ0FDeEJDLE9BQ0FDLFVBQ0csQ0FBQzs7OztBQUlOLEVBQ0VELFFBQ0ksQ0FBQzs7QUFFUCxFQUFFQSxNQUFNO0FBQ1IsQ0FBQyxHQUNLLG9CQUNMOzs7O0FBSUQsRUFDRUMsVUFDSSxDQUFDOztBQUVQLEVBQUVBLFFBQVE7QUFDVixDQUFDLEdBQ0ssb0JBQ0w7O0FBRUQsQ0FBQztBQUVELE1BQU1DLDRCQUE0QixJQUE0QixDQUFBO1FBQzVEQyxJQUFJO1FBQ0pDLE9BQU87WUFDTEMsU0FBUyxDQUFDO1lBQ1ZDLFNBQVMsQ0FBQztZQUNWQyxRQUFRLENBQUM7UUFDWDtRQUNBQyxTQUFTO1FBQ1RDLE9BQU8sQ0FBQztRQUNSQyxRQUFRO1FBQ1JKLFNBQVMsQ0FBQztRQUNWQyxRQUFRLENBQUM7UUFDVEksU0FBUztJQUNYLENBQUE7QUFFTyxNQUFNYixrQkFBbUMsZUFBZUEsZ0JBRTdEYyxPQUFPLEVBQ1BDLGFBQWE7SUFFYkQsUUFBUUUsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFBRUMsS0FBSztJQUE0QjtJQUN2RCxNQUFNQyxNQUFNTCxRQUFRTSxFQUFFLENBQUNDLFlBQVk7SUFDbkMsSUFBSSxDQUFDQyxXQUFFLENBQUNDLFVBQVUsQ0FBQ0osTUFBTTtRQUN2QkcsV0FBRSxDQUFDRSxTQUFTLENBQUNMO0lBQ2Y7SUFFQSxNQUFNLENBQUNNLFNBQVNDLE9BQU8sR0FBRyxJQUFJQyxPQUFPQyxXQUFXLEdBQUdDLEtBQUssQ0FBQztJQUN6RCxNQUFNQyxnQkFBZ0JMLFFBQVFNLE9BQU8sQ0FBQyxPQUFPO0lBQzdDLE1BQU1DLGdCQUFnQk4sT0FBT0csS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUNFLE9BQU8sQ0FBQyxPQUFPO0lBRTFELE1BQU1FLFlBQVksQ0FBQyxFQUFFSCxjQUFjLENBQUMsRUFBRUUsY0FBYyxDQUFDO0lBRXJELE1BQU1FLFdBQVduQixnQkFDYixDQUFDLEVBQUVrQixVQUFVLENBQUMsRUFBRWxCLGNBQWNnQixPQUFPLENBQUMsT0FBTyxLQUFLLENBQUMsR0FDbkQsQ0FBQyxFQUFFRSxVQUFVLENBQUM7SUFFbEIsTUFBTUUsV0FBVyxDQUFDLEVBQUVoQixJQUFJLENBQUMsRUFBRWUsU0FBUyxDQUFDO0lBRXJDLElBQUlFLG9CQUFvQmhDO0lBRXhCLGdDQUFnQztJQUNoQyxNQUFNaUMsaUJBQWlCZixXQUFFLENBQ3RCZ0IsV0FBVyxDQUFDbkIsS0FDWm9CLE1BQU0sQ0FBQyxDQUFDQyxPQUFTQSxLQUFLQyxRQUFRLENBQUMsVUFDL0JDLElBQUksR0FDSkMsT0FBTyxJQUFJLENBQUMsRUFBRTtJQUVqQixJQUFJTixnQkFBZ0I7UUFDbEIsTUFBTU8scUJBQXFCQyxLQUFLQyxLQUFLLENBQ25DeEIsV0FBRSxDQUFDeUIsWUFBWSxDQUFDLENBQUMsRUFBRTVCLElBQUksQ0FBQyxFQUFFa0IsZUFBZSxDQUFDLEVBQUU7UUFHOUNELG9CQUFvQlE7SUFDdEI7SUFFQSxNQUFNSSxtQkFBbUJDLElBQUFBLDBCQUFtQixFQUFDLElBQUksQ0FBQ0MsTUFBTTtJQUN4RCxNQUFNQyxrQkFBa0IsTUFBTUMsSUFBQUEsd0JBQWlCLEVBQUNoQixtQkFBbUJZO0lBQ25FLE1BQU1LLG9CQUFvQixNQUFNRCxJQUFBQSx3QkFBaUIsRUFBQ0osa0JBQWtCWjtJQUVwRSxlQUFlO0lBQ2ZkLFdBQUUsQ0FBQ2dDLGFBQWEsQ0FBQyxDQUFDLEVBQUVuQixTQUFTLEtBQUssQ0FBQyxFQUFFVSxLQUFLVSxTQUFTLENBQUNQLGtCQUFrQixNQUFNO0lBRTVFLGtCQUFrQjtJQUNsQjFCLFdBQUUsQ0FBQ2dDLGFBQWEsQ0FDZCxDQUFDLEVBQUVuQixTQUFTLEdBQUcsQ0FBQyxFQUNoQmxDLGtCQUNFa0QsZ0JBQWdCSyxNQUFNLEdBQUdMLGlCQUFpQk0sS0FBSyxRQUFRQyxXQUN2REwsa0JBQWtCRyxNQUFNLEdBQUdILG1CQUFtQkksS0FBSyxRQUFRQztJQUcvRDVDLFFBQVFFLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1FBQUVDLEtBQUssQ0FBQyxxQkFBcUIsRUFBRWlCLFNBQVMsR0FBRyxDQUFDO0lBQUM7QUFDbkUifQ==
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/createMigration.ts"],"sourcesContent":["/* eslint-disable no-restricted-syntax, no-await-in-loop */\nimport type { DrizzleSnapshotJSON } from 'drizzle-kit/utils'\nimport type { CreateMigration } from 'payload/database'\n\nimport { generateDrizzleJson, generateMigration } from 'drizzle-kit/utils'\nimport fs from 'fs'\nimport prompts from 'prompts'\n\nimport type { PostgresAdapter } from './types'\n\nconst migrationTemplate = (\n  upSQL?: string,\n  downSQL?: string,\n) => `import { MigrateUpArgs, MigrateDownArgs } from '@payloadcms/db-postgres'\nimport { sql } from 'drizzle-orm'\n\nexport async function up({ payload }: MigrateUpArgs): Promise<void> {\n${\n  upSQL\n    ? `await payload.db.drizzle.execute(sql\\`\n\n${upSQL}\\`);\n`\n    : '// Migration code'\n}\n};\n\nexport async function down({ payload }: MigrateDownArgs): Promise<void> {\n${\n  downSQL\n    ? `await payload.db.drizzle.execute(sql\\`\n\n${downSQL}\\`);\n`\n    : '// Migration code'\n}\n};\n`\n\nconst getDefaultDrizzleSnapshot = (): DrizzleSnapshotJSON => ({\n  id: '00000000-0000-0000-0000-000000000000',\n  _meta: {\n    columns: {},\n    schemas: {},\n    tables: {},\n  },\n  dialect: 'pg',\n  enums: {},\n  prevId: '00000000-0000-0000-0000-00000000000',\n  schemas: {},\n  tables: {},\n  version: '5',\n})\n\nexport const createMigration: CreateMigration = async function createMigration(\n  this: PostgresAdapter,\n  payload,\n  migrationName,\n) {\n  payload.logger.info({ msg: 'Creating new migration...' })\n  const dir = payload.db.migrationDir\n  if (!fs.existsSync(dir)) {\n    fs.mkdirSync(dir)\n  }\n\n  const [yyymmdd, hhmmss] = new Date().toISOString().split('T')\n  const formattedDate = yyymmdd.replace(/\\D/g, '')\n  const formattedTime = hhmmss.split('.')[0].replace(/\\D/g, '')\n\n  const timestamp = `${formattedDate}_${formattedTime}`\n\n  const fileName = migrationName\n    ? `${timestamp}_${migrationName.replace(/\\W/g, '_')}`\n    : `${timestamp}`\n\n  const filePath = `${dir}/${fileName}`\n\n  let drizzleJsonBefore = getDefaultDrizzleSnapshot()\n\n  // Get latest migration snapshot\n  const latestSnapshot = fs\n    .readdirSync(dir)\n    .filter((file) => file.endsWith('.json'))\n    .sort()\n    .reverse()?.[0]\n\n  if (latestSnapshot) {\n    const latestSnapshotJSON = JSON.parse(\n      fs.readFileSync(`${dir}/${latestSnapshot}`, 'utf8'),\n    ) as DrizzleSnapshotJSON\n\n    drizzleJsonBefore = latestSnapshotJSON\n  }\n\n  const drizzleJsonAfter = generateDrizzleJson(this.schema)\n  const sqlStatementsUp = await generateMigration(drizzleJsonBefore, drizzleJsonAfter)\n  const sqlStatementsDown = await generateMigration(drizzleJsonAfter, drizzleJsonBefore)\n\n  if (!sqlStatementsUp.length && !sqlStatementsDown.length) {\n    const { confirm: shouldCreateBlankMigration } = await prompts(\n      {\n        name: 'confirm',\n        initial: false,\n        message: 'No schema changes detected. Would you like to create a blank migration file?',\n        type: 'confirm',\n      },\n      {\n        onCancel: () => {\n          process.exit(0)\n        },\n      },\n    )\n\n    if (!shouldCreateBlankMigration) {\n      process.exit(0)\n    }\n  }\n\n  // write schema\n  fs.writeFileSync(`${filePath}.json`, JSON.stringify(drizzleJsonAfter, null, 2))\n\n  // write migration\n  fs.writeFileSync(\n    `${filePath}.ts`,\n    migrationTemplate(\n      sqlStatementsUp.length ? sqlStatementsUp?.join('\\n') : undefined,\n      sqlStatementsDown.length ? sqlStatementsDown?.join('\\n') : undefined,\n    ),\n  )\n  payload.logger.info({ msg: `Migration created at ${filePath}.ts` })\n}\n"],"names":["createMigration","migrationTemplate","upSQL","downSQL","getDefaultDrizzleSnapshot","id","_meta","columns","schemas","tables","dialect","enums","prevId","version","payload","migrationName","logger","info","msg","dir","db","migrationDir","fs","existsSync","mkdirSync","yyymmdd","hhmmss","Date","toISOString","split","formattedDate","replace","formattedTime","timestamp","fileName","filePath","drizzleJsonBefore","latestSnapshot","readdirSync","filter","file","endsWith","sort","reverse","latestSnapshotJSON","JSON","parse","readFileSync","drizzleJsonAfter","generateDrizzleJson","schema","sqlStatementsUp","generateMigration","sqlStatementsDown","length","confirm","shouldCreateBlankMigration","prompts","name","initial","message","type","onCancel","process","exit","writeFileSync","stringify","join","undefined"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../src/migrate.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAK9C,wBAAsB,OAAO,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAiElE"}
1
+ {"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../src/migrate.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAK9C,wBAAsB,OAAO,CAAC,IAAI,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CA8DlE"}
package/dist/migrate.js CHANGED
@@ -11,70 +11,100 @@ Object.defineProperty(exports, "migrate", {
11
11
  const _utils = require("drizzle-kit/utils");
12
12
  const _database = require("payload/database");
13
13
  const _pg = require("pg");
14
+ const _prompts = /*#__PURE__*/ _interop_require_default(require("prompts"));
14
15
  const _createMigrationTable = require("./utilities/createMigrationTable");
15
16
  const _migrationTableExists = require("./utilities/migrationTableExists");
17
+ function _interop_require_default(obj) {
18
+ return obj && obj.__esModule ? obj : {
19
+ default: obj
20
+ };
21
+ }
16
22
  async function migrate() {
17
23
  const { payload } = this;
18
24
  const migrationFiles = await (0, _database.readMigrationFiles)({
19
25
  payload
20
26
  });
27
+ if (!migrationFiles.length) {
28
+ payload.logger.info({
29
+ msg: 'No migrations to run.'
30
+ });
31
+ return;
32
+ }
21
33
  let latestBatch = 0;
22
- let existingMigrations = [];
34
+ let migrationsInDB = [];
23
35
  const hasMigrationTable = await (0, _migrationTableExists.migrationTableExists)(this.drizzle);
24
36
  if (hasMigrationTable) {
25
- ({ docs: existingMigrations } = await payload.find({
37
+ ({ docs: migrationsInDB } = await payload.find({
26
38
  collection: 'payload-migrations',
27
39
  limit: 0,
28
40
  sort: '-name'
29
41
  }));
30
- if (Number(existingMigrations[0]?.batch) > 0) {
31
- latestBatch = Number(existingMigrations[0]?.batch);
42
+ if (Number(migrationsInDB?.[0]?.batch) > 0) {
43
+ latestBatch = Number(migrationsInDB[0]?.batch);
32
44
  }
33
45
  } else {
34
46
  await (0, _createMigrationTable.createMigrationTable)(this.drizzle);
35
47
  }
48
+ if (migrationsInDB.find((m)=>m.batch === -1)) {
49
+ const { confirm: runMigrations } = await (0, _prompts.default)({
50
+ name: 'confirm',
51
+ initial: false,
52
+ message: "It looks like you've run Payload in dev mode, meaning you've dynamically pushed changes to your database. " + "If you'd like to run migrations, data loss will occur. Would you like to proceed?",
53
+ type: 'confirm'
54
+ }, {
55
+ onCancel: ()=>{
56
+ process.exit(0);
57
+ }
58
+ });
59
+ if (!runMigrations) {
60
+ process.exit(0);
61
+ }
62
+ }
36
63
  const newBatch = latestBatch + 1;
37
64
  // Execute 'up' function for each migration sequentially
38
65
  for (const migration of migrationFiles){
39
- const existingMigration = existingMigrations.find((existing)=>existing.name === migration.name);
40
- // Run migration if not found in database
41
- if (existingMigration) {
66
+ const alreadyRan = migrationsInDB.find((existing)=>existing.name === migration.name);
67
+ // If already ran, skip
68
+ if (alreadyRan) {
42
69
  continue; // eslint-disable-line no-continue
43
70
  }
44
- const start = Date.now();
71
+ await runMigrationFile(payload, migration, newBatch);
72
+ }
73
+ }
74
+ async function runMigrationFile(payload, migration, batch) {
75
+ const start = Date.now();
76
+ payload.logger.info({
77
+ msg: `Migrating: ${migration.name}`
78
+ });
79
+ const pgAdapter = payload.db;
80
+ const drizzleJSON = (0, _utils.generateDrizzleJson)(pgAdapter.schema);
81
+ try {
82
+ await migration.up({
83
+ payload
84
+ });
45
85
  payload.logger.info({
46
- msg: `Migrating: ${migration.name}`
86
+ msg: `Migrated: ${migration.name} (${Date.now() - start}ms)`
47
87
  });
48
- const pgAdapter = payload.db;
49
- const drizzleJSON = (0, _utils.generateDrizzleJson)(pgAdapter.schema);
50
- try {
51
- await migration.up({
52
- payload
53
- });
54
- payload.logger.info({
55
- msg: `Migrated: ${migration.name} (${Date.now() - start}ms)`
56
- });
57
- await payload.create({
58
- collection: 'payload-migrations',
59
- data: {
60
- name: migration.name,
61
- batch: newBatch,
62
- schema: drizzleJSON
63
- }
64
- });
65
- } catch (err) {
66
- let msg = `Error running migration ${migration.name}`;
67
- if (err instanceof _pg.DatabaseError) {
68
- msg += `: ${err.message}`;
69
- if (err.hint) msg += `. ${err.hint}`;
88
+ await payload.create({
89
+ collection: 'payload-migrations',
90
+ data: {
91
+ name: migration.name,
92
+ batch,
93
+ schema: drizzleJSON
70
94
  }
71
- payload.logger.error({
72
- err,
73
- msg
74
- });
75
- throw err;
95
+ });
96
+ } catch (err) {
97
+ let msg = `Error running migration ${migration.name}`;
98
+ if (err instanceof _pg.DatabaseError) {
99
+ msg += `: ${err.message}`;
100
+ if (err.hint) msg += `. ${err.hint}`;
76
101
  }
102
+ payload.logger.error({
103
+ err,
104
+ msg
105
+ });
106
+ throw err;
77
107
  }
78
108
  }
79
109
 
80
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXJlc3RyaWN0ZWQtc3ludGF4LCBuby1hd2FpdC1pbi1sb29wICovXG5pbXBvcnQgeyBnZW5lcmF0ZURyaXp6bGVKc29uIH0gZnJvbSAnZHJpenpsZS1raXQvdXRpbHMnXG5pbXBvcnQgeyByZWFkTWlncmF0aW9uRmlsZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgRGF0YWJhc2VFcnJvciB9IGZyb20gJ3BnJ1xuXG5pbXBvcnQgdHlwZSB7IFBvc3RncmVzQWRhcHRlciB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGNyZWF0ZU1pZ3JhdGlvblRhYmxlIH0gZnJvbSAnLi91dGlsaXRpZXMvY3JlYXRlTWlncmF0aW9uVGFibGUnXG5pbXBvcnQgeyBtaWdyYXRpb25UYWJsZUV4aXN0cyB9IGZyb20gJy4vdXRpbGl0aWVzL21pZ3JhdGlvblRhYmxlRXhpc3RzJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWlncmF0ZSh0aGlzOiBQb3N0Z3Jlc0FkYXB0ZXIpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgeyBwYXlsb2FkIH0gPSB0aGlzXG4gIGNvbnN0IG1pZ3JhdGlvbkZpbGVzID0gYXdhaXQgcmVhZE1pZ3JhdGlvbkZpbGVzKHsgcGF5bG9hZCB9KVxuXG4gIGxldCBsYXRlc3RCYXRjaCA9IDBcbiAgbGV0IGV4aXN0aW5nTWlncmF0aW9ucyA9IFtdXG5cbiAgY29uc3QgaGFzTWlncmF0aW9uVGFibGUgPSBhd2FpdCBtaWdyYXRpb25UYWJsZUV4aXN0cyh0aGlzLmRyaXp6bGUpXG5cbiAgaWYgKGhhc01pZ3JhdGlvblRhYmxlKSB7XG4gICAgOyh7IGRvY3M6IGV4aXN0aW5nTWlncmF0aW9ucyB9ID0gYXdhaXQgcGF5bG9hZC5maW5kKHtcbiAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgbGltaXQ6IDAsXG4gICAgICBzb3J0OiAnLW5hbWUnLFxuICAgIH0pKVxuICAgIGlmIChOdW1iZXIoZXhpc3RpbmdNaWdyYXRpb25zWzBdPy5iYXRjaCkgPiAwKSB7XG4gICAgICBsYXRlc3RCYXRjaCA9IE51bWJlcihleGlzdGluZ01pZ3JhdGlvbnNbMF0/LmJhdGNoKVxuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBhd2FpdCBjcmVhdGVNaWdyYXRpb25UYWJsZSh0aGlzLmRyaXp6bGUpXG4gIH1cblxuICBjb25zdCBuZXdCYXRjaCA9IGxhdGVzdEJhdGNoICsgMVxuXG4gIC8vIEV4ZWN1dGUgJ3VwJyBmdW5jdGlvbiBmb3IgZWFjaCBtaWdyYXRpb24gc2VxdWVudGlhbGx5XG4gIGZvciAoY29uc3QgbWlncmF0aW9uIG9mIG1pZ3JhdGlvbkZpbGVzKSB7XG4gICAgY29uc3QgZXhpc3RpbmdNaWdyYXRpb24gPSBleGlzdGluZ01pZ3JhdGlvbnMuZmluZChcbiAgICAgIChleGlzdGluZykgPT4gZXhpc3RpbmcubmFtZSA9PT0gbWlncmF0aW9uLm5hbWUsXG4gICAgKVxuXG4gICAgLy8gUnVuIG1pZ3JhdGlvbiBpZiBub3QgZm91bmQgaW4gZGF0YWJhc2VcbiAgICBpZiAoZXhpc3RpbmdNaWdyYXRpb24pIHtcbiAgICAgIGNvbnRpbnVlIC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29udGludWVcbiAgICB9XG5cbiAgICBjb25zdCBzdGFydCA9IERhdGUubm93KClcblxuICAgIHBheWxvYWQubG9nZ2VyLmluZm8oeyBtc2c6IGBNaWdyYXRpbmc6ICR7bWlncmF0aW9uLm5hbWV9YCB9KVxuXG4gICAgY29uc3QgcGdBZGFwdGVyID0gcGF5bG9hZC5kYlxuICAgIGNvbnN0IGRyaXp6bGVKU09OID0gZ2VuZXJhdGVEcml6emxlSnNvbihwZ0FkYXB0ZXIuc2NoZW1hKVxuXG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IG1pZ3JhdGlvbi51cCh7IHBheWxvYWQgfSlcbiAgICAgIHBheWxvYWQubG9nZ2VyLmluZm8oeyBtc2c6IGBNaWdyYXRlZDogICR7bWlncmF0aW9uLm5hbWV9ICgke0RhdGUubm93KCkgLSBzdGFydH1tcylgIH0pXG4gICAgICBhd2FpdCBwYXlsb2FkLmNyZWF0ZSh7XG4gICAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgbmFtZTogbWlncmF0aW9uLm5hbWUsXG4gICAgICAgICAgYmF0Y2g6IG5ld0JhdGNoLFxuICAgICAgICAgIHNjaGVtYTogZHJpenpsZUpTT04sXG4gICAgICAgIH0sXG4gICAgICB9KVxuICAgIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgICAgbGV0IG1zZyA9IGBFcnJvciBydW5uaW5nIG1pZ3JhdGlvbiAke21pZ3JhdGlvbi5uYW1lfWBcblxuICAgICAgaWYgKGVyciBpbnN0YW5jZW9mIERhdGFiYXNlRXJyb3IpIHtcbiAgICAgICAgbXNnICs9IGA6ICR7ZXJyLm1lc3NhZ2V9YFxuICAgICAgICBpZiAoZXJyLmhpbnQpIG1zZyArPSBgLiAke2Vyci5oaW50fWBcbiAgICAgIH1cblxuICAgICAgcGF5bG9hZC5sb2dnZXIuZXJyb3IoeyBlcnIsIG1zZyB9KVxuICAgICAgdGhyb3cgZXJyXG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsibWlncmF0ZSIsInBheWxvYWQiLCJtaWdyYXRpb25GaWxlcyIsInJlYWRNaWdyYXRpb25GaWxlcyIsImxhdGVzdEJhdGNoIiwiZXhpc3RpbmdNaWdyYXRpb25zIiwiaGFzTWlncmF0aW9uVGFibGUiLCJtaWdyYXRpb25UYWJsZUV4aXN0cyIsImRyaXp6bGUiLCJkb2NzIiwiZmluZCIsImNvbGxlY3Rpb24iLCJsaW1pdCIsInNvcnQiLCJOdW1iZXIiLCJiYXRjaCIsImNyZWF0ZU1pZ3JhdGlvblRhYmxlIiwibmV3QmF0Y2giLCJtaWdyYXRpb24iLCJleGlzdGluZ01pZ3JhdGlvbiIsImV4aXN0aW5nIiwibmFtZSIsInN0YXJ0IiwiRGF0ZSIsIm5vdyIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJwZ0FkYXB0ZXIiLCJkYiIsImRyaXp6bGVKU09OIiwiZ2VuZXJhdGVEcml6emxlSnNvbiIsInNjaGVtYSIsInVwIiwiY3JlYXRlIiwiZGF0YSIsImVyciIsIkRhdGFiYXNlRXJyb3IiLCJtZXNzYWdlIiwiaGludCIsImVycm9yIl0sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7Ozs7K0JBVW5DQTs7O2VBQUFBOzs7dUJBVGM7MEJBQ0Q7b0JBQ0w7c0NBSU87c0NBQ0E7QUFFOUIsZUFBZUE7SUFDcEIsTUFBTSxFQUFFQyxPQUFPLEVBQUUsR0FBRyxJQUFJO0lBQ3hCLE1BQU1DLGlCQUFpQixNQUFNQyxJQUFBQSw0QkFBa0IsRUFBQztRQUFFRjtJQUFRO0lBRTFELElBQUlHLGNBQWM7SUFDbEIsSUFBSUMscUJBQXFCLEVBQUU7SUFFM0IsTUFBTUMsb0JBQW9CLE1BQU1DLElBQUFBLDBDQUFvQixFQUFDLElBQUksQ0FBQ0MsT0FBTztJQUVqRSxJQUFJRixtQkFBbUI7UUFDbkIsQ0FBQSxFQUFFRyxNQUFNSixrQkFBa0IsRUFBRSxHQUFHLE1BQU1KLFFBQVFTLElBQUksQ0FBQztZQUNsREMsWUFBWTtZQUNaQyxPQUFPO1lBQ1BDLE1BQU07UUFDUixFQUFDO1FBQ0QsSUFBSUMsT0FBT1Qsa0JBQWtCLENBQUMsRUFBRSxFQUFFVSxTQUFTLEdBQUc7WUFDNUNYLGNBQWNVLE9BQU9ULGtCQUFrQixDQUFDLEVBQUUsRUFBRVU7UUFDOUM7SUFDRixPQUFPO1FBQ0wsTUFBTUMsSUFBQUEsMENBQW9CLEVBQUMsSUFBSSxDQUFDUixPQUFPO0lBQ3pDO0lBRUEsTUFBTVMsV0FBV2IsY0FBYztJQUUvQix3REFBd0Q7SUFDeEQsS0FBSyxNQUFNYyxhQUFhaEIsZUFBZ0I7UUFDdEMsTUFBTWlCLG9CQUFvQmQsbUJBQW1CSyxJQUFJLENBQy9DLENBQUNVLFdBQWFBLFNBQVNDLElBQUksS0FBS0gsVUFBVUcsSUFBSTtRQUdoRCx5Q0FBeUM7UUFDekMsSUFBSUYsbUJBQW1CO1lBQ3JCLFVBQVMsa0NBQWtDO1FBQzdDO1FBRUEsTUFBTUcsUUFBUUMsS0FBS0MsR0FBRztRQUV0QnZCLFFBQVF3QixNQUFNLENBQUNDLElBQUksQ0FBQztZQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFVCxVQUFVRyxJQUFJLENBQUMsQ0FBQztRQUFDO1FBRTFELE1BQU1PLFlBQVkzQixRQUFRNEIsRUFBRTtRQUM1QixNQUFNQyxjQUFjQyxJQUFBQSwwQkFBbUIsRUFBQ0gsVUFBVUksTUFBTTtRQUV4RCxJQUFJO1lBQ0YsTUFBTWQsVUFBVWUsRUFBRSxDQUFDO2dCQUFFaEM7WUFBUTtZQUM3QkEsUUFBUXdCLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO2dCQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFVCxVQUFVRyxJQUFJLENBQUMsRUFBRSxFQUFFRSxLQUFLQyxHQUFHLEtBQUtGLE1BQU0sR0FBRyxDQUFDO1lBQUM7WUFDcEYsTUFBTXJCLFFBQVFpQyxNQUFNLENBQUM7Z0JBQ25CdkIsWUFBWTtnQkFDWndCLE1BQU07b0JBQ0pkLE1BQU1ILFVBQVVHLElBQUk7b0JBQ3BCTixPQUFPRTtvQkFDUGUsUUFBUUY7Z0JBQ1Y7WUFDRjtRQUNGLEVBQUUsT0FBT00sS0FBYztZQUNyQixJQUFJVCxNQUFNLENBQUMsd0JBQXdCLEVBQUVULFVBQVVHLElBQUksQ0FBQyxDQUFDO1lBRXJELElBQUllLGVBQWVDLGlCQUFhLEVBQUU7Z0JBQ2hDVixPQUFPLENBQUMsRUFBRSxFQUFFUyxJQUFJRSxPQUFPLENBQUMsQ0FBQztnQkFDekIsSUFBSUYsSUFBSUcsSUFBSSxFQUFFWixPQUFPLENBQUMsRUFBRSxFQUFFUyxJQUFJRyxJQUFJLENBQUMsQ0FBQztZQUN0QztZQUVBdEMsUUFBUXdCLE1BQU0sQ0FBQ2UsS0FBSyxDQUFDO2dCQUFFSjtnQkFBS1Q7WUFBSTtZQUNoQyxNQUFNUztRQUNSO0lBQ0Y7QUFDRiJ9
110
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXJlc3RyaWN0ZWQtc3ludGF4LCBuby1hd2FpdC1pbi1sb29wICovXG5pbXBvcnQgdHlwZSB7IFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBNaWdyYXRpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgeyBnZW5lcmF0ZURyaXp6bGVKc29uIH0gZnJvbSAnZHJpenpsZS1raXQvdXRpbHMnXG5pbXBvcnQgeyByZWFkTWlncmF0aW9uRmlsZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgRGF0YWJhc2VFcnJvciB9IGZyb20gJ3BnJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBjcmVhdGVNaWdyYXRpb25UYWJsZSB9IGZyb20gJy4vdXRpbGl0aWVzL2NyZWF0ZU1pZ3JhdGlvblRhYmxlJ1xuaW1wb3J0IHsgbWlncmF0aW9uVGFibGVFeGlzdHMgfSBmcm9tICcuL3V0aWxpdGllcy9taWdyYXRpb25UYWJsZUV4aXN0cydcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGUodGhpczogUG9zdGdyZXNBZGFwdGVyKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHsgcGF5bG9hZCB9ID0gdGhpc1xuICBjb25zdCBtaWdyYXRpb25GaWxlcyA9IGF3YWl0IHJlYWRNaWdyYXRpb25GaWxlcyh7IHBheWxvYWQgfSlcblxuICBpZiAoIW1pZ3JhdGlvbkZpbGVzLmxlbmd0aCkge1xuICAgIHBheWxvYWQubG9nZ2VyLmluZm8oeyBtc2c6ICdObyBtaWdyYXRpb25zIHRvIHJ1bi4nIH0pXG4gICAgcmV0dXJuXG4gIH1cblxuICBsZXQgbGF0ZXN0QmF0Y2ggPSAwXG4gIGxldCBtaWdyYXRpb25zSW5EQiA9IFtdXG5cbiAgY29uc3QgaGFzTWlncmF0aW9uVGFibGUgPSBhd2FpdCBtaWdyYXRpb25UYWJsZUV4aXN0cyh0aGlzLmRyaXp6bGUpXG5cbiAgaWYgKGhhc01pZ3JhdGlvblRhYmxlKSB7XG4gICAgOyh7IGRvY3M6IG1pZ3JhdGlvbnNJbkRCIH0gPSBhd2FpdCBwYXlsb2FkLmZpbmQoe1xuICAgICAgY29sbGVjdGlvbjogJ3BheWxvYWQtbWlncmF0aW9ucycsXG4gICAgICBsaW1pdDogMCxcbiAgICAgIHNvcnQ6ICctbmFtZScsXG4gICAgfSkpXG4gICAgaWYgKE51bWJlcihtaWdyYXRpb25zSW5EQj8uWzBdPy5iYXRjaCkgPiAwKSB7XG4gICAgICBsYXRlc3RCYXRjaCA9IE51bWJlcihtaWdyYXRpb25zSW5EQlswXT8uYmF0Y2gpXG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGF3YWl0IGNyZWF0ZU1pZ3JhdGlvblRhYmxlKHRoaXMuZHJpenpsZSlcbiAgfVxuXG4gIGlmIChtaWdyYXRpb25zSW5EQi5maW5kKChtKSA9PiBtLmJhdGNoID09PSAtMSkpIHtcbiAgICBjb25zdCB7IGNvbmZpcm06IHJ1bk1pZ3JhdGlvbnMgfSA9IGF3YWl0IHByb21wdHMoXG4gICAgICB7XG4gICAgICAgIG5hbWU6ICdjb25maXJtJyxcbiAgICAgICAgaW5pdGlhbDogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6XG4gICAgICAgICAgXCJJdCBsb29rcyBsaWtlIHlvdSd2ZSBydW4gUGF5bG9hZCBpbiBkZXYgbW9kZSwgbWVhbmluZyB5b3UndmUgZHluYW1pY2FsbHkgcHVzaGVkIGNoYW5nZXMgdG8geW91ciBkYXRhYmFzZS4gXCIgK1xuICAgICAgICAgIFwiSWYgeW91J2QgbGlrZSB0byBydW4gbWlncmF0aW9ucywgZGF0YSBsb3NzIHdpbGwgb2NjdXIuIFdvdWxkIHlvdSBsaWtlIHRvIHByb2NlZWQ/XCIsXG4gICAgICAgIHR5cGU6ICdjb25maXJtJyxcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIG9uQ2FuY2VsOiAoKSA9PiB7XG4gICAgICAgICAgcHJvY2Vzcy5leGl0KDApXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIClcblxuICAgIGlmICghcnVuTWlncmF0aW9ucykge1xuICAgICAgcHJvY2Vzcy5leGl0KDApXG4gICAgfVxuICB9XG5cbiAgY29uc3QgbmV3QmF0Y2ggPSBsYXRlc3RCYXRjaCArIDFcblxuICAvLyBFeGVjdXRlICd1cCcgZnVuY3Rpb24gZm9yIGVhY2ggbWlncmF0aW9uIHNlcXVlbnRpYWxseVxuICBmb3IgKGNvbnN0IG1pZ3JhdGlvbiBvZiBtaWdyYXRpb25GaWxlcykge1xuICAgIGNvbnN0IGFscmVhZHlSYW4gPSBtaWdyYXRpb25zSW5EQi5maW5kKChleGlzdGluZykgPT4gZXhpc3RpbmcubmFtZSA9PT0gbWlncmF0aW9uLm5hbWUpXG5cbiAgICAvLyBJZiBhbHJlYWR5IHJhbiwgc2tpcFxuICAgIGlmIChhbHJlYWR5UmFuKSB7XG4gICAgICBjb250aW51ZSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWNvbnRpbnVlXG4gICAgfVxuXG4gICAgYXdhaXQgcnVuTWlncmF0aW9uRmlsZShwYXlsb2FkLCBtaWdyYXRpb24sIG5ld0JhdGNoKVxuICB9XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHJ1bk1pZ3JhdGlvbkZpbGUocGF5bG9hZDogUGF5bG9hZCwgbWlncmF0aW9uOiBNaWdyYXRpb24sIGJhdGNoOiBudW1iZXIpIHtcbiAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpXG5cbiAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGluZzogJHttaWdyYXRpb24ubmFtZX1gIH0pXG5cbiAgY29uc3QgcGdBZGFwdGVyID0gcGF5bG9hZC5kYlxuICBjb25zdCBkcml6emxlSlNPTiA9IGdlbmVyYXRlRHJpenpsZUpzb24ocGdBZGFwdGVyLnNjaGVtYSlcblxuICB0cnkge1xuICAgIGF3YWl0IG1pZ3JhdGlvbi51cCh7IHBheWxvYWQgfSlcbiAgICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0ZWQ6ICAke21pZ3JhdGlvbi5uYW1lfSAoJHtEYXRlLm5vdygpIC0gc3RhcnR9bXMpYCB9KVxuICAgIGF3YWl0IHBheWxvYWQuY3JlYXRlKHtcbiAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgZGF0YToge1xuICAgICAgICBuYW1lOiBtaWdyYXRpb24ubmFtZSxcbiAgICAgICAgYmF0Y2gsXG4gICAgICAgIHNjaGVtYTogZHJpenpsZUpTT04sXG4gICAgICB9LFxuICAgIH0pXG4gIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgIGxldCBtc2cgPSBgRXJyb3IgcnVubmluZyBtaWdyYXRpb24gJHttaWdyYXRpb24ubmFtZX1gXG5cbiAgICBpZiAoZXJyIGluc3RhbmNlb2YgRGF0YWJhc2VFcnJvcikge1xuICAgICAgbXNnICs9IGA6ICR7ZXJyLm1lc3NhZ2V9YFxuICAgICAgaWYgKGVyci5oaW50KSBtc2cgKz0gYC4gJHtlcnIuaGludH1gXG4gICAgfVxuXG4gICAgcGF5bG9hZC5sb2dnZXIuZXJyb3IoeyBlcnIsIG1zZyB9KVxuICAgIHRocm93IGVyclxuICB9XG59XG4iXSwibmFtZXMiOlsibWlncmF0ZSIsInBheWxvYWQiLCJtaWdyYXRpb25GaWxlcyIsInJlYWRNaWdyYXRpb25GaWxlcyIsImxlbmd0aCIsImxvZ2dlciIsImluZm8iLCJtc2ciLCJsYXRlc3RCYXRjaCIsIm1pZ3JhdGlvbnNJbkRCIiwiaGFzTWlncmF0aW9uVGFibGUiLCJtaWdyYXRpb25UYWJsZUV4aXN0cyIsImRyaXp6bGUiLCJkb2NzIiwiZmluZCIsImNvbGxlY3Rpb24iLCJsaW1pdCIsInNvcnQiLCJOdW1iZXIiLCJiYXRjaCIsImNyZWF0ZU1pZ3JhdGlvblRhYmxlIiwibSIsImNvbmZpcm0iLCJydW5NaWdyYXRpb25zIiwicHJvbXB0cyIsIm5hbWUiLCJpbml0aWFsIiwibWVzc2FnZSIsInR5cGUiLCJvbkNhbmNlbCIsInByb2Nlc3MiLCJleGl0IiwibmV3QmF0Y2giLCJtaWdyYXRpb24iLCJhbHJlYWR5UmFuIiwiZXhpc3RpbmciLCJydW5NaWdyYXRpb25GaWxlIiwic3RhcnQiLCJEYXRlIiwibm93IiwicGdBZGFwdGVyIiwiZGIiLCJkcml6emxlSlNPTiIsImdlbmVyYXRlRHJpenpsZUpzb24iLCJzY2hlbWEiLCJ1cCIsImNyZWF0ZSIsImRhdGEiLCJlcnIiLCJEYXRhYmFzZUVycm9yIiwiaGludCIsImVycm9yIl0sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7Ozs7K0JBY25DQTs7O2VBQUFBOzs7dUJBVmM7MEJBQ0Q7b0JBQ0w7Z0VBQ1Y7c0NBSWlCO3NDQUNBOzs7Ozs7QUFFOUIsZUFBZUE7SUFDcEIsTUFBTSxFQUFFQyxPQUFPLEVBQUUsR0FBRyxJQUFJO0lBQ3hCLE1BQU1DLGlCQUFpQixNQUFNQyxJQUFBQSw0QkFBa0IsRUFBQztRQUFFRjtJQUFRO0lBRTFELElBQUksQ0FBQ0MsZUFBZUUsTUFBTSxFQUFFO1FBQzFCSCxRQUFRSSxNQUFNLENBQUNDLElBQUksQ0FBQztZQUFFQyxLQUFLO1FBQXdCO1FBQ25EO0lBQ0Y7SUFFQSxJQUFJQyxjQUFjO0lBQ2xCLElBQUlDLGlCQUFpQixFQUFFO0lBRXZCLE1BQU1DLG9CQUFvQixNQUFNQyxJQUFBQSwwQ0FBb0IsRUFBQyxJQUFJLENBQUNDLE9BQU87SUFFakUsSUFBSUYsbUJBQW1CO1FBQ25CLENBQUEsRUFBRUcsTUFBTUosY0FBYyxFQUFFLEdBQUcsTUFBTVIsUUFBUWEsSUFBSSxDQUFDO1lBQzlDQyxZQUFZO1lBQ1pDLE9BQU87WUFDUEMsTUFBTTtRQUNSLEVBQUM7UUFDRCxJQUFJQyxPQUFPVCxnQkFBZ0IsQ0FBQyxFQUFFLEVBQUVVLFNBQVMsR0FBRztZQUMxQ1gsY0FBY1UsT0FBT1QsY0FBYyxDQUFDLEVBQUUsRUFBRVU7UUFDMUM7SUFDRixPQUFPO1FBQ0wsTUFBTUMsSUFBQUEsMENBQW9CLEVBQUMsSUFBSSxDQUFDUixPQUFPO0lBQ3pDO0lBRUEsSUFBSUgsZUFBZUssSUFBSSxDQUFDLENBQUNPLElBQU1BLEVBQUVGLEtBQUssS0FBSyxDQUFDLElBQUk7UUFDOUMsTUFBTSxFQUFFRyxTQUFTQyxhQUFhLEVBQUUsR0FBRyxNQUFNQyxJQUFBQSxnQkFBTyxFQUM5QztZQUNFQyxNQUFNO1lBQ05DLFNBQVM7WUFDVEMsU0FDRSwrR0FDQTtZQUNGQyxNQUFNO1FBQ1IsR0FDQTtZQUNFQyxVQUFVO2dCQUNSQyxRQUFRQyxJQUFJLENBQUM7WUFDZjtRQUNGO1FBR0YsSUFBSSxDQUFDUixlQUFlO1lBQ2xCTyxRQUFRQyxJQUFJLENBQUM7UUFDZjtJQUNGO0lBRUEsTUFBTUMsV0FBV3hCLGNBQWM7SUFFL0Isd0RBQXdEO0lBQ3hELEtBQUssTUFBTXlCLGFBQWEvQixlQUFnQjtRQUN0QyxNQUFNZ0MsYUFBYXpCLGVBQWVLLElBQUksQ0FBQyxDQUFDcUIsV0FBYUEsU0FBU1YsSUFBSSxLQUFLUSxVQUFVUixJQUFJO1FBRXJGLHVCQUF1QjtRQUN2QixJQUFJUyxZQUFZO1lBQ2QsVUFBUyxrQ0FBa0M7UUFDN0M7UUFFQSxNQUFNRSxpQkFBaUJuQyxTQUFTZ0MsV0FBV0Q7SUFDN0M7QUFDRjtBQUVBLGVBQWVJLGlCQUFpQm5DLE9BQWdCLEVBQUVnQyxTQUFvQixFQUFFZCxLQUFhO0lBQ25GLE1BQU1rQixRQUFRQyxLQUFLQyxHQUFHO0lBRXRCdEMsUUFBUUksTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFBRUMsS0FBSyxDQUFDLFdBQVcsRUFBRTBCLFVBQVVSLElBQUksQ0FBQyxDQUFDO0lBQUM7SUFFMUQsTUFBTWUsWUFBWXZDLFFBQVF3QyxFQUFFO0lBQzVCLE1BQU1DLGNBQWNDLElBQUFBLDBCQUFtQixFQUFDSCxVQUFVSSxNQUFNO0lBRXhELElBQUk7UUFDRixNQUFNWCxVQUFVWSxFQUFFLENBQUM7WUFBRTVDO1FBQVE7UUFDN0JBLFFBQVFJLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDO1lBQUVDLEtBQUssQ0FBQyxXQUFXLEVBQUUwQixVQUFVUixJQUFJLENBQUMsRUFBRSxFQUFFYSxLQUFLQyxHQUFHLEtBQUtGLE1BQU0sR0FBRyxDQUFDO1FBQUM7UUFDcEYsTUFBTXBDLFFBQVE2QyxNQUFNLENBQUM7WUFDbkIvQixZQUFZO1lBQ1pnQyxNQUFNO2dCQUNKdEIsTUFBTVEsVUFBVVIsSUFBSTtnQkFDcEJOO2dCQUNBeUIsUUFBUUY7WUFDVjtRQUNGO0lBQ0YsRUFBRSxPQUFPTSxLQUFjO1FBQ3JCLElBQUl6QyxNQUFNLENBQUMsd0JBQXdCLEVBQUUwQixVQUFVUixJQUFJLENBQUMsQ0FBQztRQUVyRCxJQUFJdUIsZUFBZUMsaUJBQWEsRUFBRTtZQUNoQzFDLE9BQU8sQ0FBQyxFQUFFLEVBQUV5QyxJQUFJckIsT0FBTyxDQUFDLENBQUM7WUFDekIsSUFBSXFCLElBQUlFLElBQUksRUFBRTNDLE9BQU8sQ0FBQyxFQUFFLEVBQUV5QyxJQUFJRSxJQUFJLENBQUMsQ0FBQztRQUN0QztRQUVBakQsUUFBUUksTUFBTSxDQUFDOEMsS0FBSyxDQUFDO1lBQUVIO1lBQUt6QztRQUFJO1FBQ2hDLE1BQU15QztJQUNSO0FBQ0YifQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-postgres",
3
- "version": "0.1.0-beta.11",
3
+ "version": "0.1.0-beta.13",
4
4
  "description": "The officially supported Postgres database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -25,7 +25,7 @@
25
25
  "@types/pg": "8.10.2",
26
26
  "@types/to-snake-case": "1.0.0",
27
27
  "@payloadcms/eslint-config": "0.0.1",
28
- "payload": "2.0.0-beta.13"
28
+ "payload": "2.0.0-beta.15"
29
29
  },
30
30
  "peerDependencies": {
31
31
  "better-sqlite3": "^8.5.0"