@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,39 @@
|
|
|
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.DatabaseService = 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 schedule_service_1 = require("./schedule.service");
|
|
17
|
+
let DatabaseService = class DatabaseService {
|
|
18
|
+
repository;
|
|
19
|
+
config;
|
|
20
|
+
schedule;
|
|
21
|
+
constructor(repository, config, schedule) {
|
|
22
|
+
this.repository = repository;
|
|
23
|
+
this.config = config;
|
|
24
|
+
this.schedule = schedule;
|
|
25
|
+
}
|
|
26
|
+
async onApplicationBootstrap() {
|
|
27
|
+
await this.repository.runMigrations();
|
|
28
|
+
await this.config.bootstrap();
|
|
29
|
+
await this.schedule.bootstrap();
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
exports.DatabaseService = DatabaseService;
|
|
33
|
+
exports.DatabaseService = DatabaseService = __decorate([
|
|
34
|
+
(0, common_1.Injectable)(),
|
|
35
|
+
__metadata("design:paramtypes", [database_repository_1.DatabaseRepository,
|
|
36
|
+
config_repository_1.ConfigRepository,
|
|
37
|
+
schedule_service_1.ScheduleService])
|
|
38
|
+
], DatabaseService);
|
|
39
|
+
//# sourceMappingURL=database.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"database.service.js","sourceRoot":"","sources":["../../src/services/database.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAoE;AACpE,yEAAqE;AACrE,6EAAyE;AACzE,yDAAqD;AAG9C,IAAM,eAAe,GAArB,MAAM,eAAe;IAEP;IACA;IACA;IAHnB,YACmB,UAA8B,EAC9B,MAAwB,EACxB,QAAyB;QAFzB,eAAU,GAAV,UAAU,CAAoB;QAC9B,WAAM,GAAN,MAAM,CAAkB;QACxB,aAAQ,GAAR,QAAQ,CAAiB;IACzC,CAAC;IAEJ,KAAK,CAAC,sBAAsB;QAC1B,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;QACtC,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;QAC9B,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;IAClC,CAAC;CACF,CAAA;AAZY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,mBAAU,GAAE;qCAGoB,wCAAkB;QACtB,oCAAgB;QACd,kCAAe;GAJjC,eAAe,CAY3B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Kysely } from 'kysely';
|
|
2
|
+
import { ModuleConfigRepository } from '../repositories/moduleConfig.repository';
|
|
3
|
+
import { DB } from '../schema';
|
|
4
|
+
import { BootstrapService } from './bootstrap.service';
|
|
5
|
+
export declare class DevelopmentService {
|
|
6
|
+
private readonly db;
|
|
7
|
+
private readonly moduleConfig;
|
|
8
|
+
private readonly bootstrap;
|
|
9
|
+
constructor(db: Kysely<DB>, moduleConfig: ModuleConfigRepository, bootstrap: BootstrapService);
|
|
10
|
+
resetOrchestrator(): Promise<void>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
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
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.DevelopmentService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const kysely_1 = require("kysely");
|
|
18
|
+
const nestjs_kysely_1 = require("nestjs-kysely");
|
|
19
|
+
const moduleConfig_repository_1 = require("../repositories/moduleConfig.repository");
|
|
20
|
+
const bootstrap_service_1 = require("./bootstrap.service");
|
|
21
|
+
let DevelopmentService = class DevelopmentService {
|
|
22
|
+
db;
|
|
23
|
+
moduleConfig;
|
|
24
|
+
bootstrap;
|
|
25
|
+
constructor(db, moduleConfig, bootstrap) {
|
|
26
|
+
this.db = db;
|
|
27
|
+
this.moduleConfig = moduleConfig;
|
|
28
|
+
this.bootstrap = bootstrap;
|
|
29
|
+
}
|
|
30
|
+
async resetOrchestrator() {
|
|
31
|
+
if (!this.moduleConfig.get().developmentMode) {
|
|
32
|
+
throw new common_1.BadRequestException('Not in development mode');
|
|
33
|
+
}
|
|
34
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = OFF`.execute(this.db);
|
|
35
|
+
const tables = await (0, kysely_1.sql) `
|
|
36
|
+
SELECT name FROM sqlite_master WHERE type = 'table' AND name NOT LIKE 'sqlite_%'
|
|
37
|
+
`.execute(this.db);
|
|
38
|
+
for (const { name } of tables.rows) {
|
|
39
|
+
await (0, kysely_1.sql) `DROP TABLE IF EXISTS ${kysely_1.sql.ref(name)}`.execute(this.db);
|
|
40
|
+
}
|
|
41
|
+
await (0, kysely_1.sql) `PRAGMA foreign_keys = ON`.execute(this.db);
|
|
42
|
+
await this.bootstrap.onApplicationBootstrap();
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
exports.DevelopmentService = DevelopmentService;
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, common_1.Post)('reset'),
|
|
48
|
+
__metadata("design:type", Function),
|
|
49
|
+
__metadata("design:paramtypes", []),
|
|
50
|
+
__metadata("design:returntype", Promise)
|
|
51
|
+
], DevelopmentService.prototype, "resetOrchestrator", null);
|
|
52
|
+
exports.DevelopmentService = DevelopmentService = __decorate([
|
|
53
|
+
(0, common_1.Injectable)(),
|
|
54
|
+
__param(0, (0, nestjs_kysely_1.InjectKysely)('orchestrator')),
|
|
55
|
+
__metadata("design:paramtypes", [kysely_1.Kysely,
|
|
56
|
+
moduleConfig_repository_1.ModuleConfigRepository,
|
|
57
|
+
bootstrap_service_1.BootstrapService])
|
|
58
|
+
], DevelopmentService);
|
|
59
|
+
//# sourceMappingURL=development.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"development.service.js","sourceRoot":"","sources":["../../src/services/development.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAuE;AACvE,mCAAqC;AACrC,iDAA6C;AAC7C,qFAAiF;AAEjF,2DAAuD;AAGhD,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAEoB;IAC9B;IACA;IAHnB,YACiD,EAAc,EAC5C,YAAoC,EACpC,SAA2B;QAFG,OAAE,GAAF,EAAE,CAAY;QAC5C,iBAAY,GAAZ,YAAY,CAAwB;QACpC,cAAS,GAAT,SAAS,CAAkB;IAC3C,CAAC;IAGE,AAAN,KAAK,CAAC,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,eAAe,EAAE,CAAC;YAC7C,MAAM,IAAI,4BAAmB,CAAC,yBAAyB,CAAC,CAAC;QAC3D,CAAC;QAED,MAAM,IAAA,YAAG,EAAA,2BAA2B,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEtD,MAAM,MAAM,GAAG,MAAM,IAAA,YAAG,EAAkB;;KAEzC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEnB,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;YACnC,MAAM,IAAA,YAAG,EAAA,wBAAwB,YAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpE,CAAC;QAED,MAAM,IAAA,YAAG,EAAA,0BAA0B,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAErD,MAAM,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,CAAC;IAChD,CAAC;CACF,CAAA;AA3BY,gDAAkB;AAQvB;IADL,IAAA,aAAI,EAAC,OAAO,CAAC;;;;2DAmBb;6BA1BU,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,4BAAY,EAAC,cAAc,CAAC,CAAA;qCAAsB,eAAM;QAC1B,gDAAsB;QACzB,oCAAgB;GAJnC,kBAAkB,CA2B9B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { FilesystemListingRequestDto, FilesystemListingResponseDto } from '../dto/filesystem.dto';
|
|
2
|
+
import { StorageRepository } from '../repositories/storage.repository';
|
|
3
|
+
export declare class FilesystemService {
|
|
4
|
+
private readonly storage;
|
|
5
|
+
constructor(storage: StorageRepository);
|
|
6
|
+
getFileListing(dto: FilesystemListingRequestDto): Promise<FilesystemListingResponseDto>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
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.FilesystemService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const node_os_1 = require("node:os");
|
|
15
|
+
const node_path_1 = require("node:path");
|
|
16
|
+
const storage_repository_1 = require("../repositories/storage.repository");
|
|
17
|
+
let FilesystemService = class FilesystemService {
|
|
18
|
+
storage;
|
|
19
|
+
constructor(storage) {
|
|
20
|
+
this.storage = storage;
|
|
21
|
+
}
|
|
22
|
+
async getFileListing(dto) {
|
|
23
|
+
const path = dto.path ?? (0, node_os_1.homedir)();
|
|
24
|
+
const files = await this.storage.readdir(path);
|
|
25
|
+
return {
|
|
26
|
+
parent: (0, node_path_1.dirname)(path),
|
|
27
|
+
path,
|
|
28
|
+
items: await Promise.all(files
|
|
29
|
+
.map((file) => (0, node_path_1.resolve)(path, file))
|
|
30
|
+
.map(async (path) => ({
|
|
31
|
+
path,
|
|
32
|
+
isDirectory: await this.storage.stat(path).then((s) => s.isDirectory()),
|
|
33
|
+
}))
|
|
34
|
+
.map((result) => result.catch(() => void 0))).then((result) => result.filter((entry) => entry !== undefined)),
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
exports.FilesystemService = FilesystemService;
|
|
39
|
+
exports.FilesystemService = FilesystemService = __decorate([
|
|
40
|
+
(0, common_1.Injectable)(),
|
|
41
|
+
__metadata("design:paramtypes", [storage_repository_1.StorageRepository])
|
|
42
|
+
], FilesystemService);
|
|
43
|
+
//# sourceMappingURL=filesystem.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filesystem.service.js","sourceRoot":"","sources":["../../src/services/filesystem.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,qCAAkC;AAClC,yCAA6C;AAE7C,2EAAuE;AAGhE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IACC;IAA7B,YAA6B,OAA0B;QAA1B,YAAO,GAAP,OAAO,CAAmB;IAAG,CAAC;IAE3D,KAAK,CAAC,cAAc,CAAC,GAAgC;QACnD,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,IAAI,IAAA,iBAAO,GAAE,CAAC;QACnC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE/C,OAAO;YACL,MAAM,EAAE,IAAA,mBAAO,EAAC,IAAI,CAAC;YACrB,IAAI;YACJ,KAAK,EAAE,MAAM,OAAO,CAAC,GAAG,CACtB,KAAK;iBACF,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAA,mBAAO,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC;iBAClC,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;gBACpB,IAAI;gBACJ,WAAW,EAAE,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;aACxE,CAAC,CAAC;iBACF,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAC/C,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC;SAClE,CAAC;IACJ,CAAC;CACF,CAAA;AArBY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAE2B,sCAAiB;GAD5C,iBAAiB,CAqB7B"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ConfigureImmichIntegrationRequestDto, IntegrationsResponseDto } from '../dto/integrations.dto';
|
|
2
|
+
import { EventsGateway } from '../events/events.gateway';
|
|
3
|
+
import type { ModuleConfig } from '../moduleConfig';
|
|
4
|
+
import { ModuleConfigRepository } from '../repositories/moduleConfig.repository';
|
|
5
|
+
import { RepositoryIntegrationImmichRepository } from '../repositories/repositoryIntegrationImmich.repository';
|
|
6
|
+
import { RepositoryPathRepository } from '../repositories/repositoryPath.repository';
|
|
7
|
+
import { RepositoryService } from './repository.service';
|
|
8
|
+
import { ScheduleService } from './schedule.service';
|
|
9
|
+
export declare class IntegrationsService {
|
|
10
|
+
private readonly events;
|
|
11
|
+
private readonly moduleConfig;
|
|
12
|
+
private readonly repositoryIntegrationImmich;
|
|
13
|
+
private readonly repositoryPath;
|
|
14
|
+
private readonly repositoryService;
|
|
15
|
+
private readonly scheduleService;
|
|
16
|
+
constructor(events: EventsGateway, moduleConfig: ModuleConfigRepository, repositoryIntegrationImmich: RepositoryIntegrationImmichRepository, repositoryPath: RepositoryPathRepository, repositoryService: RepositoryService, scheduleService: ScheduleService);
|
|
17
|
+
onModuleConfigUpdate(moduleConfig: ModuleConfig): Promise<void>;
|
|
18
|
+
getIntegrationsConfig(): Promise<IntegrationsResponseDto>;
|
|
19
|
+
configureImmichIntegration(dto: ConfigureImmichIntegrationRequestDto): Promise<void>;
|
|
20
|
+
private syncImmichRepositoryPaths;
|
|
21
|
+
private getImmichBackupPaths;
|
|
22
|
+
}
|
|
@@ -0,0 +1,158 @@
|
|
|
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.IntegrationsService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
15
|
+
const node_path_1 = require("node:path");
|
|
16
|
+
const enum_1 = require("../enum");
|
|
17
|
+
const events_gateway_1 = require("../events/events.gateway");
|
|
18
|
+
const moduleConfig_repository_1 = require("../repositories/moduleConfig.repository");
|
|
19
|
+
const repositoryIntegrationImmich_repository_1 = require("../repositories/repositoryIntegrationImmich.repository");
|
|
20
|
+
const repositoryPath_repository_1 = require("../repositories/repositoryPath.repository");
|
|
21
|
+
const repository_service_1 = require("./repository.service");
|
|
22
|
+
const schedule_service_1 = require("./schedule.service");
|
|
23
|
+
let IntegrationsService = class IntegrationsService {
|
|
24
|
+
events;
|
|
25
|
+
moduleConfig;
|
|
26
|
+
repositoryIntegrationImmich;
|
|
27
|
+
repositoryPath;
|
|
28
|
+
repositoryService;
|
|
29
|
+
scheduleService;
|
|
30
|
+
constructor(events, moduleConfig, repositoryIntegrationImmich, repositoryPath, repositoryService, scheduleService) {
|
|
31
|
+
this.events = events;
|
|
32
|
+
this.moduleConfig = moduleConfig;
|
|
33
|
+
this.repositoryIntegrationImmich = repositoryIntegrationImmich;
|
|
34
|
+
this.repositoryPath = repositoryPath;
|
|
35
|
+
this.repositoryService = repositoryService;
|
|
36
|
+
this.scheduleService = scheduleService;
|
|
37
|
+
}
|
|
38
|
+
async onModuleConfigUpdate(moduleConfig) {
|
|
39
|
+
if (moduleConfig.immichIntegration) {
|
|
40
|
+
const integration = await this.repositoryIntegrationImmich.get();
|
|
41
|
+
if (!integration) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
await this.syncImmichRepositoryPaths(integration.id, integration.configuration, moduleConfig.immichIntegration);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
async getIntegrationsConfig() {
|
|
48
|
+
const { immichIntegration: immichState } = this.moduleConfig.get();
|
|
49
|
+
const immichIntegration = await this.repositoryIntegrationImmich.get();
|
|
50
|
+
return {
|
|
51
|
+
immichState,
|
|
52
|
+
immichIntegration,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
async configureImmichIntegration(dto) {
|
|
56
|
+
const { immichIntegration } = this.moduleConfig.get();
|
|
57
|
+
if (!immichIntegration) {
|
|
58
|
+
throw new common_1.BadRequestException('Immich integration is not enabled.');
|
|
59
|
+
}
|
|
60
|
+
const existing = await this.repositoryIntegrationImmich.get();
|
|
61
|
+
let repositoryId;
|
|
62
|
+
let scheduleId;
|
|
63
|
+
if (existing) {
|
|
64
|
+
repositoryId = existing.id;
|
|
65
|
+
scheduleId = existing.scheduleId;
|
|
66
|
+
await this.repositoryService.updateRepository(existing.id, {
|
|
67
|
+
name: dto.name,
|
|
68
|
+
retentionPolicy: dto.retentionPolicy,
|
|
69
|
+
});
|
|
70
|
+
await this.scheduleService.applyScheduleUpdate(scheduleId, { cron: dto.cron });
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
({
|
|
74
|
+
repository: { id: repositoryId },
|
|
75
|
+
} = await this.repositoryService.createRepository({
|
|
76
|
+
name: dto.name,
|
|
77
|
+
worm: dto.worm,
|
|
78
|
+
}));
|
|
79
|
+
if (dto.retentionPolicy !== undefined) {
|
|
80
|
+
await this.repositoryService.updateRepository(repositoryId, {
|
|
81
|
+
retentionPolicy: dto.retentionPolicy,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
({
|
|
85
|
+
schedule: { id: scheduleId },
|
|
86
|
+
} = await this.scheduleService.createSchedule({
|
|
87
|
+
name: 'Immich Backup',
|
|
88
|
+
cron: dto.cron,
|
|
89
|
+
repositories: [repositoryId],
|
|
90
|
+
}));
|
|
91
|
+
}
|
|
92
|
+
const configuration = {
|
|
93
|
+
dataFolders: dto.dataFolders,
|
|
94
|
+
backupConfiguration: dto.backupConfiguration,
|
|
95
|
+
libraries: dto.libraries,
|
|
96
|
+
};
|
|
97
|
+
await this.repositoryIntegrationImmich.upsert(repositoryId, scheduleId, configuration);
|
|
98
|
+
await this.syncImmichRepositoryPaths(repositoryId, configuration, immichIntegration);
|
|
99
|
+
this.events.publish({
|
|
100
|
+
type: 'IntegrationUpdate',
|
|
101
|
+
integrations: await this.getIntegrationsConfig(),
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
async syncImmichRepositoryPaths(repositoryId, config, immich) {
|
|
105
|
+
const newPaths = new Set(this.getImmichBackupPaths(config, immich));
|
|
106
|
+
const currentPaths = new Set(await this.repositoryPath.get(repositoryId));
|
|
107
|
+
const toAdd = newPaths.difference(currentPaths);
|
|
108
|
+
const toRemove = currentPaths.difference(newPaths);
|
|
109
|
+
for (const path of toRemove) {
|
|
110
|
+
await this.repositoryPath.delete(repositoryId, path);
|
|
111
|
+
}
|
|
112
|
+
for (const path of toAdd) {
|
|
113
|
+
await this.repositoryPath.create({ id: repositoryId, path });
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
getImmichBackupPaths(config, immich) {
|
|
117
|
+
const paths = [];
|
|
118
|
+
for (const folder of config.dataFolders) {
|
|
119
|
+
if (immich.dataFolders.includes(folder)) {
|
|
120
|
+
paths.push((0, node_path_1.join)(immich.dataPath, folder));
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (config.backupConfiguration) {
|
|
124
|
+
paths.push(this.moduleConfig.get().statePath);
|
|
125
|
+
}
|
|
126
|
+
if (config.libraries === 'all') {
|
|
127
|
+
for (const library of immich.libraries) {
|
|
128
|
+
paths.push(...library.importPaths);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
const selectedIds = new Set(config.libraries);
|
|
133
|
+
for (const library of immich.libraries) {
|
|
134
|
+
if (selectedIds.has(library.id)) {
|
|
135
|
+
paths.push(...library.importPaths);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return [...new Set(paths)];
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
exports.IntegrationsService = IntegrationsService;
|
|
143
|
+
__decorate([
|
|
144
|
+
(0, event_emitter_1.OnEvent)(enum_1.InternalEvent.ModuleConfigUpdated),
|
|
145
|
+
__metadata("design:type", Function),
|
|
146
|
+
__metadata("design:paramtypes", [Object]),
|
|
147
|
+
__metadata("design:returntype", Promise)
|
|
148
|
+
], IntegrationsService.prototype, "onModuleConfigUpdate", null);
|
|
149
|
+
exports.IntegrationsService = IntegrationsService = __decorate([
|
|
150
|
+
(0, common_1.Injectable)(),
|
|
151
|
+
__metadata("design:paramtypes", [events_gateway_1.EventsGateway,
|
|
152
|
+
moduleConfig_repository_1.ModuleConfigRepository,
|
|
153
|
+
repositoryIntegrationImmich_repository_1.RepositoryIntegrationImmichRepository,
|
|
154
|
+
repositoryPath_repository_1.RepositoryPathRepository,
|
|
155
|
+
repository_service_1.RepositoryService,
|
|
156
|
+
schedule_service_1.ScheduleService])
|
|
157
|
+
], IntegrationsService);
|
|
158
|
+
//# sourceMappingURL=integrations.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integrations.service.js","sourceRoot":"","sources":["../../src/services/integrations.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { CurrentRecoveryKeyResponse, OnboardingStatusResponseDto } from '../dto/onboarding.dto';
|
|
2
|
+
import { BackendRepository } from '../repositories/backend.repository';
|
|
3
|
+
import { ConfigRepository } from '../repositories/config.repository';
|
|
4
|
+
import { RepositoryRepository } from '../repositories/repository.repository';
|
|
5
|
+
import { ScheduleRepository } from '../repositories/schedule.repository';
|
|
6
|
+
export declare class OnboardingService {
|
|
7
|
+
private readonly backend;
|
|
8
|
+
private readonly repository;
|
|
9
|
+
private readonly schedule;
|
|
10
|
+
private readonly config;
|
|
11
|
+
constructor(backend: BackendRepository, repository: RepositoryRepository, schedule: ScheduleRepository, config: ConfigRepository);
|
|
12
|
+
onboardingStatus(): Promise<OnboardingStatusResponseDto>;
|
|
13
|
+
currentRecoveryKey(): Promise<CurrentRecoveryKeyResponse>;
|
|
14
|
+
importRecoveryKey(key: string): Promise<void>;
|
|
15
|
+
confirmRecoveryKey(): Promise<void>;
|
|
16
|
+
skipExtraConfig(): Promise<void>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
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.OnboardingService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const backend_repository_1 = require("../repositories/backend.repository");
|
|
15
|
+
const config_repository_1 = require("../repositories/config.repository");
|
|
16
|
+
const repository_repository_1 = require("../repositories/repository.repository");
|
|
17
|
+
const schedule_repository_1 = require("../repositories/schedule.repository");
|
|
18
|
+
let OnboardingService = class OnboardingService {
|
|
19
|
+
backend;
|
|
20
|
+
repository;
|
|
21
|
+
schedule;
|
|
22
|
+
config;
|
|
23
|
+
constructor(backend, repository, schedule, config) {
|
|
24
|
+
this.backend = backend;
|
|
25
|
+
this.repository = repository;
|
|
26
|
+
this.schedule = schedule;
|
|
27
|
+
this.config = config;
|
|
28
|
+
}
|
|
29
|
+
async onboardingStatus() {
|
|
30
|
+
const backends = await this.backend.getBackends();
|
|
31
|
+
const repositories = await this.repository.getAll();
|
|
32
|
+
const schedules = await this.schedule.getAll();
|
|
33
|
+
return {
|
|
34
|
+
hasOnboardedKey: await this.config.hasOnboardedKey(),
|
|
35
|
+
hasBackend: backends.length > 0,
|
|
36
|
+
hasBackup: repositories.length > 0,
|
|
37
|
+
hasSchedule: schedules.length > 0,
|
|
38
|
+
hasSkippedExtraConfig: await this.config.hasSkippedExtraConfig(),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
async currentRecoveryKey() {
|
|
42
|
+
const recoveryKey = await this.config.getMasterEncryptionKey();
|
|
43
|
+
return {
|
|
44
|
+
recoveryKey,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
async importRecoveryKey(key) {
|
|
48
|
+
await this.config.importEncryptionKey(key);
|
|
49
|
+
}
|
|
50
|
+
async confirmRecoveryKey() {
|
|
51
|
+
await this.config.confirmKeyOnboarded();
|
|
52
|
+
}
|
|
53
|
+
async skipExtraConfig() {
|
|
54
|
+
await this.config.skipExtraConfig();
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
exports.OnboardingService = OnboardingService;
|
|
58
|
+
exports.OnboardingService = OnboardingService = __decorate([
|
|
59
|
+
(0, common_1.Injectable)(),
|
|
60
|
+
__metadata("design:paramtypes", [backend_repository_1.BackendRepository,
|
|
61
|
+
repository_repository_1.RepositoryRepository,
|
|
62
|
+
schedule_repository_1.ScheduleRepository,
|
|
63
|
+
config_repository_1.ConfigRepository])
|
|
64
|
+
], OnboardingService);
|
|
65
|
+
//# sourceMappingURL=onboarding.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"onboarding.service.js","sourceRoot":"","sources":["../../src/services/onboarding.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,2EAAuE;AACvE,yEAAqE;AACrE,iFAA6E;AAC7E,6EAAyE;AAGlE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAET;IACA;IACA;IACA;IAJnB,YACmB,OAA0B,EAC1B,UAAgC,EAChC,QAA4B,EAC5B,MAAwB;QAHxB,YAAO,GAAP,OAAO,CAAmB;QAC1B,eAAU,GAAV,UAAU,CAAsB;QAChC,aAAQ,GAAR,QAAQ,CAAoB;QAC5B,WAAM,GAAN,MAAM,CAAkB;IACxC,CAAC;IAEJ,KAAK,CAAC,gBAAgB;QACpB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QAClD,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACpD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAE/C,OAAO;YACL,eAAe,EAAE,MAAM,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;YACpD,UAAU,EAAE,QAAQ,CAAC,MAAM,GAAG,CAAC;YAC/B,SAAS,EAAE,YAAY,CAAC,MAAM,GAAG,CAAC;YAClC,WAAW,EAAE,SAAS,CAAC,MAAM,GAAG,CAAC;YACjC,qBAAqB,EAAE,MAAM,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE;SACjE,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,kBAAkB;QACtB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;QAE/D,OAAO;YACL,WAAW;SACZ,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,GAAW;QACjC,MAAM,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,kBAAkB;QACtB,MAAM,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,MAAM,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;IACtC,CAAC;CACF,CAAA;AAzCY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAGiB,sCAAiB;QACd,4CAAoB;QACtB,wCAAkB;QACpB,oCAAgB;GALhC,iBAAiB,CAyC7B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { FilesystemListingRequestDto, FilesystemListingResponseDto } from '../dto/filesystem.dto';
|
|
3
|
+
import { ListSnapshotsResponseDto, RepositoryCheckImportResponseDto, RepositoryCreateRequestDto, RepositoryCreateResponseDto, RepositoryInspectResponseDto, RepositoryListResponseDto, RepositorySnapshotRestoreFromPointRequestDto, RepositorySnapshotRestoreRequestDto, RepositoryUpdateRequestDto, RepositoryUpdateResponseDto, RunHistoryResponseDto } from '../dto/repository.dto';
|
|
4
|
+
import { EventsGateway } from '../events/events.gateway';
|
|
5
|
+
import { BackendRepository } from '../repositories/backend.repository';
|
|
6
|
+
import { ConfigRepository } from '../repositories/config.repository';
|
|
7
|
+
import { DatabaseRepository } from '../repositories/database.repository';
|
|
8
|
+
import { ModuleConfigRepository } from '../repositories/moduleConfig.repository';
|
|
9
|
+
import { RepositoryRepository } from '../repositories/repository.repository';
|
|
10
|
+
import { RepositoryLocalMetricsRepository } from '../repositories/repositoryLocalMetrics.repository';
|
|
11
|
+
import { RepositoryPathRepository } from '../repositories/repositoryPath.repository';
|
|
12
|
+
import { ResticRepository } from '../repositories/restic.repository';
|
|
13
|
+
import { RunHistoryRepository } from '../repositories/runHistory.repository';
|
|
14
|
+
import { RunningTasksRepository } from '../repositories/runningTasks.repository';
|
|
15
|
+
import { StorageRepository } from '../repositories/storage.repository';
|
|
16
|
+
import { BootstrapService } from './bootstrap.service';
|
|
17
|
+
export declare class RepositoryService {
|
|
18
|
+
private readonly tasks;
|
|
19
|
+
private readonly events;
|
|
20
|
+
private readonly backend;
|
|
21
|
+
private readonly config;
|
|
22
|
+
private readonly database;
|
|
23
|
+
private readonly restic;
|
|
24
|
+
private readonly runHistory;
|
|
25
|
+
private readonly repository;
|
|
26
|
+
private readonly repositoryPath;
|
|
27
|
+
private readonly repositoryLocalMetrics;
|
|
28
|
+
private readonly moduleConfig;
|
|
29
|
+
private readonly storage;
|
|
30
|
+
private readonly bootstrap;
|
|
31
|
+
constructor(tasks: RunningTasksRepository, events: EventsGateway, backend: BackendRepository, config: ConfigRepository, database: DatabaseRepository, restic: ResticRepository, runHistory: RunHistoryRepository, repository: RepositoryRepository, repositoryPath: RepositoryPathRepository, repositoryLocalMetrics: RepositoryLocalMetricsRepository, moduleConfig: ModuleConfigRepository, storage: StorageRepository, bootstrap: BootstrapService);
|
|
32
|
+
private getLocalRepository;
|
|
33
|
+
createRepository(dto: RepositoryCreateRequestDto, backendId?: string): Promise<RepositoryCreateResponseDto>;
|
|
34
|
+
getRepositories(): Promise<RepositoryListResponseDto>;
|
|
35
|
+
inspectRepositories(): Promise<RepositoryInspectResponseDto>;
|
|
36
|
+
private mapSnapshot;
|
|
37
|
+
updateRepository(id: string, dto: RepositoryUpdateRequestDto, backendId?: string): Promise<RepositoryUpdateResponseDto>;
|
|
38
|
+
deleteRepository(id: string): Promise<void>;
|
|
39
|
+
private getResticParameters;
|
|
40
|
+
private updateLocalMetrics;
|
|
41
|
+
createBackup(id: string, signal?: AbortSignal): Promise<{
|
|
42
|
+
logId: string;
|
|
43
|
+
task: Promise<void>;
|
|
44
|
+
}>;
|
|
45
|
+
private runForgetAndPrune;
|
|
46
|
+
pruneRepository(id: string, signal?: AbortSignal): Promise<{
|
|
47
|
+
logId: string;
|
|
48
|
+
task: Promise<void>;
|
|
49
|
+
}>;
|
|
50
|
+
checkImportRepository(id: string, backendId: string): Promise<RepositoryCheckImportResponseDto>;
|
|
51
|
+
importRepository(id: string, backendId: string): Promise<RepositoryCreateResponseDto>;
|
|
52
|
+
getSnapshots(id: string): Promise<ListSnapshotsResponseDto>;
|
|
53
|
+
restoreSnapshot(id: string, snapshotId: string, dto: RepositorySnapshotRestoreRequestDto): Promise<{
|
|
54
|
+
logId: string;
|
|
55
|
+
task: Promise<void>;
|
|
56
|
+
}>;
|
|
57
|
+
restoreFromPoint(id: string, snapshotId: string, backendId: string, dto: RepositorySnapshotRestoreFromPointRequestDto): Promise<{
|
|
58
|
+
logId: string;
|
|
59
|
+
task: Promise<void>;
|
|
60
|
+
}>;
|
|
61
|
+
forgetSnapshot(id: string, snapshotId: string): Promise<void>;
|
|
62
|
+
getSnapshotListing(id: string, snapshotId: string, dto: FilesystemListingRequestDto): Promise<FilesystemListingResponseDto>;
|
|
63
|
+
getRunHistory(id: string): Promise<RunHistoryResponseDto>;
|
|
64
|
+
observableLog(id: string): Observable<MessageEvent>;
|
|
65
|
+
}
|