@pristine-ts/mysql-cli 2.0.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/dist/lib/cjs/commands/commands.js +25 -0
- package/dist/lib/cjs/commands/commands.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-create.command-options.js +37 -0
- package/dist/lib/cjs/commands/mysql-migrate-create.command-options.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-create.command.js +120 -0
- package/dist/lib/cjs/commands/mysql-migrate-create.command.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-status.command-options.js +27 -0
- package/dist/lib/cjs/commands/mysql-migrate-status.command-options.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-status.command.js +104 -0
- package/dist/lib/cjs/commands/mysql-migrate-status.command.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-verify.command-options.js +27 -0
- package/dist/lib/cjs/commands/mysql-migrate-verify.command-options.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate-verify.command.js +74 -0
- package/dist/lib/cjs/commands/mysql-migrate-verify.command.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate.command-options.js +41 -0
- package/dist/lib/cjs/commands/mysql-migrate.command-options.js.map +1 -0
- package/dist/lib/cjs/commands/mysql-migrate.command.js +86 -0
- package/dist/lib/cjs/commands/mysql-migrate.command.js.map +1 -0
- package/dist/lib/cjs/enums/enums.js +18 -0
- package/dist/lib/cjs/enums/enums.js.map +1 -0
- package/dist/lib/cjs/enums/migration-state.enum.js +28 -0
- package/dist/lib/cjs/enums/migration-state.enum.js.map +1 -0
- package/dist/lib/cjs/errors/errors.js +22 -0
- package/dist/lib/cjs/errors/errors.js.map +1 -0
- package/dist/lib/cjs/errors/migration-checksum-mismatch.error.js +24 -0
- package/dist/lib/cjs/errors/migration-checksum-mismatch.error.js.map +1 -0
- package/dist/lib/cjs/errors/migration-duplicate-name.error.js +21 -0
- package/dist/lib/cjs/errors/migration-duplicate-name.error.js.map +1 -0
- package/dist/lib/cjs/errors/migration-execution.error.js +21 -0
- package/dist/lib/cjs/errors/migration-execution.error.js.map +1 -0
- package/dist/lib/cjs/errors/migration-invalid-name.error.js +20 -0
- package/dist/lib/cjs/errors/migration-invalid-name.error.js.map +1 -0
- package/dist/lib/cjs/errors/migration-orphaned-record.error.js +22 -0
- package/dist/lib/cjs/errors/migration-orphaned-record.error.js.map +1 -0
- package/dist/lib/cjs/interfaces/interfaces.js +18 -0
- package/dist/lib/cjs/interfaces/interfaces.js.map +1 -0
- package/dist/lib/cjs/interfaces/mysql-migration.interface.js +3 -0
- package/dist/lib/cjs/interfaces/mysql-migration.interface.js.map +1 -0
- package/dist/lib/cjs/managers/managers.js +22 -0
- package/dist/lib/cjs/managers/managers.js.map +1 -0
- package/dist/lib/cjs/managers/mysql-migration-checksum.manager.js +35 -0
- package/dist/lib/cjs/managers/mysql-migration-checksum.manager.js.map +1 -0
- package/dist/lib/cjs/managers/mysql-migration-record.manager.js +96 -0
- package/dist/lib/cjs/managers/mysql-migration-record.manager.js.map +1 -0
- package/dist/lib/cjs/managers/mysql-migration-runner.manager.js +96 -0
- package/dist/lib/cjs/managers/mysql-migration-runner.manager.js.map +1 -0
- package/dist/lib/cjs/managers/mysql-migration-scaffold.manager.js +217 -0
- package/dist/lib/cjs/managers/mysql-migration-scaffold.manager.js.map +1 -0
- package/dist/lib/cjs/managers/mysql-migration.manager.js +261 -0
- package/dist/lib/cjs/managers/mysql-migration.manager.js.map +1 -0
- package/dist/lib/cjs/models/migration-apply-entry.model.js +11 -0
- package/dist/lib/cjs/models/migration-apply-entry.model.js.map +1 -0
- package/dist/lib/cjs/models/migration-apply-result.model.js +18 -0
- package/dist/lib/cjs/models/migration-apply-result.model.js.map +1 -0
- package/dist/lib/cjs/models/migration-plan-entry.model.js +11 -0
- package/dist/lib/cjs/models/migration-plan-entry.model.js.map +1 -0
- package/dist/lib/cjs/models/migration-plan.model.js +24 -0
- package/dist/lib/cjs/models/migration-plan.model.js.map +1 -0
- package/dist/lib/cjs/models/migration-record.model.js +12 -0
- package/dist/lib/cjs/models/migration-record.model.js.map +1 -0
- package/dist/lib/cjs/models/models.js +22 -0
- package/dist/lib/cjs/models/models.js.map +1 -0
- package/dist/lib/cjs/mysql-cli.configuration-keys.js +20 -0
- package/dist/lib/cjs/mysql-cli.configuration-keys.js.map +1 -0
- package/dist/lib/cjs/mysql-cli.module.js +63 -0
- package/dist/lib/cjs/mysql-cli.module.js.map +1 -0
- package/dist/lib/cjs/mysql-cli.module.keyname.js +5 -0
- package/dist/lib/cjs/mysql-cli.module.keyname.js.map +1 -0
- package/dist/lib/cjs/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/lib/esm/commands/commands.js +9 -0
- package/dist/lib/esm/commands/commands.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-create.command-options.js +33 -0
- package/dist/lib/esm/commands/mysql-migrate-create.command-options.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-create.command.js +114 -0
- package/dist/lib/esm/commands/mysql-migrate-create.command.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-status.command-options.js +23 -0
- package/dist/lib/esm/commands/mysql-migrate-status.command-options.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-status.command.js +101 -0
- package/dist/lib/esm/commands/mysql-migrate-status.command.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-verify.command-options.js +23 -0
- package/dist/lib/esm/commands/mysql-migrate-verify.command-options.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate-verify.command.js +71 -0
- package/dist/lib/esm/commands/mysql-migrate-verify.command.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate.command-options.js +37 -0
- package/dist/lib/esm/commands/mysql-migrate.command-options.js.map +1 -0
- package/dist/lib/esm/commands/mysql-migrate.command.js +83 -0
- package/dist/lib/esm/commands/mysql-migrate.command.js.map +1 -0
- package/dist/lib/esm/enums/enums.js +2 -0
- package/dist/lib/esm/enums/enums.js.map +1 -0
- package/dist/lib/esm/enums/migration-state.enum.js +25 -0
- package/dist/lib/esm/enums/migration-state.enum.js.map +1 -0
- package/dist/lib/esm/errors/errors.js +6 -0
- package/dist/lib/esm/errors/errors.js.map +1 -0
- package/dist/lib/esm/errors/migration-checksum-mismatch.error.js +20 -0
- package/dist/lib/esm/errors/migration-checksum-mismatch.error.js.map +1 -0
- package/dist/lib/esm/errors/migration-duplicate-name.error.js +17 -0
- package/dist/lib/esm/errors/migration-duplicate-name.error.js.map +1 -0
- package/dist/lib/esm/errors/migration-execution.error.js +17 -0
- package/dist/lib/esm/errors/migration-execution.error.js.map +1 -0
- package/dist/lib/esm/errors/migration-invalid-name.error.js +16 -0
- package/dist/lib/esm/errors/migration-invalid-name.error.js.map +1 -0
- package/dist/lib/esm/errors/migration-orphaned-record.error.js +18 -0
- package/dist/lib/esm/errors/migration-orphaned-record.error.js.map +1 -0
- package/dist/lib/esm/interfaces/interfaces.js +2 -0
- package/dist/lib/esm/interfaces/interfaces.js.map +1 -0
- package/dist/lib/esm/interfaces/mysql-migration.interface.js +2 -0
- package/dist/lib/esm/interfaces/mysql-migration.interface.js.map +1 -0
- package/dist/lib/esm/managers/managers.js +6 -0
- package/dist/lib/esm/managers/managers.js.map +1 -0
- package/dist/lib/esm/managers/mysql-migration-checksum.manager.js +32 -0
- package/dist/lib/esm/managers/mysql-migration-checksum.manager.js.map +1 -0
- package/dist/lib/esm/managers/mysql-migration-record.manager.js +93 -0
- package/dist/lib/esm/managers/mysql-migration-record.manager.js.map +1 -0
- package/dist/lib/esm/managers/mysql-migration-runner.manager.js +93 -0
- package/dist/lib/esm/managers/mysql-migration-runner.manager.js.map +1 -0
- package/dist/lib/esm/managers/mysql-migration-scaffold.manager.js +211 -0
- package/dist/lib/esm/managers/mysql-migration-scaffold.manager.js.map +1 -0
- package/dist/lib/esm/managers/mysql-migration.manager.js +258 -0
- package/dist/lib/esm/managers/mysql-migration.manager.js.map +1 -0
- package/dist/lib/esm/models/migration-apply-entry.model.js +7 -0
- package/dist/lib/esm/models/migration-apply-entry.model.js.map +1 -0
- package/dist/lib/esm/models/migration-apply-result.model.js +14 -0
- package/dist/lib/esm/models/migration-apply-result.model.js.map +1 -0
- package/dist/lib/esm/models/migration-plan-entry.model.js +7 -0
- package/dist/lib/esm/models/migration-plan-entry.model.js.map +1 -0
- package/dist/lib/esm/models/migration-plan.model.js +20 -0
- package/dist/lib/esm/models/migration-plan.model.js.map +1 -0
- package/dist/lib/esm/models/migration-record.model.js +8 -0
- package/dist/lib/esm/models/migration-record.model.js.map +1 -0
- package/dist/lib/esm/models/models.js +6 -0
- package/dist/lib/esm/models/models.js.map +1 -0
- package/dist/lib/esm/mysql-cli.configuration-keys.js +17 -0
- package/dist/lib/esm/mysql-cli.configuration-keys.js.map +1 -0
- package/dist/lib/esm/mysql-cli.module.js +46 -0
- package/dist/lib/esm/mysql-cli.module.js.map +1 -0
- package/dist/lib/esm/mysql-cli.module.keyname.js +2 -0
- package/dist/lib/esm/mysql-cli.module.keyname.js.map +1 -0
- package/dist/lib/esm/tsconfig.tsbuildinfo +1 -0
- package/dist/types/commands/commands.d.ts +8 -0
- package/dist/types/commands/mysql-migrate-create.command-options.d.ts +12 -0
- package/dist/types/commands/mysql-migrate-create.command.d.ts +32 -0
- package/dist/types/commands/mysql-migrate-status.command-options.d.ts +8 -0
- package/dist/types/commands/mysql-migrate-status.command.d.ts +25 -0
- package/dist/types/commands/mysql-migrate-verify.command-options.d.ts +8 -0
- package/dist/types/commands/mysql-migrate-verify.command.d.ts +23 -0
- package/dist/types/commands/mysql-migrate.command-options.d.ts +14 -0
- package/dist/types/commands/mysql-migrate.command.d.ts +23 -0
- package/dist/types/enums/enums.d.ts +1 -0
- package/dist/types/enums/migration-state.enum.d.ts +23 -0
- package/dist/types/errors/errors.d.ts +5 -0
- package/dist/types/errors/migration-checksum-mismatch.error.d.ts +14 -0
- package/dist/types/errors/migration-duplicate-name.error.d.ts +11 -0
- package/dist/types/errors/migration-execution.error.d.ts +12 -0
- package/dist/types/errors/migration-invalid-name.error.d.ts +10 -0
- package/dist/types/errors/migration-orphaned-record.error.d.ts +12 -0
- package/dist/types/interfaces/interfaces.d.ts +1 -0
- package/dist/types/interfaces/mysql-migration.interface.d.ts +40 -0
- package/dist/types/managers/managers.d.ts +5 -0
- package/dist/types/managers/mysql-migration-checksum.manager.d.ts +15 -0
- package/dist/types/managers/mysql-migration-record.manager.d.ts +22 -0
- package/dist/types/managers/mysql-migration-runner.manager.d.ts +16 -0
- package/dist/types/managers/mysql-migration-scaffold.manager.d.ts +40 -0
- package/dist/types/managers/mysql-migration.manager.d.ts +41 -0
- package/dist/types/models/migration-apply-entry.model.d.ts +9 -0
- package/dist/types/models/migration-apply-result.model.d.ts +14 -0
- package/dist/types/models/migration-plan-entry.model.d.ts +15 -0
- package/dist/types/models/migration-plan.model.d.ts +14 -0
- package/dist/types/models/migration-record.model.d.ts +12 -0
- package/dist/types/models/models.d.ts +5 -0
- package/dist/types/mysql-cli.configuration-keys.d.ts +29 -0
- package/dist/types/mysql-cli.module.d.ts +10 -0
- package/dist/types/mysql-cli.module.keyname.d.ts +1 -0
- package/package.json +75 -0
- package/readme.md +195 -0
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
14
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
15
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
16
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
17
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
18
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
19
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
var MysqlMigrationManager_1;
|
|
23
|
+
import { inject, injectable, injectAll } from "tsyringe";
|
|
24
|
+
import { traced } from "@pristine-ts/common";
|
|
25
|
+
import { MigrationStateEnum } from "../enums/migration-state.enum";
|
|
26
|
+
import { MigrationPlan } from "../models/migration-plan.model";
|
|
27
|
+
import { MigrationPlanEntry } from "../models/migration-plan-entry.model";
|
|
28
|
+
import { MigrationApplyResult } from "../models/migration-apply-result.model";
|
|
29
|
+
import { MigrationApplyEntry } from "../models/migration-apply-entry.model";
|
|
30
|
+
import { MysqlMigrationChecksumManager } from "./mysql-migration-checksum.manager";
|
|
31
|
+
import { MysqlMigrationRecordManager } from "./mysql-migration-record.manager";
|
|
32
|
+
import { MysqlMigrationRunner } from "./mysql-migration-runner.manager";
|
|
33
|
+
import { MigrationInvalidNameError } from "../errors/migration-invalid-name.error";
|
|
34
|
+
import { MigrationDuplicateNameError } from "../errors/migration-duplicate-name.error";
|
|
35
|
+
import { MigrationChecksumMismatchError } from "../errors/migration-checksum-mismatch.error";
|
|
36
|
+
import { MigrationOrphanedRecordError } from "../errors/migration-orphaned-record.error";
|
|
37
|
+
import { MigrationExecutionError } from "../errors/migration-execution.error";
|
|
38
|
+
/**
|
|
39
|
+
* Public orchestrator for migration operations. The CLI commands and any deploy-time
|
|
40
|
+
* runner should depend on this class — never on `MysqlMigrationRunner` /
|
|
41
|
+
* `MysqlMigrationRecordManager` directly.
|
|
42
|
+
*
|
|
43
|
+
* Discovery is DI-based: every migration registered with
|
|
44
|
+
* `@tag("MysqlMigrationInterface") @injectable()` and reachable through the AppModule's
|
|
45
|
+
* `importServices` graph is injected here via `@injectAll`. There is no filesystem
|
|
46
|
+
* scan at apply time, which means this works identically in a bundled Lambda and on
|
|
47
|
+
* a dev laptop.
|
|
48
|
+
*/
|
|
49
|
+
let MysqlMigrationManager = MysqlMigrationManager_1 = class MysqlMigrationManager {
|
|
50
|
+
constructor(registeredMigrations, mysqlConfigProviders, recordManager, runner, checksumManager, logHandler) {
|
|
51
|
+
this.registeredMigrations = registeredMigrations;
|
|
52
|
+
this.mysqlConfigProviders = mysqlConfigProviders;
|
|
53
|
+
this.recordManager = recordManager;
|
|
54
|
+
this.runner = runner;
|
|
55
|
+
this.checksumManager = checksumManager;
|
|
56
|
+
this.logHandler = logHandler;
|
|
57
|
+
}
|
|
58
|
+
status(configUniqueKeyname) {
|
|
59
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
+
const tableName = yield this.resolveTableName(configUniqueKeyname);
|
|
61
|
+
yield this.recordManager.ensureTable(configUniqueKeyname, tableName);
|
|
62
|
+
return this.buildPlan(configUniqueKeyname, tableName);
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
verify(configUniqueKeyname) {
|
|
66
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
+
const plan = yield this.status(configUniqueKeyname);
|
|
68
|
+
this.assertNoDrift(plan, configUniqueKeyname);
|
|
69
|
+
return plan;
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
apply(configUniqueKeyname, options) {
|
|
73
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
74
|
+
const dryRun = (options === null || options === void 0 ? void 0 : options.dryRun) === true;
|
|
75
|
+
const force = (options === null || options === void 0 ? void 0 : options.force) === true;
|
|
76
|
+
const tableName = yield this.resolveTableName(configUniqueKeyname);
|
|
77
|
+
yield this.recordManager.ensureTable(configUniqueKeyname, tableName);
|
|
78
|
+
const plan = yield this.buildPlan(configUniqueKeyname, tableName);
|
|
79
|
+
const result = new MigrationApplyResult();
|
|
80
|
+
result.configUniqueKeyname = configUniqueKeyname;
|
|
81
|
+
result.dryRun = dryRun;
|
|
82
|
+
if (force === false) {
|
|
83
|
+
this.assertNoDrift(plan, configUniqueKeyname);
|
|
84
|
+
}
|
|
85
|
+
else if (plan.hasDrift()) {
|
|
86
|
+
this.logHandler.warning("MysqlMigrationManager: proceeding past drift due to --force.", {
|
|
87
|
+
highlights: {
|
|
88
|
+
configUniqueKeyname,
|
|
89
|
+
modified: plan.countByState(MigrationStateEnum.Modified),
|
|
90
|
+
orphaned: plan.countByState(MigrationStateEnum.Orphaned),
|
|
91
|
+
},
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
const migrationsByName = new Map(this.selectMigrations(configUniqueKeyname).map((m) => [m.name, m]));
|
|
95
|
+
for (const entry of plan.entries) {
|
|
96
|
+
if (entry.state === MigrationStateEnum.Applied) {
|
|
97
|
+
result.skippedAlreadyApplied.push(entry.name);
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
if (entry.state !== MigrationStateEnum.Pending) {
|
|
101
|
+
// Modified or Orphaned — only reachable here under --force. Skip; the user is
|
|
102
|
+
// explicitly accepting the drift, but we won't re-run modified migrations or
|
|
103
|
+
// touch orphaned records.
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
106
|
+
const migration = migrationsByName.get(entry.name);
|
|
107
|
+
if (migration === undefined) {
|
|
108
|
+
// Defensive: a Pending entry by definition came from registeredMigrations.
|
|
109
|
+
continue;
|
|
110
|
+
}
|
|
111
|
+
const sql = yield migration.up();
|
|
112
|
+
const checksum = this.checksumManager.compute(sql);
|
|
113
|
+
const applyEntry = new MigrationApplyEntry();
|
|
114
|
+
applyEntry.name = entry.name;
|
|
115
|
+
try {
|
|
116
|
+
if (dryRun) {
|
|
117
|
+
applyEntry.executionTimeMs = 0;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
applyEntry.executionTimeMs = yield this.runner.execute(configUniqueKeyname, entry.name, sql);
|
|
121
|
+
yield this.recordManager.recordApplied(configUniqueKeyname, tableName, {
|
|
122
|
+
filename: entry.name,
|
|
123
|
+
checksum,
|
|
124
|
+
executionTimeMs: applyEntry.executionTimeMs,
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
result.appliedMigrations.push(applyEntry);
|
|
128
|
+
}
|
|
129
|
+
catch (error) {
|
|
130
|
+
applyEntry.executionTimeMs = 0;
|
|
131
|
+
applyEntry.error = error instanceof MigrationExecutionError ? error.message : error.message;
|
|
132
|
+
result.failedMigration = applyEntry;
|
|
133
|
+
return result;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
return result;
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
resolveConfig(configUniqueKeyname) {
|
|
140
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
141
|
+
const provider = this.mysqlConfigProviders.find((p) => p.supports(configUniqueKeyname));
|
|
142
|
+
if (provider === undefined) {
|
|
143
|
+
throw new Error(`No MysqlConfigProvider supports the unique keyname "${configUniqueKeyname}".`);
|
|
144
|
+
}
|
|
145
|
+
return provider.getMysqlConfig(configUniqueKeyname);
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
resolveTableName(configUniqueKeyname) {
|
|
149
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
150
|
+
var _a;
|
|
151
|
+
const config = yield this.resolveConfig(configUniqueKeyname);
|
|
152
|
+
return (_a = config.migrationsTableName) !== null && _a !== void 0 ? _a : MysqlMigrationManager_1.DefaultTableName;
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
selectMigrations(configUniqueKeyname) {
|
|
156
|
+
const filtered = this.registeredMigrations.filter((migration) => {
|
|
157
|
+
if (migration.configUniqueKeynames === undefined) {
|
|
158
|
+
return true;
|
|
159
|
+
}
|
|
160
|
+
return migration.configUniqueKeynames.includes(configUniqueKeyname);
|
|
161
|
+
});
|
|
162
|
+
const seen = new Set();
|
|
163
|
+
for (const migration of filtered) {
|
|
164
|
+
if (MysqlMigrationManager_1.ValidNamePattern.test(migration.name) === false) {
|
|
165
|
+
throw new MigrationInvalidNameError(migration.name);
|
|
166
|
+
}
|
|
167
|
+
if (seen.has(migration.name)) {
|
|
168
|
+
throw new MigrationDuplicateNameError(migration.name, configUniqueKeyname);
|
|
169
|
+
}
|
|
170
|
+
seen.add(migration.name);
|
|
171
|
+
}
|
|
172
|
+
return [...filtered].sort((a, b) => a.name.localeCompare(b.name));
|
|
173
|
+
}
|
|
174
|
+
buildPlan(configUniqueKeyname, tableName) {
|
|
175
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
176
|
+
const plan = new MigrationPlan();
|
|
177
|
+
plan.configUniqueKeyname = configUniqueKeyname;
|
|
178
|
+
plan.tableName = tableName;
|
|
179
|
+
const selected = this.selectMigrations(configUniqueKeyname);
|
|
180
|
+
const records = yield this.recordManager.listApplied(configUniqueKeyname, tableName);
|
|
181
|
+
const recordsByName = new Map(records.map((r) => [r.filename, r]));
|
|
182
|
+
const seenNames = new Set();
|
|
183
|
+
for (const migration of selected) {
|
|
184
|
+
const sql = yield migration.up();
|
|
185
|
+
const diskChecksum = this.checksumManager.compute(sql);
|
|
186
|
+
const record = recordsByName.get(migration.name);
|
|
187
|
+
const entry = new MigrationPlanEntry();
|
|
188
|
+
entry.name = migration.name;
|
|
189
|
+
entry.diskChecksum = diskChecksum;
|
|
190
|
+
if (record === undefined) {
|
|
191
|
+
entry.state = MigrationStateEnum.Pending;
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
entry.appliedChecksum = record.checksum;
|
|
195
|
+
entry.appliedAt = record.appliedAt;
|
|
196
|
+
entry.state = record.checksum === diskChecksum ? MigrationStateEnum.Applied : MigrationStateEnum.Modified;
|
|
197
|
+
}
|
|
198
|
+
plan.entries.push(entry);
|
|
199
|
+
seenNames.add(migration.name);
|
|
200
|
+
}
|
|
201
|
+
for (const record of records) {
|
|
202
|
+
if (seenNames.has(record.filename)) {
|
|
203
|
+
continue;
|
|
204
|
+
}
|
|
205
|
+
const entry = new MigrationPlanEntry();
|
|
206
|
+
entry.name = record.filename;
|
|
207
|
+
entry.state = MigrationStateEnum.Orphaned;
|
|
208
|
+
entry.appliedChecksum = record.checksum;
|
|
209
|
+
entry.appliedAt = record.appliedAt;
|
|
210
|
+
plan.entries.push(entry);
|
|
211
|
+
}
|
|
212
|
+
plan.entries.sort((a, b) => a.name.localeCompare(b.name));
|
|
213
|
+
return plan;
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
assertNoDrift(plan, configUniqueKeyname) {
|
|
217
|
+
var _a, _b;
|
|
218
|
+
for (const entry of plan.entries) {
|
|
219
|
+
if (entry.state === MigrationStateEnum.Modified) {
|
|
220
|
+
throw new MigrationChecksumMismatchError(entry.name, configUniqueKeyname, (_a = entry.diskChecksum) !== null && _a !== void 0 ? _a : "", (_b = entry.appliedChecksum) !== null && _b !== void 0 ? _b : "");
|
|
221
|
+
}
|
|
222
|
+
if (entry.state === MigrationStateEnum.Orphaned) {
|
|
223
|
+
throw new MigrationOrphanedRecordError(entry.name, configUniqueKeyname);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
};
|
|
228
|
+
MysqlMigrationManager.DefaultTableName = "pristine_migrations";
|
|
229
|
+
MysqlMigrationManager.ValidNamePattern = /^\d+-[a-z0-9-]+$/;
|
|
230
|
+
__decorate([
|
|
231
|
+
traced(),
|
|
232
|
+
__metadata("design:type", Function),
|
|
233
|
+
__metadata("design:paramtypes", [String]),
|
|
234
|
+
__metadata("design:returntype", Promise)
|
|
235
|
+
], MysqlMigrationManager.prototype, "status", null);
|
|
236
|
+
__decorate([
|
|
237
|
+
traced(),
|
|
238
|
+
__metadata("design:type", Function),
|
|
239
|
+
__metadata("design:paramtypes", [String]),
|
|
240
|
+
__metadata("design:returntype", Promise)
|
|
241
|
+
], MysqlMigrationManager.prototype, "verify", null);
|
|
242
|
+
__decorate([
|
|
243
|
+
traced(),
|
|
244
|
+
__metadata("design:type", Function),
|
|
245
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
246
|
+
__metadata("design:returntype", Promise)
|
|
247
|
+
], MysqlMigrationManager.prototype, "apply", null);
|
|
248
|
+
MysqlMigrationManager = MysqlMigrationManager_1 = __decorate([
|
|
249
|
+
injectable(),
|
|
250
|
+
__param(0, injectAll("MysqlMigrationInterface")),
|
|
251
|
+
__param(1, injectAll("MysqlConfigProviderInterface")),
|
|
252
|
+
__param(5, inject("LogHandlerInterface")),
|
|
253
|
+
__metadata("design:paramtypes", [Array, Array, MysqlMigrationRecordManager,
|
|
254
|
+
MysqlMigrationRunner,
|
|
255
|
+
MysqlMigrationChecksumManager, Object])
|
|
256
|
+
], MysqlMigrationManager);
|
|
257
|
+
export { MysqlMigrationManager };
|
|
258
|
+
//# sourceMappingURL=mysql-migration.manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql-migration.manager.js","sourceRoot":"","sources":["../../../../src/managers/mysql-migration.manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-apply-entry.model.js","sourceRoot":"","sources":["../../../../src/models/migration-apply-entry.model.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,OAAO,mBAAmB;CAI/B"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Output of `MysqlMigrationManager.apply`. `appliedMigrations` is the in-order list
|
|
3
|
+
* of migrations that ran successfully. `skippedAlreadyApplied` is the list of
|
|
4
|
+
* names that were already in the database (no-op). `failedMigration` is set when
|
|
5
|
+
* the run halted on a failure — subsequent pending migrations were not attempted.
|
|
6
|
+
*/
|
|
7
|
+
export class MigrationApplyResult {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.dryRun = false;
|
|
10
|
+
this.appliedMigrations = [];
|
|
11
|
+
this.skippedAlreadyApplied = [];
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=migration-apply-result.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-apply-result.model.js","sourceRoot":"","sources":["../../../../src/models/migration-apply-result.model.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,MAAM,OAAO,oBAAoB;IAAjC;QAES,WAAM,GAAY,KAAK,CAAC;QACxB,sBAAiB,GAA0B,EAAE,CAAC;QAC9C,0BAAqB,GAAa,EAAE,CAAC;IAE9C,CAAC;CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* One row of a `MigrationPlan`: the union view of a single migration as it appears
|
|
3
|
+
* to both the DI registry and the bookkeeping table. State combines the two views.
|
|
4
|
+
*/
|
|
5
|
+
export class MigrationPlanEntry {
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=migration-plan-entry.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-plan-entry.model.js","sourceRoot":"","sources":["../../../../src/models/migration-plan-entry.model.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,OAAO,kBAAkB;CAY9B"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { MigrationStateEnum } from "../enums/migration-state.enum";
|
|
2
|
+
/**
|
|
3
|
+
* Output of `MysqlMigrationManager.status` (and `verify` when no drift exists). The
|
|
4
|
+
* `entries` array is sorted lexicographically by `name`, matching apply order.
|
|
5
|
+
*/
|
|
6
|
+
export class MigrationPlan {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.entries = [];
|
|
9
|
+
}
|
|
10
|
+
hasPending() {
|
|
11
|
+
return this.entries.some((entry) => entry.state === MigrationStateEnum.Pending);
|
|
12
|
+
}
|
|
13
|
+
hasDrift() {
|
|
14
|
+
return this.entries.some((entry) => entry.state === MigrationStateEnum.Modified || entry.state === MigrationStateEnum.Orphaned);
|
|
15
|
+
}
|
|
16
|
+
countByState(state) {
|
|
17
|
+
return this.entries.filter((entry) => entry.state === state).length;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=migration-plan.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-plan.model.js","sourceRoot":"","sources":["../../../../src/models/migration-plan.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,kBAAkB,EAAC,MAAM,+BAA+B,CAAC;AAGjE;;;GAGG;AACH,MAAM,OAAO,aAAa;IAA1B;QAGS,YAAO,GAAyB,EAAE,CAAC;IAe5C,CAAC;IAbQ,UAAU;QACf,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAClF,CAAC;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CACtB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,kBAAkB,CAAC,QAAQ,IAAI,KAAK,CAAC,KAAK,KAAK,kBAAkB,CAAC,QAAQ,CACtG,CAAC;IACJ,CAAC;IAEM,YAAY,CAAC,KAAyB;QAC3C,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,MAAM,CAAC;IACtE,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* One row of the `pristine_migrations` bookkeeping table. Mirrors the schema exactly
|
|
3
|
+
* (snake_case in the database; the manager handles translation when reading rows
|
|
4
|
+
* back via `MysqlClient.executeSql`).
|
|
5
|
+
*/
|
|
6
|
+
export class MigrationRecord {
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=migration-record.model.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration-record.model.js","sourceRoot":"","sources":["../../../../src/models/migration-record.model.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,OAAO,eAAe;CAM3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../src/models/models.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Typed configuration keys for `@pristine-ts/mysql-cli`. Use these constants with
|
|
3
|
+
* `@injectConfig` for autocomplete + rename safety, instead of typing the parameter
|
|
4
|
+
* name as a string.
|
|
5
|
+
*
|
|
6
|
+
* ```ts
|
|
7
|
+
* import {injectConfig} from "@pristine-ts/common";
|
|
8
|
+
* import {MysqlCliConfigurationKeys} from "@pristine-ts/mysql-cli";
|
|
9
|
+
*
|
|
10
|
+
* constructor(@injectConfig(MysqlCliConfigurationKeys.ScaffoldPath) path: string) {}
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
13
|
+
export const MysqlCliConfigurationKeys = {
|
|
14
|
+
ScaffoldPath: "pristine.mysql-cli.scaffold.path",
|
|
15
|
+
ScaffoldBarrelPath: "pristine.mysql-cli.scaffold.barrelPath",
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=mysql-cli.configuration-keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql-cli.configuration-keys.js","sourceRoot":"","sources":["../../../src/mysql-cli.configuration-keys.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,YAAY,EAAE,kCAAkC;IAChD,kBAAkB,EAAE,wCAAwC;CACpD,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { CommonModule } from "@pristine-ts/common";
|
|
2
|
+
import { CliModule } from "@pristine-ts/cli";
|
|
3
|
+
import { CoreModule } from "@pristine-ts/core";
|
|
4
|
+
import { FileModule } from "@pristine-ts/file";
|
|
5
|
+
import { LoggingModule } from "@pristine-ts/logging";
|
|
6
|
+
import { MysqlModule } from "@pristine-ts/mysql";
|
|
7
|
+
import { MysqlCliModuleKeyname } from "./mysql-cli.module.keyname";
|
|
8
|
+
export * from "./commands/commands";
|
|
9
|
+
export * from "./enums/enums";
|
|
10
|
+
export * from "./errors/errors";
|
|
11
|
+
export * from "./interfaces/interfaces";
|
|
12
|
+
export * from "./managers/managers";
|
|
13
|
+
export * from "./models/models";
|
|
14
|
+
export * from "./mysql-cli.configuration-keys";
|
|
15
|
+
export * from "./mysql-cli.module.keyname";
|
|
16
|
+
export const MysqlCliModule = {
|
|
17
|
+
keyname: MysqlCliModuleKeyname,
|
|
18
|
+
importModules: [
|
|
19
|
+
CommonModule,
|
|
20
|
+
CoreModule,
|
|
21
|
+
CliModule,
|
|
22
|
+
FileModule,
|
|
23
|
+
LoggingModule,
|
|
24
|
+
MysqlModule,
|
|
25
|
+
],
|
|
26
|
+
configurationDefinitions: [
|
|
27
|
+
{
|
|
28
|
+
// The directory `mysql:create` writes new migration files into. Resolved against
|
|
29
|
+
// `process.cwd()` at command time. Override per-project in pristine.config.ts.
|
|
30
|
+
parameterName: MysqlCliModuleKeyname + ".scaffold.path",
|
|
31
|
+
isRequired: false,
|
|
32
|
+
defaultValue: "src/sql-migrations",
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
// When set to a non-empty path, `mysql:create` auto-edits the file at this
|
|
36
|
+
// path to splice in the new import and class reference between marker
|
|
37
|
+
// comments. Empty string (the default) means "not configured" — the command
|
|
38
|
+
// prints manual registration instructions instead. Single field = single
|
|
39
|
+
// signal — no separate enable flag.
|
|
40
|
+
parameterName: MysqlCliModuleKeyname + ".scaffold.barrelPath",
|
|
41
|
+
isRequired: false,
|
|
42
|
+
defaultValue: "",
|
|
43
|
+
},
|
|
44
|
+
],
|
|
45
|
+
};
|
|
46
|
+
//# sourceMappingURL=mysql-cli.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql-cli.module.js","sourceRoot":"","sources":["../../../src/mysql-cli.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAkB,MAAM,qBAAqB,CAAC;AAClE,OAAO,EAAC,SAAS,EAAC,MAAM,kBAAkB,CAAC;AAC3C,OAAO,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,WAAW,EAAC,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAC,qBAAqB,EAAC,MAAM,4BAA4B,CAAC;AAEjE,cAAc,qBAAqB,CAAC;AACpC,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,yBAAyB,CAAC;AACxC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,4BAA4B,CAAC;AAE3C,MAAM,CAAC,MAAM,cAAc,GAAoB;IAC7C,OAAO,EAAE,qBAAqB;IAC9B,aAAa,EAAE;QACb,YAAY;QACZ,UAAU;QACV,SAAS;QACT,UAAU;QACV,aAAa;QACb,WAAW;KACZ;IACD,wBAAwB,EAAE;QACxB;YACE,iFAAiF;YACjF,+EAA+E;YAC/E,aAAa,EAAE,qBAAqB,GAAG,gBAAgB;YACvD,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,oBAAoB;SACnC;QACD;YACE,2EAA2E;YAC3E,sEAAsE;YACtE,4EAA4E;YAC5E,yEAAyE;YACzE,oCAAoC;YACpC,aAAa,EAAE,qBAAqB,GAAG,sBAAsB;YAC7D,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,EAAE;SACjB;KACF;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mysql-cli.module.keyname.js","sourceRoot":"","sources":["../../../src/mysql-cli.module.keyname.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,qBAAqB,GAAW,oBAAoB,CAAC"}
|