@futo-org/backups-orchestrator-api 0.1.71
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 +41 -0
- package/dist/backends/backend.d.ts +23 -0
- package/dist/backends/backend.js +31 -0
- package/dist/backends/backend.js.map +1 -0
- package/dist/backends/local.backend.d.ts +24 -0
- package/dist/backends/local.backend.js +92 -0
- package/dist/backends/local.backend.js.map +1 -0
- package/dist/backends/s3.backend.d.ts +24 -0
- package/dist/backends/s3.backend.js +47 -0
- package/dist/backends/s3.backend.js.map +1 -0
- package/dist/backends/yucca.backend.d.ts +27 -0
- package/dist/backends/yucca.backend.js +63 -0
- package/dist/backends/yucca.backend.js.map +1 -0
- package/dist/const.d.ts +2 -0
- package/dist/const.js +6 -0
- package/dist/const.js.map +1 -0
- package/dist/controllers/auth.controller.d.ts +7 -0
- package/dist/controllers/auth.controller.js +38 -0
- package/dist/controllers/auth.controller.js.map +1 -0
- package/dist/controllers/backend.controller.d.ts +8 -0
- package/dist/controllers/backend.controller.js +52 -0
- package/dist/controllers/backend.controller.js.map +1 -0
- package/dist/controllers/development.controller.d.ts +6 -0
- package/dist/controllers/development.controller.js +35 -0
- package/dist/controllers/development.controller.js.map +1 -0
- package/dist/controllers/filesystem.controller.d.ts +7 -0
- package/dist/controllers/filesystem.controller.js +43 -0
- package/dist/controllers/filesystem.controller.js.map +1 -0
- package/dist/controllers/integrations.controller.d.ts +8 -0
- package/dist/controllers/integrations.controller.js +51 -0
- package/dist/controllers/integrations.controller.js.map +1 -0
- package/dist/controllers/onboarding.controller.d.ts +11 -0
- package/dist/controllers/onboarding.controller.js +80 -0
- package/dist/controllers/onboarding.controller.js.map +1 -0
- package/dist/controllers/repository.controller.d.ts +22 -0
- package/dist/controllers/repository.controller.js +227 -0
- package/dist/controllers/repository.controller.js.map +1 -0
- package/dist/controllers/runHistory.controller.d.ts +9 -0
- package/dist/controllers/runHistory.controller.js +55 -0
- package/dist/controllers/runHistory.controller.js.map +1 -0
- package/dist/controllers/runningTasks.controller.d.ts +8 -0
- package/dist/controllers/runningTasks.controller.js +52 -0
- package/dist/controllers/runningTasks.controller.js.map +1 -0
- package/dist/controllers/schedule.controller.d.ts +10 -0
- package/dist/controllers/schedule.controller.js +76 -0
- package/dist/controllers/schedule.controller.js.map +1 -0
- package/dist/dto/auth.dto.d.ts +4 -0
- package/dist/dto/auth.dto.js +27 -0
- package/dist/dto/auth.dto.js.map +1 -0
- package/dist/dto/backend.dto.d.ts +16 -0
- package/dist/dto/backend.dto.js +64 -0
- package/dist/dto/backend.dto.js.map +1 -0
- package/dist/dto/filesystem.dto.d.ts +12 -0
- package/dist/dto/filesystem.dto.js +56 -0
- package/dist/dto/filesystem.dto.js.map +1 -0
- package/dist/dto/integrations.dto.d.ts +35 -0
- package/dist/dto/integrations.dto.js +163 -0
- package/dist/dto/integrations.dto.js.map +1 -0
- package/dist/dto/onboarding.dto.d.ts +13 -0
- package/dist/dto/onboarding.dto.js +60 -0
- package/dist/dto/onboarding.dto.js.map +1 -0
- package/dist/dto/repository.dto.d.ts +113 -0
- package/dist/dto/repository.dto.js +421 -0
- package/dist/dto/repository.dto.js.map +1 -0
- package/dist/dto/runningTasks.dto.d.ts +14 -0
- package/dist/dto/runningTasks.dto.js +59 -0
- package/dist/dto/runningTasks.dto.js.map +1 -0
- package/dist/dto/schedule.dto.d.ts +29 -0
- package/dist/dto/schedule.dto.js +149 -0
- package/dist/dto/schedule.dto.js.map +1 -0
- package/dist/enum.d.ts +32 -0
- package/dist/enum.js +42 -0
- package/dist/enum.js.map +1 -0
- package/dist/events/events.gateway.d.ts +73 -0
- package/dist/events/events.gateway.js +79 -0
- package/dist/events/events.gateway.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +24 -0
- package/dist/index.js.map +1 -0
- package/dist/moduleConfig.d.ts +20 -0
- package/dist/moduleConfig.js +5 -0
- package/dist/moduleConfig.js.map +1 -0
- package/dist/orchestrationApi.module.d.ts +5 -0
- package/dist/orchestrationApi.module.js +134 -0
- package/dist/orchestrationApi.module.js.map +1 -0
- package/dist/repositories/backend.repository.d.ts +19 -0
- package/dist/repositories/backend.repository.js +60 -0
- package/dist/repositories/backend.repository.js.map +1 -0
- package/dist/repositories/config.repository.d.ts +18 -0
- package/dist/repositories/config.repository.js +93 -0
- package/dist/repositories/config.repository.js.map +1 -0
- package/dist/repositories/database.repository.d.ts +11 -0
- package/dist/repositories/database.repository.js +85 -0
- package/dist/repositories/database.repository.js.map +1 -0
- package/dist/repositories/moduleConfig.repository.d.ts +12 -0
- package/dist/repositories/moduleConfig.repository.js +48 -0
- package/dist/repositories/moduleConfig.repository.js.map +1 -0
- package/dist/repositories/repository.repository.d.ts +18 -0
- package/dist/repositories/repository.repository.js +81 -0
- package/dist/repositories/repository.repository.js.map +1 -0
- package/dist/repositories/repositoryIntegrationImmich.repository.d.ts +14 -0
- package/dist/repositories/repositoryIntegrationImmich.repository.js +57 -0
- package/dist/repositories/repositoryIntegrationImmich.repository.js.map +1 -0
- package/dist/repositories/repositoryLocalMetrics.repository.d.ts +23 -0
- package/dist/repositories/repositoryLocalMetrics.repository.js +55 -0
- package/dist/repositories/repositoryLocalMetrics.repository.js.map +1 -0
- package/dist/repositories/repositoryPath.repository.d.ts +17 -0
- package/dist/repositories/repositoryPath.repository.js +48 -0
- package/dist/repositories/repositoryPath.repository.js.map +1 -0
- package/dist/repositories/restic.repository.d.ts +207 -0
- package/dist/repositories/restic.repository.js +96 -0
- package/dist/repositories/restic.repository.js.map +1 -0
- package/dist/repositories/runHistory.repository.d.ts +44 -0
- package/dist/repositories/runHistory.repository.js +191 -0
- package/dist/repositories/runHistory.repository.js.map +1 -0
- package/dist/repositories/runningTasks.repository.d.ts +14 -0
- package/dist/repositories/runningTasks.repository.js +77 -0
- package/dist/repositories/runningTasks.repository.js.map +1 -0
- package/dist/repositories/schedule.repository.d.ts +47 -0
- package/dist/repositories/schedule.repository.js +99 -0
- package/dist/repositories/schedule.repository.js.map +1 -0
- package/dist/repositories/storage.repository.d.ts +9 -0
- package/dist/repositories/storage.repository.js +39 -0
- package/dist/repositories/storage.repository.js.map +1 -0
- package/dist/schema/index.d.ts +20 -0
- package/dist/schema/index.js +3 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/migrations/20260218105210-InitialMigration.d.ts +3 -0
- package/dist/schema/migrations/20260218105210-InitialMigration.js +15 -0
- package/dist/schema/migrations/20260218105210-InitialMigration.js.map +1 -0
- package/dist/schema/migrations/20260218122600-AddRepositories.d.ts +3 -0
- package/dist/schema/migrations/20260218122600-AddRepositories.js +21 -0
- package/dist/schema/migrations/20260218122600-AddRepositories.js.map +1 -0
- package/dist/schema/migrations/20260224112323-RepositoryPathTable.d.ts +3 -0
- package/dist/schema/migrations/20260224112323-RepositoryPathTable.js +16 -0
- package/dist/schema/migrations/20260224112323-RepositoryPathTable.js.map +1 -0
- package/dist/schema/migrations/20260224123344-RunHistoryTable.d.ts +3 -0
- package/dist/schema/migrations/20260224123344-RunHistoryTable.js +20 -0
- package/dist/schema/migrations/20260224123344-RunHistoryTable.js.map +1 -0
- package/dist/schema/migrations/20260224125102-RepositoryMetricsTable.d.ts +3 -0
- package/dist/schema/migrations/20260224125102-RepositoryMetricsTable.js +16 -0
- package/dist/schema/migrations/20260224125102-RepositoryMetricsTable.js.map +1 -0
- package/dist/schema/migrations/20260304162353-ScheduleTable.d.ts +3 -0
- package/dist/schema/migrations/20260304162353-ScheduleTable.js +27 -0
- package/dist/schema/migrations/20260304162353-ScheduleTable.js.map +1 -0
- package/dist/schema/migrations/20260313222211-AddMetricsColumns.d.ts +3 -0
- package/dist/schema/migrations/20260313222211-AddMetricsColumns.js +13 -0
- package/dist/schema/migrations/20260313222211-AddMetricsColumns.js.map +1 -0
- package/dist/schema/migrations/20260330120000-RepositoryIntegrationImmichTable.d.ts +3 -0
- package/dist/schema/migrations/20260330120000-RepositoryIntegrationImmichTable.js +15 -0
- package/dist/schema/migrations/20260330120000-RepositoryIntegrationImmichTable.js.map +1 -0
- package/dist/schema/migrations/20260330130000-AddScheduleIdToImmichIntegration.d.ts +3 -0
- package/dist/schema/migrations/20260330130000-AddScheduleIdToImmichIntegration.js +14 -0
- package/dist/schema/migrations/20260330130000-AddScheduleIdToImmichIntegration.js.map +1 -0
- package/dist/schema/migrations/20260507120000-AddRunHistoryType.d.ts +3 -0
- package/dist/schema/migrations/20260507120000-AddRunHistoryType.js +18 -0
- package/dist/schema/migrations/20260507120000-AddRunHistoryType.js.map +1 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPolicy.d.ts +3 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPolicy.js +11 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPolicy.js.map +1 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPreset.d.ts +3 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPreset.js +18 -0
- package/dist/schema/migrations/20260512120000-AddRepositoryRetentionPreset.js.map +1 -0
- package/dist/schema/migrations/20260512130000-AllowForgetRunHistoryType.d.ts +3 -0
- package/dist/schema/migrations/20260512130000-AllowForgetRunHistoryType.js +47 -0
- package/dist/schema/migrations/20260512130000-AllowForgetRunHistoryType.js.map +1 -0
- package/dist/schema/tables/backend.table.d.ts +20 -0
- package/dist/schema/tables/backend.table.js +9 -0
- package/dist/schema/tables/backend.table.js.map +1 -0
- package/dist/schema/tables/config.table.d.ts +4 -0
- package/dist/schema/tables/config.table.js +9 -0
- package/dist/schema/tables/config.table.js.map +1 -0
- package/dist/schema/tables/repository.table.d.ts +5 -0
- package/dist/schema/tables/repository.table.js +10 -0
- package/dist/schema/tables/repository.table.js.map +1 -0
- package/dist/schema/tables/repositoryIntegrationImmich.table.d.ts +10 -0
- package/dist/schema/tables/repositoryIntegrationImmich.table.js +10 -0
- package/dist/schema/tables/repositoryIntegrationImmich.table.js.map +1 -0
- package/dist/schema/tables/repositoryLocalMetrics.table.d.ts +7 -0
- package/dist/schema/tables/repositoryLocalMetrics.table.js +12 -0
- package/dist/schema/tables/repositoryLocalMetrics.table.js.map +1 -0
- package/dist/schema/tables/repositoryPath.table.d.ts +4 -0
- package/dist/schema/tables/repositoryPath.table.js +9 -0
- package/dist/schema/tables/repositoryPath.table.js.map +1 -0
- package/dist/schema/tables/repositorySchedule.table.d.ts +4 -0
- package/dist/schema/tables/repositorySchedule.table.js +9 -0
- package/dist/schema/tables/repositorySchedule.table.js.map +1 -0
- package/dist/schema/tables/runHistory.table.d.ts +11 -0
- package/dist/schema/tables/runHistory.table.js +14 -0
- package/dist/schema/tables/runHistory.table.js.map +1 -0
- package/dist/schema/tables/schedule.table.d.ts +9 -0
- package/dist/schema/tables/schedule.table.js +14 -0
- package/dist/schema/tables/schedule.table.js.map +1 -0
- package/dist/services/auth.service.d.ts +16 -0
- package/dist/services/auth.service.js +85 -0
- package/dist/services/auth.service.js.map +1 -0
- package/dist/services/backend.service.d.ts +12 -0
- package/dist/services/backend.service.js +68 -0
- package/dist/services/backend.service.js.map +1 -0
- package/dist/services/bootstrap.service.d.ts +13 -0
- package/dist/services/bootstrap.service.js +44 -0
- package/dist/services/bootstrap.service.js.map +1 -0
- package/dist/services/database.service.d.ts +11 -0
- package/dist/services/database.service.js +39 -0
- package/dist/services/database.service.js.map +1 -0
- package/dist/services/development.service.d.ts +11 -0
- package/dist/services/development.service.js +59 -0
- package/dist/services/development.service.js.map +1 -0
- package/dist/services/filesystem.service.d.ts +7 -0
- package/dist/services/filesystem.service.js +43 -0
- package/dist/services/filesystem.service.js.map +1 -0
- package/dist/services/integrations.service.d.ts +22 -0
- package/dist/services/integrations.service.js +158 -0
- package/dist/services/integrations.service.js.map +1 -0
- package/dist/services/onboarding.service.d.ts +17 -0
- package/dist/services/onboarding.service.js +65 -0
- package/dist/services/onboarding.service.js.map +1 -0
- package/dist/services/repository.service.d.ts +65 -0
- package/dist/services/repository.service.js +623 -0
- package/dist/services/repository.service.js.map +1 -0
- package/dist/services/runHistory.service.d.ts +7 -0
- package/dist/services/runHistory.service.js +29 -0
- package/dist/services/runHistory.service.js.map +1 -0
- package/dist/services/runningTasks.service.d.ts +8 -0
- package/dist/services/runningTasks.service.js +34 -0
- package/dist/services/runningTasks.service.js.map +1 -0
- package/dist/services/schedule.service.d.ts +27 -0
- package/dist/services/schedule.service.js +197 -0
- package/dist/services/schedule.service.js.map +1 -0
- package/dist/utils/restic.d.ts +17 -0
- package/dist/utils/restic.js +26 -0
- package/dist/utils/restic.js.map +1 -0
- package/package.json +79 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260512120000-AddRepositoryRetentionPolicy.js","sourceRoot":"","sources":["../../../src/schema/migrations/20260512120000-AddRepositoryRetentionPolicy.ts"],"names":[],"mappings":";;AAEA,gBAEC;AAED,oBAEC;AANM,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC;AAC5F,CAAC;AAEM,KAAK,UAAU,IAAI,CAAC,EAAe;IACxC,MAAM,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,OAAO,EAAE,CAAC;AACrF,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.up = up;
|
|
4
|
+
exports.down = down;
|
|
5
|
+
const kysely_1 = require("kysely");
|
|
6
|
+
async function up(db) {
|
|
7
|
+
await db.schema
|
|
8
|
+
.alterTable('repositories')
|
|
9
|
+
.addColumn('retentionPreset', 'text', (col) => col
|
|
10
|
+
.notNull()
|
|
11
|
+
.defaultTo('default')
|
|
12
|
+
.check((0, kysely_1.sql) `retentionPreset IN ('default', 'off')`))
|
|
13
|
+
.execute();
|
|
14
|
+
}
|
|
15
|
+
async function down(db) {
|
|
16
|
+
await db.schema.alterTable('repositories').dropColumn('retentionPreset').execute();
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=20260512120000-AddRepositoryRetentionPreset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260512120000-AddRepositoryRetentionPreset.js","sourceRoot":"","sources":["../../../src/schema/migrations/20260512120000-AddRepositoryRetentionPreset.ts"],"names":[],"mappings":";;AAEA,gBAUC;AAED,oBAEC;AAhBD,mCAAqC;AAE9B,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,UAAU,CAAC,cAAc,CAAC;SAC1B,SAAS,CAAC,iBAAiB,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAC5C,GAAG;SACA,OAAO,EAAE;SACT,SAAS,CAAC,SAAS,CAAC;SACpB,KAAK,CAAC,IAAA,YAAG,EAAA,uCAAuC,CAAC,CACrD;SACA,OAAO,EAAE,CAAC;AACf,CAAC;AAEM,KAAK,UAAU,IAAI,CAAC,EAAe;IACxC,MAAM,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,OAAO,EAAE,CAAC;AACrF,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.up = up;
|
|
4
|
+
exports.down = down;
|
|
5
|
+
const kysely_1 = require("kysely");
|
|
6
|
+
async function up(db) {
|
|
7
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = OFF`.execute(db);
|
|
8
|
+
await db.schema
|
|
9
|
+
.createTable('runHistory_new')
|
|
10
|
+
.addColumn('id', 'text', (col) => col.primaryKey())
|
|
11
|
+
.addColumn('repositoryId', 'text', (col) => col.references('repositories.id'))
|
|
12
|
+
.addColumn('start', 'datetime')
|
|
13
|
+
.addColumn('end', 'datetime')
|
|
14
|
+
.addColumn('logFilePath', 'text')
|
|
15
|
+
.addColumn('status', 'text', (col) => col.check((0, kysely_1.sql) `status IN ('incomplete', 'complete', 'failed')`))
|
|
16
|
+
.addColumn('type', 'text', (col) => col
|
|
17
|
+
.notNull()
|
|
18
|
+
.defaultTo('backup')
|
|
19
|
+
.check((0, kysely_1.sql) `type IN ('backup', 'restore', 'forget')`))
|
|
20
|
+
.as(db.selectFrom('runHistory').selectAll())
|
|
21
|
+
.execute();
|
|
22
|
+
await db.schema.dropTable('runHistory').execute();
|
|
23
|
+
await (0, kysely_1.sql) `ALTER TABLE "runHistory_new" RENAME TO "runHistory"`.execute(db);
|
|
24
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = ON`.execute(db);
|
|
25
|
+
}
|
|
26
|
+
async function down(db) {
|
|
27
|
+
await db.deleteFrom('runHistory').where('type', '=', 'forget').execute();
|
|
28
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = OFF`.execute(db);
|
|
29
|
+
await db.schema
|
|
30
|
+
.createTable('runHistory_new')
|
|
31
|
+
.addColumn('id', 'text', (col) => col.primaryKey())
|
|
32
|
+
.addColumn('repositoryId', 'text', (col) => col.references('repositories.id'))
|
|
33
|
+
.addColumn('start', 'datetime')
|
|
34
|
+
.addColumn('end', 'datetime')
|
|
35
|
+
.addColumn('logFilePath', 'text')
|
|
36
|
+
.addColumn('status', 'text', (col) => col.check((0, kysely_1.sql) `status IN ('incomplete', 'complete', 'failed')`))
|
|
37
|
+
.addColumn('type', 'text', (col) => col
|
|
38
|
+
.notNull()
|
|
39
|
+
.defaultTo('backup')
|
|
40
|
+
.check((0, kysely_1.sql) `type IN ('backup', 'restore')`))
|
|
41
|
+
.as(db.selectFrom('runHistory').selectAll())
|
|
42
|
+
.execute();
|
|
43
|
+
await db.schema.dropTable('runHistory').execute();
|
|
44
|
+
await (0, kysely_1.sql) `ALTER TABLE "runHistory_new" RENAME TO "runHistory"`.execute(db);
|
|
45
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = ON`.execute(db);
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=20260512130000-AllowForgetRunHistoryType.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260512130000-AllowForgetRunHistoryType.js","sourceRoot":"","sources":["../../../src/schema/migrations/20260512130000-AllowForgetRunHistoryType.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Generated } from 'kysely';
|
|
2
|
+
import { BackendType } from '../../enum';
|
|
3
|
+
export type BackendConfiguration = {
|
|
4
|
+
type: BackendType.Yucca;
|
|
5
|
+
url?: string;
|
|
6
|
+
accessToken: string;
|
|
7
|
+
} | {
|
|
8
|
+
type: BackendType.Local;
|
|
9
|
+
path: string;
|
|
10
|
+
} | {
|
|
11
|
+
type: BackendType.S3;
|
|
12
|
+
endpoint: string;
|
|
13
|
+
region: string;
|
|
14
|
+
accessKeyId: string;
|
|
15
|
+
secretAccessKey: string;
|
|
16
|
+
};
|
|
17
|
+
export declare class BackendTable {
|
|
18
|
+
id: Generated<string>;
|
|
19
|
+
configuration: string;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.table.js","sourceRoot":"","sources":["../../../src/schema/tables/backend.table.ts"],"names":[],"mappings":";;;AAuCA,MAAa,YAAY;IACvB,EAAE,CAAqB;IACvB,aAAa,CAAU;CACxB;AAHD,oCAGC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.table.js","sourceRoot":"","sources":["../../../src/schema/tables/config.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,WAAW;IACtB,GAAG,CAAU;IACb,KAAK,CAAU;CAChB;AAHD,kCAGC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RepositoryTable = void 0;
|
|
4
|
+
class RepositoryTable {
|
|
5
|
+
id;
|
|
6
|
+
backendId;
|
|
7
|
+
retentionPolicy;
|
|
8
|
+
}
|
|
9
|
+
exports.RepositoryTable = RepositoryTable;
|
|
10
|
+
//# sourceMappingURL=repository.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository.table.js","sourceRoot":"","sources":["../../../src/schema/tables/repository.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,eAAe;IAC1B,EAAE,CAAU;IAEZ,SAAS,CAAU;IAEnB,eAAe,CAAiB;CACjC;AAND,0CAMC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RepositoryIntegrationImmichTable = void 0;
|
|
4
|
+
class RepositoryIntegrationImmichTable {
|
|
5
|
+
id;
|
|
6
|
+
scheduleId;
|
|
7
|
+
configuration;
|
|
8
|
+
}
|
|
9
|
+
exports.RepositoryIntegrationImmichTable = RepositoryIntegrationImmichTable;
|
|
10
|
+
//# sourceMappingURL=repositoryIntegrationImmich.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositoryIntegrationImmich.table.js","sourceRoot":"","sources":["../../../src/schema/tables/repositoryIntegrationImmich.table.ts"],"names":[],"mappings":";;;AAMA,MAAa,gCAAgC;IAC3C,EAAE,CAAU;IAEZ,UAAU,CAAU;IAEpB,aAAa,CAAU;CACxB;AAND,4EAMC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RepositoryLocalMetricsTable = void 0;
|
|
4
|
+
class RepositoryLocalMetricsTable {
|
|
5
|
+
id;
|
|
6
|
+
sizeBytes;
|
|
7
|
+
lastBackup;
|
|
8
|
+
lastSuccessfulBackup;
|
|
9
|
+
lastBackupDuration;
|
|
10
|
+
}
|
|
11
|
+
exports.RepositoryLocalMetricsTable = RepositoryLocalMetricsTable;
|
|
12
|
+
//# sourceMappingURL=repositoryLocalMetrics.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositoryLocalMetrics.table.js","sourceRoot":"","sources":["../../../src/schema/tables/repositoryLocalMetrics.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,2BAA2B;IACtC,EAAE,CAAU;IAEZ,SAAS,CAAU;IACnB,UAAU,CAAU;IACpB,oBAAoB,CAAU;IAC9B,kBAAkB,CAAU;CAC7B;AAPD,kEAOC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RepositoryPathTable = void 0;
|
|
4
|
+
class RepositoryPathTable {
|
|
5
|
+
id;
|
|
6
|
+
path;
|
|
7
|
+
}
|
|
8
|
+
exports.RepositoryPathTable = RepositoryPathTable;
|
|
9
|
+
//# sourceMappingURL=repositoryPath.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositoryPath.table.js","sourceRoot":"","sources":["../../../src/schema/tables/repositoryPath.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,mBAAmB;IAC9B,EAAE,CAAU;IAEZ,IAAI,CAAU;CACf;AAJD,kDAIC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RepositoryScheduleTable = void 0;
|
|
4
|
+
class RepositoryScheduleTable {
|
|
5
|
+
schedule;
|
|
6
|
+
repository;
|
|
7
|
+
}
|
|
8
|
+
exports.RepositoryScheduleTable = RepositoryScheduleTable;
|
|
9
|
+
//# sourceMappingURL=repositorySchedule.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repositorySchedule.table.js","sourceRoot":"","sources":["../../../src/schema/tables/repositorySchedule.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,uBAAuB;IAClC,QAAQ,CAAU;IAClB,UAAU,CAAU;CACrB;AAHD,0DAGC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { TaskStatus, TaskType } from '../../enum';
|
|
2
|
+
export type RunType = TaskType.Backup | TaskType.Restore | TaskType.Forget;
|
|
3
|
+
export declare class RunHistoryTable {
|
|
4
|
+
id: string;
|
|
5
|
+
repositoryId: string;
|
|
6
|
+
start: string;
|
|
7
|
+
end?: string;
|
|
8
|
+
logFilePath: string;
|
|
9
|
+
status: TaskStatus;
|
|
10
|
+
type: RunType;
|
|
11
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RunHistoryTable = void 0;
|
|
4
|
+
class RunHistoryTable {
|
|
5
|
+
id;
|
|
6
|
+
repositoryId;
|
|
7
|
+
start;
|
|
8
|
+
end;
|
|
9
|
+
logFilePath;
|
|
10
|
+
status;
|
|
11
|
+
type;
|
|
12
|
+
}
|
|
13
|
+
exports.RunHistoryTable = RunHistoryTable;
|
|
14
|
+
//# sourceMappingURL=runHistory.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runHistory.table.js","sourceRoot":"","sources":["../../../src/schema/tables/runHistory.table.ts"],"names":[],"mappings":";;;AAIA,MAAa,eAAe;IAC1B,EAAE,CAAU;IACZ,YAAY,CAAU;IAEtB,KAAK,CAAU;IACf,GAAG,CAAU;IAEb,WAAW,CAAU;IACrB,MAAM,CAAc;IACpB,IAAI,CAAW;CAChB;AAVD,0CAUC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ScheduleTable = void 0;
|
|
4
|
+
class ScheduleTable {
|
|
5
|
+
id;
|
|
6
|
+
name;
|
|
7
|
+
paused;
|
|
8
|
+
cron;
|
|
9
|
+
ordering;
|
|
10
|
+
lastRun;
|
|
11
|
+
lastFinished;
|
|
12
|
+
}
|
|
13
|
+
exports.ScheduleTable = ScheduleTable;
|
|
14
|
+
//# sourceMappingURL=schedule.table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schedule.table.js","sourceRoot":"","sources":["../../../src/schema/tables/schedule.table.ts"],"names":[],"mappings":";;;AAAA,MAAa,aAAa;IACxB,EAAE,CAAU;IACZ,IAAI,CAAU;IACd,MAAM,CAAU;IAChB,IAAI,CAAU;IACd,QAAQ,CAAU;IAElB,OAAO,CAAU;IACjB,YAAY,CAAU;CACvB;AATD,sCASC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { EventsGateway } from '../events/events.gateway';
|
|
2
|
+
import { BackendRepository } from '../repositories/backend.repository';
|
|
3
|
+
import { ConfigRepository } from '../repositories/config.repository';
|
|
4
|
+
import { ModuleConfigRepository } from '../repositories/moduleConfig.repository';
|
|
5
|
+
export declare class AuthService {
|
|
6
|
+
readonly config: ConfigRepository;
|
|
7
|
+
readonly backend: BackendRepository;
|
|
8
|
+
readonly moduleConfig: ModuleConfigRepository;
|
|
9
|
+
readonly events: EventsGateway;
|
|
10
|
+
constructor(config: ConfigRepository, backend: BackendRepository, moduleConfig: ModuleConfigRepository, events: EventsGateway);
|
|
11
|
+
private waitForDeviceFlow;
|
|
12
|
+
oidcDeviceFlow(): Promise<{
|
|
13
|
+
userCode: string;
|
|
14
|
+
verificationUri: string;
|
|
15
|
+
}>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AuthService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const eventsource_client_1 = require("eventsource-client");
|
|
15
|
+
const const_1 = require("../const");
|
|
16
|
+
const enum_1 = require("../enum");
|
|
17
|
+
const events_gateway_1 = require("../events/events.gateway");
|
|
18
|
+
const backend_repository_1 = require("../repositories/backend.repository");
|
|
19
|
+
const config_repository_1 = require("../repositories/config.repository");
|
|
20
|
+
const moduleConfig_repository_1 = require("../repositories/moduleConfig.repository");
|
|
21
|
+
let AuthService = class AuthService {
|
|
22
|
+
config;
|
|
23
|
+
backend;
|
|
24
|
+
moduleConfig;
|
|
25
|
+
events;
|
|
26
|
+
constructor(config, backend, moduleConfig, events) {
|
|
27
|
+
this.config = config;
|
|
28
|
+
this.backend = backend;
|
|
29
|
+
this.moduleConfig = moduleConfig;
|
|
30
|
+
this.events = events;
|
|
31
|
+
}
|
|
32
|
+
async waitForDeviceFlow(events) {
|
|
33
|
+
for await (const { data } of events) {
|
|
34
|
+
const { type, accessToken } = JSON.parse(data);
|
|
35
|
+
switch (type) {
|
|
36
|
+
case 'SUCCESS': {
|
|
37
|
+
await this.backend.updateBackend(const_1.YUCCA_PRODUCTION_UUID, {
|
|
38
|
+
type: enum_1.BackendType.Yucca,
|
|
39
|
+
accessToken,
|
|
40
|
+
});
|
|
41
|
+
this.events.publish({
|
|
42
|
+
type: 'BackendCreate',
|
|
43
|
+
backend: {
|
|
44
|
+
id: const_1.YUCCA_PRODUCTION_UUID,
|
|
45
|
+
type: enum_1.BackendType.Yucca,
|
|
46
|
+
isOnline: true,
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
break;
|
|
50
|
+
}
|
|
51
|
+
case 'FAILURE': {
|
|
52
|
+
this.events.publish({
|
|
53
|
+
type: 'DeviceFlowFailure',
|
|
54
|
+
});
|
|
55
|
+
break;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
events.close();
|
|
60
|
+
}
|
|
61
|
+
async oidcDeviceFlow() {
|
|
62
|
+
const events = (0, eventsource_client_1.createEventSource)({
|
|
63
|
+
url: new URL('/api/auth/oidc/device', this.moduleConfig.get().yuccaProductionApi),
|
|
64
|
+
onDisconnect: () => events.close(),
|
|
65
|
+
});
|
|
66
|
+
for await (const { data } of events) {
|
|
67
|
+
const { userCode, verificationUri } = JSON.parse(data);
|
|
68
|
+
void this.waitForDeviceFlow(events).catch(() => { });
|
|
69
|
+
return {
|
|
70
|
+
userCode,
|
|
71
|
+
verificationUri,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
throw new common_1.InternalServerErrorException('Failed to start authentication with FUTO Backups');
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
exports.AuthService = AuthService;
|
|
78
|
+
exports.AuthService = AuthService = __decorate([
|
|
79
|
+
(0, common_1.Injectable)(),
|
|
80
|
+
__metadata("design:paramtypes", [config_repository_1.ConfigRepository,
|
|
81
|
+
backend_repository_1.BackendRepository,
|
|
82
|
+
moduleConfig_repository_1.ModuleConfigRepository,
|
|
83
|
+
events_gateway_1.EventsGateway])
|
|
84
|
+
], AuthService);
|
|
85
|
+
//# sourceMappingURL=auth.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/services/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA0E;AAC1E,2DAA0E;AAC1E,oCAAiD;AACjD,kCAAsC;AACtC,6DAAyD;AACzD,2EAAuE;AACvE,yEAAqE;AACrE,qFAAiF;AAG1E,IAAM,WAAW,GAAjB,MAAM,WAAW;IAEX;IACA;IACA;IACA;IAJX,YACW,MAAwB,EACxB,OAA0B,EAC1B,YAAoC,EACpC,MAAqB;QAHrB,WAAM,GAAN,MAAM,CAAkB;QACxB,YAAO,GAAP,OAAO,CAAmB;QAC1B,iBAAY,GAAZ,YAAY,CAAwB;QACpC,WAAM,GAAN,MAAM,CAAe;IAC7B,CAAC;IAEI,KAAK,CAAC,iBAAiB,CAAC,MAAyB;QACvD,IAAI,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,MAAM,EAAE,CAAC;YACpC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAE/C,QAAQ,IAAI,EAAE,CAAC;gBACb,KAAK,SAAS,CAAC,CAAC,CAAC;oBACf,MAAM,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,6BAAqB,EAAE;wBACtD,IAAI,EAAE,kBAAW,CAAC,KAAK;wBACvB,WAAW;qBACZ,CAAC,CAAC;oBAEH,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;wBAClB,IAAI,EAAE,eAAe;wBACrB,OAAO,EAAE;4BACP,EAAE,EAAE,6BAAqB;4BACzB,IAAI,EAAE,kBAAW,CAAC,KAAK;4BACvB,QAAQ,EAAE,IAAI;yBACf;qBACF,CAAC,CAAC;oBAEH,MAAM;gBACR,CAAC;gBACD,KAAK,SAAS,CAAC,CAAC,CAAC;oBACf,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;wBAClB,IAAI,EAAE,mBAAmB;qBAC1B,CAAC,CAAC;oBAEH,MAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;QAED,MAAM,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,MAAM,MAAM,GAAsB,IAAA,sCAAiB,EAAC;YAClD,GAAG,EAAE,IAAI,GAAG,CAAC,uBAAuB,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;YACjF,YAAY,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE;SACnC,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,MAAM,EAAE,CAAC;YACpC,MAAM,EAAE,QAAQ,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAEvD,KAAK,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;YAEpD,OAAO;gBACL,QAAQ;gBACR,eAAe;aAChB,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,qCAA4B,CAAC,kDAAkD,CAAC,CAAC;IAC7F,CAAC;CACF,CAAA;AA9DY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAGQ,oCAAgB;QACf,sCAAiB;QACZ,gDAAsB;QAC5B,8BAAa;GALrB,WAAW,CA8DvB"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BackendResponseDto, BackendsResponseDto, CreateLocalBackendRequestDto } from '../dto/backend.dto';
|
|
2
|
+
import { EventsGateway } from '../events/events.gateway';
|
|
3
|
+
import { BackendRepository } from '../repositories/backend.repository';
|
|
4
|
+
import { ModuleConfigRepository } from '../repositories/moduleConfig.repository';
|
|
5
|
+
export declare class BackendService {
|
|
6
|
+
private readonly moduleConfig;
|
|
7
|
+
private readonly repository;
|
|
8
|
+
private readonly events;
|
|
9
|
+
constructor(moduleConfig: ModuleConfigRepository, repository: BackendRepository, events: EventsGateway);
|
|
10
|
+
getBackends(): Promise<BackendsResponseDto>;
|
|
11
|
+
createLocalBackend(dto: CreateLocalBackendRequestDto): Promise<BackendResponseDto>;
|
|
12
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.BackendService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const node_crypto_1 = require("node:crypto");
|
|
15
|
+
const backend_1 = require("../backends/backend");
|
|
16
|
+
const enum_1 = require("../enum");
|
|
17
|
+
const events_gateway_1 = require("../events/events.gateway");
|
|
18
|
+
const backend_repository_1 = require("../repositories/backend.repository");
|
|
19
|
+
const moduleConfig_repository_1 = require("../repositories/moduleConfig.repository");
|
|
20
|
+
let BackendService = class BackendService {
|
|
21
|
+
moduleConfig;
|
|
22
|
+
repository;
|
|
23
|
+
events;
|
|
24
|
+
constructor(moduleConfig, repository, events) {
|
|
25
|
+
this.moduleConfig = moduleConfig;
|
|
26
|
+
this.repository = repository;
|
|
27
|
+
this.events = events;
|
|
28
|
+
}
|
|
29
|
+
async getBackends() {
|
|
30
|
+
const backends = await this.repository.getBackends();
|
|
31
|
+
const error = await Promise.all(backends.map((backend) => backend_1.Backend.from(backend.configuration, this.moduleConfig.get())
|
|
32
|
+
.checkOnline()
|
|
33
|
+
.then(() => void 0)
|
|
34
|
+
.catch((error) => error)));
|
|
35
|
+
return {
|
|
36
|
+
backends: backends.map((backend, idx) => ({
|
|
37
|
+
id: backend.id,
|
|
38
|
+
type: backend.configuration.type,
|
|
39
|
+
isOnline: error[idx] === undefined,
|
|
40
|
+
error: error[idx],
|
|
41
|
+
})),
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
async createLocalBackend(dto) {
|
|
45
|
+
const { id } = await this.repository.updateBackend((0, node_crypto_1.randomUUID)(), {
|
|
46
|
+
type: enum_1.BackendType.Local,
|
|
47
|
+
path: dto.path,
|
|
48
|
+
});
|
|
49
|
+
const backend = {
|
|
50
|
+
type: enum_1.BackendType.Local,
|
|
51
|
+
id,
|
|
52
|
+
isOnline: true,
|
|
53
|
+
};
|
|
54
|
+
this.events.publish({
|
|
55
|
+
type: 'BackendCreate',
|
|
56
|
+
backend,
|
|
57
|
+
});
|
|
58
|
+
return { backend };
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
exports.BackendService = BackendService;
|
|
62
|
+
exports.BackendService = BackendService = __decorate([
|
|
63
|
+
(0, common_1.Injectable)(),
|
|
64
|
+
__metadata("design:paramtypes", [moduleConfig_repository_1.ModuleConfigRepository,
|
|
65
|
+
backend_repository_1.BackendRepository,
|
|
66
|
+
events_gateway_1.EventsGateway])
|
|
67
|
+
], BackendService);
|
|
68
|
+
//# sourceMappingURL=backend.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backend.service.js","sourceRoot":"","sources":["../../src/services/backend.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAyC;AACzC,iDAA8C;AAE9C,kCAAsC;AACtC,6DAAyD;AACzD,2EAAuE;AACvE,qFAAiF;AAG1E,IAAM,cAAc,GAApB,MAAM,cAAc;IAEN;IACA;IACA;IAHnB,YACmB,YAAoC,EACpC,UAA6B,EAC7B,MAAqB;QAFrB,iBAAY,GAAZ,YAAY,CAAwB;QACpC,eAAU,GAAV,UAAU,CAAmB;QAC7B,WAAM,GAAN,MAAM,CAAe;IACrC,CAAC;IAEJ,KAAK,CAAC,WAAW;QACf,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QAErD,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,GAAG,CAC7B,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACvB,iBAAO,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC;aACzD,WAAW,EAAE;aACb,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;aAClB,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAC3B,CACF,CAAC;QAEF,OAAO;YACL,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;gBACxC,EAAE,EAAE,OAAO,CAAC,EAAE;gBACd,IAAI,EAAE,OAAO,CAAC,aAAa,CAAC,IAAI;gBAChC,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,KAAK,SAAS;gBAClC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC;aAClB,CAAC,CAAC;SACJ,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,GAAiC;QACxD,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAA,wBAAU,GAAE,EAAE;YAC/D,IAAI,EAAE,kBAAW,CAAC,KAAK;YACvB,IAAI,EAAE,GAAG,CAAC,IAAI;SACf,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG;YACd,IAAI,EAAE,kBAAW,CAAC,KAAK;YACvB,EAAE;YACF,QAAQ,EAAE,IAAI;SACf,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAClB,IAAI,EAAE,eAAe;YACrB,OAAO;SACR,CAAC,CAAC;QAEH,OAAO,EAAE,OAAO,EAAE,CAAC;IACrB,CAAC;CACF,CAAA;AAhDY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGsB,gDAAsB;QACxB,sCAAiB;QACrB,8BAAa;GAJ7B,cAAc,CAgD1B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { OnApplicationBootstrap } from '@nestjs/common';
|
|
2
|
+
import { ConfigRepository } from '../repositories/config.repository';
|
|
3
|
+
import { DatabaseRepository } from '../repositories/database.repository';
|
|
4
|
+
import { RunHistoryRepository } from '../repositories/runHistory.repository';
|
|
5
|
+
import { ScheduleService } from './schedule.service';
|
|
6
|
+
export declare class BootstrapService implements OnApplicationBootstrap {
|
|
7
|
+
private readonly database;
|
|
8
|
+
private readonly config;
|
|
9
|
+
private readonly schedule;
|
|
10
|
+
private readonly runHistoryRepository;
|
|
11
|
+
constructor(database: DatabaseRepository, config: ConfigRepository, schedule: ScheduleService, runHistoryRepository: RunHistoryRepository);
|
|
12
|
+
onApplicationBootstrap(): Promise<void>;
|
|
13
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
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;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.BootstrapService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const config_repository_1 = require("../repositories/config.repository");
|
|
15
|
+
const database_repository_1 = require("../repositories/database.repository");
|
|
16
|
+
const runHistory_repository_1 = require("../repositories/runHistory.repository");
|
|
17
|
+
const schedule_service_1 = require("./schedule.service");
|
|
18
|
+
let BootstrapService = class BootstrapService {
|
|
19
|
+
database;
|
|
20
|
+
config;
|
|
21
|
+
schedule;
|
|
22
|
+
runHistoryRepository;
|
|
23
|
+
constructor(database, config, schedule, runHistoryRepository) {
|
|
24
|
+
this.database = database;
|
|
25
|
+
this.config = config;
|
|
26
|
+
this.schedule = schedule;
|
|
27
|
+
this.runHistoryRepository = runHistoryRepository;
|
|
28
|
+
}
|
|
29
|
+
async onApplicationBootstrap() {
|
|
30
|
+
await this.database.runMigrations();
|
|
31
|
+
await this.config.bootstrap();
|
|
32
|
+
await this.schedule.bootstrap();
|
|
33
|
+
await this.runHistoryRepository.markIncompleteAsFailed();
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.BootstrapService = BootstrapService;
|
|
37
|
+
exports.BootstrapService = BootstrapService = __decorate([
|
|
38
|
+
(0, common_1.Injectable)(),
|
|
39
|
+
__metadata("design:paramtypes", [database_repository_1.DatabaseRepository,
|
|
40
|
+
config_repository_1.ConfigRepository,
|
|
41
|
+
schedule_service_1.ScheduleService,
|
|
42
|
+
runHistory_repository_1.RunHistoryRepository])
|
|
43
|
+
], BootstrapService);
|
|
44
|
+
//# sourceMappingURL=bootstrap.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bootstrap.service.js","sourceRoot":"","sources":["../../src/services/bootstrap.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAoE;AACpE,yEAAqE;AACrE,6EAAyE;AACzE,iFAA6E;AAC7E,yDAAqD;AAG9C,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAER;IACA;IACA;IACA;IAJnB,YACmB,QAA4B,EAC5B,MAAwB,EACxB,QAAyB,EACzB,oBAA0C;QAH1C,aAAQ,GAAR,QAAQ,CAAoB;QAC5B,WAAM,GAAN,MAAM,CAAkB;QACxB,aAAQ,GAAR,QAAQ,CAAiB;QACzB,yBAAoB,GAApB,oBAAoB,CAAsB;IAC1D,CAAC;IAEJ,KAAK,CAAC,sBAAsB;QAC1B,MAAM,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;QACpC,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QAC9B,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;QAChC,MAAM,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,EAAE,CAAC;IAC3D,CAAC;CACF,CAAA;AAdY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,mBAAU,GAAE;qCAGkB,wCAAkB;QACpB,oCAAgB;QACd,kCAAe;QACH,4CAAoB;GALlD,gBAAgB,CAc5B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { OnApplicationBootstrap } from '@nestjs/common';
|
|
2
|
+
import { ConfigRepository } from '../repositories/config.repository';
|
|
3
|
+
import { DatabaseRepository } from '../repositories/database.repository';
|
|
4
|
+
import { ScheduleService } from './schedule.service';
|
|
5
|
+
export declare class DatabaseService implements OnApplicationBootstrap {
|
|
6
|
+
private readonly repository;
|
|
7
|
+
private readonly config;
|
|
8
|
+
private readonly schedule;
|
|
9
|
+
constructor(repository: DatabaseRepository, config: ConfigRepository, schedule: ScheduleService);
|
|
10
|
+
onApplicationBootstrap(): Promise<void>;
|
|
11
|
+
}
|