@payloadcms/db-postgres 0.1.0-beta.11 → 0.1.0-beta.12
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/connect.d.ts.map +1 -1
- package/dist/connect.js +8 -2
- package/dist/migrate.d.ts.map +1 -1
- package/dist/migrate.js +61 -37
- package/package.json +1 -1
package/dist/connect.d.ts.map
CHANGED
@@ -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,
|
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,
|
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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"}
|
package/dist/migrate.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../src/migrate.ts"],"names":[],"mappings":"
|
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,CAyDlE"}
|
package/dist/migrate.js
CHANGED
@@ -11,70 +11,94 @@ 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
|
});
|
21
27
|
let latestBatch = 0;
|
22
|
-
let
|
28
|
+
let migrationsInDB = [];
|
23
29
|
const hasMigrationTable = await (0, _migrationTableExists.migrationTableExists)(this.drizzle);
|
24
30
|
if (hasMigrationTable) {
|
25
|
-
({ docs:
|
31
|
+
({ docs: migrationsInDB } = await payload.find({
|
26
32
|
collection: 'payload-migrations',
|
27
33
|
limit: 0,
|
28
34
|
sort: '-name'
|
29
35
|
}));
|
30
|
-
if (Number(
|
31
|
-
latestBatch = Number(
|
36
|
+
if (Number(migrationsInDB?.[0]?.batch) > 0) {
|
37
|
+
latestBatch = Number(migrationsInDB[0]?.batch);
|
32
38
|
}
|
33
39
|
} else {
|
34
40
|
await (0, _createMigrationTable.createMigrationTable)(this.drizzle);
|
35
41
|
}
|
42
|
+
if (migrationsInDB.find((m)=>m.batch === -1)) {
|
43
|
+
const { confirm: runMigrations } = await (0, _prompts.default)({
|
44
|
+
name: 'confirm',
|
45
|
+
initial: false,
|
46
|
+
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?",
|
47
|
+
type: 'confirm'
|
48
|
+
}, {
|
49
|
+
onCancel: ()=>{
|
50
|
+
process.exit(0);
|
51
|
+
}
|
52
|
+
});
|
53
|
+
if (!runMigrations) {
|
54
|
+
process.exit(0);
|
55
|
+
}
|
56
|
+
}
|
36
57
|
const newBatch = latestBatch + 1;
|
37
58
|
// Execute 'up' function for each migration sequentially
|
38
59
|
for (const migration of migrationFiles){
|
39
|
-
const
|
40
|
-
//
|
41
|
-
if (
|
60
|
+
const alreadyRan = migrationsInDB.find((existing)=>existing.name === migration.name);
|
61
|
+
// If already ran, skip
|
62
|
+
if (alreadyRan) {
|
42
63
|
continue; // eslint-disable-line no-continue
|
43
64
|
}
|
44
|
-
|
65
|
+
await runMigrationFile(payload, migration, newBatch);
|
66
|
+
}
|
67
|
+
}
|
68
|
+
async function runMigrationFile(payload, migration, batch) {
|
69
|
+
const start = Date.now();
|
70
|
+
payload.logger.info({
|
71
|
+
msg: `Migrating: ${migration.name}`
|
72
|
+
});
|
73
|
+
const pgAdapter = payload.db;
|
74
|
+
const drizzleJSON = (0, _utils.generateDrizzleJson)(pgAdapter.schema);
|
75
|
+
try {
|
76
|
+
await migration.up({
|
77
|
+
payload
|
78
|
+
});
|
45
79
|
payload.logger.info({
|
46
|
-
msg: `
|
80
|
+
msg: `Migrated: ${migration.name} (${Date.now() - start}ms)`
|
47
81
|
});
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
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}`;
|
82
|
+
await payload.create({
|
83
|
+
collection: 'payload-migrations',
|
84
|
+
data: {
|
85
|
+
name: migration.name,
|
86
|
+
batch,
|
87
|
+
schema: drizzleJSON
|
70
88
|
}
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
89
|
+
});
|
90
|
+
} catch (err) {
|
91
|
+
let msg = `Error running migration ${migration.name}`;
|
92
|
+
if (err instanceof _pg.DatabaseError) {
|
93
|
+
msg += `: ${err.message}`;
|
94
|
+
if (err.hint) msg += `. ${err.hint}`;
|
76
95
|
}
|
96
|
+
payload.logger.error({
|
97
|
+
err,
|
98
|
+
msg
|
99
|
+
});
|
100
|
+
throw err;
|
77
101
|
}
|
78
102
|
}
|
79
103
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIG5vLXJlc3RyaWN0ZWQtc3ludGF4LCBuby1hd2FpdC1pbi1sb29wICovXG5pbXBvcnQgdHlwZSB7IFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBNaWdyYXRpb24gfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuXG5pbXBvcnQgeyBnZW5lcmF0ZURyaXp6bGVKc29uIH0gZnJvbSAnZHJpenpsZS1raXQvdXRpbHMnXG5pbXBvcnQgeyByZWFkTWlncmF0aW9uRmlsZXMgfSBmcm9tICdwYXlsb2FkL2RhdGFiYXNlJ1xuaW1wb3J0IHsgRGF0YWJhc2VFcnJvciB9IGZyb20gJ3BnJ1xuaW1wb3J0IHByb21wdHMgZnJvbSAncHJvbXB0cydcblxuaW1wb3J0IHR5cGUgeyBQb3N0Z3Jlc0FkYXB0ZXIgfSBmcm9tICcuL3R5cGVzJ1xuXG5pbXBvcnQgeyBjcmVhdGVNaWdyYXRpb25UYWJsZSB9IGZyb20gJy4vdXRpbGl0aWVzL2NyZWF0ZU1pZ3JhdGlvblRhYmxlJ1xuaW1wb3J0IHsgbWlncmF0aW9uVGFibGVFeGlzdHMgfSBmcm9tICcuL3V0aWxpdGllcy9taWdyYXRpb25UYWJsZUV4aXN0cydcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1pZ3JhdGUodGhpczogUG9zdGdyZXNBZGFwdGVyKTogUHJvbWlzZTx2b2lkPiB7XG4gIGNvbnN0IHsgcGF5bG9hZCB9ID0gdGhpc1xuICBjb25zdCBtaWdyYXRpb25GaWxlcyA9IGF3YWl0IHJlYWRNaWdyYXRpb25GaWxlcyh7IHBheWxvYWQgfSlcblxuICBsZXQgbGF0ZXN0QmF0Y2ggPSAwXG4gIGxldCBtaWdyYXRpb25zSW5EQiA9IFtdXG5cbiAgY29uc3QgaGFzTWlncmF0aW9uVGFibGUgPSBhd2FpdCBtaWdyYXRpb25UYWJsZUV4aXN0cyh0aGlzLmRyaXp6bGUpXG5cbiAgaWYgKGhhc01pZ3JhdGlvblRhYmxlKSB7XG4gICAgOyh7IGRvY3M6IG1pZ3JhdGlvbnNJbkRCIH0gPSBhd2FpdCBwYXlsb2FkLmZpbmQoe1xuICAgICAgY29sbGVjdGlvbjogJ3BheWxvYWQtbWlncmF0aW9ucycsXG4gICAgICBsaW1pdDogMCxcbiAgICAgIHNvcnQ6ICctbmFtZScsXG4gICAgfSkpXG4gICAgaWYgKE51bWJlcihtaWdyYXRpb25zSW5EQj8uWzBdPy5iYXRjaCkgPiAwKSB7XG4gICAgICBsYXRlc3RCYXRjaCA9IE51bWJlcihtaWdyYXRpb25zSW5EQlswXT8uYmF0Y2gpXG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGF3YWl0IGNyZWF0ZU1pZ3JhdGlvblRhYmxlKHRoaXMuZHJpenpsZSlcbiAgfVxuXG4gIGlmIChtaWdyYXRpb25zSW5EQi5maW5kKChtKSA9PiBtLmJhdGNoID09PSAtMSkpIHtcbiAgICBjb25zdCB7IGNvbmZpcm06IHJ1bk1pZ3JhdGlvbnMgfSA9IGF3YWl0IHByb21wdHMoXG4gICAgICB7XG4gICAgICAgIG5hbWU6ICdjb25maXJtJyxcbiAgICAgICAgaW5pdGlhbDogZmFsc2UsXG4gICAgICAgIG1lc3NhZ2U6XG4gICAgICAgICAgXCJJdCBsb29rcyBsaWtlIHlvdSd2ZSBydW4gUGF5bG9hZCBpbiBkZXYgbW9kZSwgbWVhbmluZyB5b3UndmUgZHluYW1pY2FsbHkgcHVzaGVkIGNoYW5nZXMgdG8geW91ciBkYXRhYmFzZS4gXCIgK1xuICAgICAgICAgIFwiSWYgeW91J2QgbGlrZSB0byBydW4gbWlncmF0aW9ucywgZGF0YSBsb3NzIHdpbGwgb2NjdXIuIFdvdWxkIHlvdSBsaWtlIHRvIHByb2NlZWQ/XCIsXG4gICAgICAgIHR5cGU6ICdjb25maXJtJyxcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIG9uQ2FuY2VsOiAoKSA9PiB7XG4gICAgICAgICAgcHJvY2Vzcy5leGl0KDApXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIClcblxuICAgIGlmICghcnVuTWlncmF0aW9ucykge1xuICAgICAgcHJvY2Vzcy5leGl0KDApXG4gICAgfVxuICB9XG5cbiAgY29uc3QgbmV3QmF0Y2ggPSBsYXRlc3RCYXRjaCArIDFcblxuICAvLyBFeGVjdXRlICd1cCcgZnVuY3Rpb24gZm9yIGVhY2ggbWlncmF0aW9uIHNlcXVlbnRpYWxseVxuICBmb3IgKGNvbnN0IG1pZ3JhdGlvbiBvZiBtaWdyYXRpb25GaWxlcykge1xuICAgIGNvbnN0IGFscmVhZHlSYW4gPSBtaWdyYXRpb25zSW5EQi5maW5kKChleGlzdGluZykgPT4gZXhpc3RpbmcubmFtZSA9PT0gbWlncmF0aW9uLm5hbWUpXG5cbiAgICAvLyBJZiBhbHJlYWR5IHJhbiwgc2tpcFxuICAgIGlmIChhbHJlYWR5UmFuKSB7XG4gICAgICBjb250aW51ZSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWNvbnRpbnVlXG4gICAgfVxuXG4gICAgYXdhaXQgcnVuTWlncmF0aW9uRmlsZShwYXlsb2FkLCBtaWdyYXRpb24sIG5ld0JhdGNoKVxuICB9XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHJ1bk1pZ3JhdGlvbkZpbGUocGF5bG9hZDogUGF5bG9hZCwgbWlncmF0aW9uOiBNaWdyYXRpb24sIGJhdGNoOiBudW1iZXIpIHtcbiAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpXG5cbiAgcGF5bG9hZC5sb2dnZXIuaW5mbyh7IG1zZzogYE1pZ3JhdGluZzogJHttaWdyYXRpb24ubmFtZX1gIH0pXG5cbiAgY29uc3QgcGdBZGFwdGVyID0gcGF5bG9hZC5kYlxuICBjb25zdCBkcml6emxlSlNPTiA9IGdlbmVyYXRlRHJpenpsZUpzb24ocGdBZGFwdGVyLnNjaGVtYSlcblxuICB0cnkge1xuICAgIGF3YWl0IG1pZ3JhdGlvbi51cCh7IHBheWxvYWQgfSlcbiAgICBwYXlsb2FkLmxvZ2dlci5pbmZvKHsgbXNnOiBgTWlncmF0ZWQ6ICAke21pZ3JhdGlvbi5uYW1lfSAoJHtEYXRlLm5vdygpIC0gc3RhcnR9bXMpYCB9KVxuICAgIGF3YWl0IHBheWxvYWQuY3JlYXRlKHtcbiAgICAgIGNvbGxlY3Rpb246ICdwYXlsb2FkLW1pZ3JhdGlvbnMnLFxuICAgICAgZGF0YToge1xuICAgICAgICBuYW1lOiBtaWdyYXRpb24ubmFtZSxcbiAgICAgICAgYmF0Y2gsXG4gICAgICAgIHNjaGVtYTogZHJpenpsZUpTT04sXG4gICAgICB9LFxuICAgIH0pXG4gIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgIGxldCBtc2cgPSBgRXJyb3IgcnVubmluZyBtaWdyYXRpb24gJHttaWdyYXRpb24ubmFtZX1gXG5cbiAgICBpZiAoZXJyIGluc3RhbmNlb2YgRGF0YWJhc2VFcnJvcikge1xuICAgICAgbXNnICs9IGA6ICR7ZXJyLm1lc3NhZ2V9YFxuICAgICAgaWYgKGVyci5oaW50KSBtc2cgKz0gYC4gJHtlcnIuaGludH1gXG4gICAgfVxuXG4gICAgcGF5bG9hZC5sb2dnZXIuZXJyb3IoeyBlcnIsIG1zZyB9KVxuICAgIHRocm93IGVyclxuICB9XG59XG4iXSwibmFtZXMiOlsibWlncmF0ZSIsInBheWxvYWQiLCJtaWdyYXRpb25GaWxlcyIsInJlYWRNaWdyYXRpb25GaWxlcyIsImxhdGVzdEJhdGNoIiwibWlncmF0aW9uc0luREIiLCJoYXNNaWdyYXRpb25UYWJsZSIsIm1pZ3JhdGlvblRhYmxlRXhpc3RzIiwiZHJpenpsZSIsImRvY3MiLCJmaW5kIiwiY29sbGVjdGlvbiIsImxpbWl0Iiwic29ydCIsIk51bWJlciIsImJhdGNoIiwiY3JlYXRlTWlncmF0aW9uVGFibGUiLCJtIiwiY29uZmlybSIsInJ1bk1pZ3JhdGlvbnMiLCJwcm9tcHRzIiwibmFtZSIsImluaXRpYWwiLCJtZXNzYWdlIiwidHlwZSIsIm9uQ2FuY2VsIiwicHJvY2VzcyIsImV4aXQiLCJuZXdCYXRjaCIsIm1pZ3JhdGlvbiIsImFscmVhZHlSYW4iLCJleGlzdGluZyIsInJ1bk1pZ3JhdGlvbkZpbGUiLCJzdGFydCIsIkRhdGUiLCJub3ciLCJsb2dnZXIiLCJpbmZvIiwibXNnIiwicGdBZGFwdGVyIiwiZGIiLCJkcml6emxlSlNPTiIsImdlbmVyYXRlRHJpenpsZUpzb24iLCJzY2hlbWEiLCJ1cCIsImNyZWF0ZSIsImRhdGEiLCJlcnIiLCJEYXRhYmFzZUVycm9yIiwiaGludCIsImVycm9yIl0sIm1hcHBpbmdzIjoiQUFBQSx5REFBeUQ7Ozs7K0JBY25DQTs7O2VBQUFBOzs7dUJBVmM7MEJBQ0Q7b0JBQ0w7Z0VBQ1Y7c0NBSWlCO3NDQUNBOzs7Ozs7QUFFOUIsZUFBZUE7SUFDcEIsTUFBTSxFQUFFQyxPQUFPLEVBQUUsR0FBRyxJQUFJO0lBQ3hCLE1BQU1DLGlCQUFpQixNQUFNQyxJQUFBQSw0QkFBa0IsRUFBQztRQUFFRjtJQUFRO0lBRTFELElBQUlHLGNBQWM7SUFDbEIsSUFBSUMsaUJBQWlCLEVBQUU7SUFFdkIsTUFBTUMsb0JBQW9CLE1BQU1DLElBQUFBLDBDQUFvQixFQUFDLElBQUksQ0FBQ0MsT0FBTztJQUVqRSxJQUFJRixtQkFBbUI7UUFDbkIsQ0FBQSxFQUFFRyxNQUFNSixjQUFjLEVBQUUsR0FBRyxNQUFNSixRQUFRUyxJQUFJLENBQUM7WUFDOUNDLFlBQVk7WUFDWkMsT0FBTztZQUNQQyxNQUFNO1FBQ1IsRUFBQztRQUNELElBQUlDLE9BQU9ULGdCQUFnQixDQUFDLEVBQUUsRUFBRVUsU0FBUyxHQUFHO1lBQzFDWCxjQUFjVSxPQUFPVCxjQUFjLENBQUMsRUFBRSxFQUFFVTtRQUMxQztJQUNGLE9BQU87UUFDTCxNQUFNQyxJQUFBQSwwQ0FBb0IsRUFBQyxJQUFJLENBQUNSLE9BQU87SUFDekM7SUFFQSxJQUFJSCxlQUFlSyxJQUFJLENBQUMsQ0FBQ08sSUFBTUEsRUFBRUYsS0FBSyxLQUFLLENBQUMsSUFBSTtRQUM5QyxNQUFNLEVBQUVHLFNBQVNDLGFBQWEsRUFBRSxHQUFHLE1BQU1DLElBQUFBLGdCQUFPLEVBQzlDO1lBQ0VDLE1BQU07WUFDTkMsU0FBUztZQUNUQyxTQUNFLCtHQUNBO1lBQ0ZDLE1BQU07UUFDUixHQUNBO1lBQ0VDLFVBQVU7Z0JBQ1JDLFFBQVFDLElBQUksQ0FBQztZQUNmO1FBQ0Y7UUFHRixJQUFJLENBQUNSLGVBQWU7WUFDbEJPLFFBQVFDLElBQUksQ0FBQztRQUNmO0lBQ0Y7SUFFQSxNQUFNQyxXQUFXeEIsY0FBYztJQUUvQix3REFBd0Q7SUFDeEQsS0FBSyxNQUFNeUIsYUFBYTNCLGVBQWdCO1FBQ3RDLE1BQU00QixhQUFhekIsZUFBZUssSUFBSSxDQUFDLENBQUNxQixXQUFhQSxTQUFTVixJQUFJLEtBQUtRLFVBQVVSLElBQUk7UUFFckYsdUJBQXVCO1FBQ3ZCLElBQUlTLFlBQVk7WUFDZCxVQUFTLGtDQUFrQztRQUM3QztRQUVBLE1BQU1FLGlCQUFpQi9CLFNBQVM0QixXQUFXRDtJQUM3QztBQUNGO0FBRUEsZUFBZUksaUJBQWlCL0IsT0FBZ0IsRUFBRTRCLFNBQW9CLEVBQUVkLEtBQWE7SUFDbkYsTUFBTWtCLFFBQVFDLEtBQUtDLEdBQUc7SUFFdEJsQyxRQUFRbUMsTUFBTSxDQUFDQyxJQUFJLENBQUM7UUFBRUMsS0FBSyxDQUFDLFdBQVcsRUFBRVQsVUFBVVIsSUFBSSxDQUFDLENBQUM7SUFBQztJQUUxRCxNQUFNa0IsWUFBWXRDLFFBQVF1QyxFQUFFO0lBQzVCLE1BQU1DLGNBQWNDLElBQUFBLDBCQUFtQixFQUFDSCxVQUFVSSxNQUFNO0lBRXhELElBQUk7UUFDRixNQUFNZCxVQUFVZSxFQUFFLENBQUM7WUFBRTNDO1FBQVE7UUFDN0JBLFFBQVFtQyxNQUFNLENBQUNDLElBQUksQ0FBQztZQUFFQyxLQUFLLENBQUMsV0FBVyxFQUFFVCxVQUFVUixJQUFJLENBQUMsRUFBRSxFQUFFYSxLQUFLQyxHQUFHLEtBQUtGLE1BQU0sR0FBRyxDQUFDO1FBQUM7UUFDcEYsTUFBTWhDLFFBQVE0QyxNQUFNLENBQUM7WUFDbkJsQyxZQUFZO1lBQ1ptQyxNQUFNO2dCQUNKekIsTUFBTVEsVUFBVVIsSUFBSTtnQkFDcEJOO2dCQUNBNEIsUUFBUUY7WUFDVjtRQUNGO0lBQ0YsRUFBRSxPQUFPTSxLQUFjO1FBQ3JCLElBQUlULE1BQU0sQ0FBQyx3QkFBd0IsRUFBRVQsVUFBVVIsSUFBSSxDQUFDLENBQUM7UUFFckQsSUFBSTBCLGVBQWVDLGlCQUFhLEVBQUU7WUFDaENWLE9BQU8sQ0FBQyxFQUFFLEVBQUVTLElBQUl4QixPQUFPLENBQUMsQ0FBQztZQUN6QixJQUFJd0IsSUFBSUUsSUFBSSxFQUFFWCxPQUFPLENBQUMsRUFBRSxFQUFFUyxJQUFJRSxJQUFJLENBQUMsQ0FBQztRQUN0QztRQUVBaEQsUUFBUW1DLE1BQU0sQ0FBQ2MsS0FBSyxDQUFDO1lBQUVIO1lBQUtUO1FBQUk7UUFDaEMsTUFBTVM7SUFDUjtBQUNGIn0=
|
package/package.json
CHANGED