feat: add backup api helpers
This commit is contained in:
@@ -0,0 +1,61 @@
|
|||||||
|
import type { CloudlyApiClient } from './classes.cloudlyapiclient.js';
|
||||||
|
|
||||||
|
export class Backup {
|
||||||
|
public static async createServiceBackup(
|
||||||
|
cloudlyClientRef: CloudlyApiClient,
|
||||||
|
optionsArg: {
|
||||||
|
serviceId: string;
|
||||||
|
clusterId?: string;
|
||||||
|
tags?: Record<string, string>;
|
||||||
|
},
|
||||||
|
) {
|
||||||
|
const request = cloudlyClientRef.typedsocketClient.createTypedRequest<any>(
|
||||||
|
'createServiceBackup',
|
||||||
|
);
|
||||||
|
return await request.fire({
|
||||||
|
identity: cloudlyClientRef.identity,
|
||||||
|
...optionsArg,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static async getServiceBackups(
|
||||||
|
cloudlyClientRef: CloudlyApiClient,
|
||||||
|
optionsArg: {
|
||||||
|
serviceId?: string;
|
||||||
|
status?: string;
|
||||||
|
} = {},
|
||||||
|
) {
|
||||||
|
const request = cloudlyClientRef.typedsocketClient.createTypedRequest<any>(
|
||||||
|
'getServiceBackups',
|
||||||
|
);
|
||||||
|
return await request.fire({
|
||||||
|
identity: cloudlyClientRef.identity,
|
||||||
|
...optionsArg,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static async getBackupById(cloudlyClientRef: CloudlyApiClient, backupIdArg: string) {
|
||||||
|
const request = cloudlyClientRef.typedsocketClient.createTypedRequest<any>('getBackupById');
|
||||||
|
return await request.fire({
|
||||||
|
identity: cloudlyClientRef.identity,
|
||||||
|
backupId: backupIdArg,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static async restoreServiceBackup(
|
||||||
|
cloudlyClientRef: CloudlyApiClient,
|
||||||
|
optionsArg: {
|
||||||
|
backupId: string;
|
||||||
|
clear?: boolean;
|
||||||
|
resourceTypes?: Array<'volume' | 'database' | 'objectstorage'>;
|
||||||
|
},
|
||||||
|
) {
|
||||||
|
const request = cloudlyClientRef.typedsocketClient.createTypedRequest<any>(
|
||||||
|
'restoreServiceBackup',
|
||||||
|
);
|
||||||
|
return await request.fire({
|
||||||
|
identity: cloudlyClientRef.identity,
|
||||||
|
...optionsArg,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -9,6 +9,7 @@ import { SecretBundle } from './classes.secretbundle.js';
|
|||||||
import { SecretGroup } from './classes.secretgroup.js';
|
import { SecretGroup } from './classes.secretgroup.js';
|
||||||
import { ExternalRegistry } from './classes.externalregistry.js';
|
import { ExternalRegistry } from './classes.externalregistry.js';
|
||||||
import { Platform } from './classes.platform.js';
|
import { Platform } from './classes.platform.js';
|
||||||
|
import { Backup } from './classes.backup.js';
|
||||||
|
|
||||||
export class CloudlyApiClient {
|
export class CloudlyApiClient {
|
||||||
private cloudlyUrl: string;
|
private cloudlyUrl: string;
|
||||||
@@ -386,6 +387,21 @@ export class CloudlyApiClient {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public backup = {
|
||||||
|
createServiceBackup: async (optionsArg: Parameters<typeof Backup.createServiceBackup>[1]) => {
|
||||||
|
return Backup.createServiceBackup(this, optionsArg);
|
||||||
|
},
|
||||||
|
getServiceBackups: async (optionsArg: Parameters<typeof Backup.getServiceBackups>[1] = {}) => {
|
||||||
|
return Backup.getServiceBackups(this, optionsArg);
|
||||||
|
},
|
||||||
|
getBackupById: async (backupIdArg: string) => {
|
||||||
|
return Backup.getBackupById(this, backupIdArg);
|
||||||
|
},
|
||||||
|
restoreServiceBackup: async (optionsArg: Parameters<typeof Backup.restoreServiceBackup>[1]) => {
|
||||||
|
return Backup.restoreServiceBackup(this, optionsArg);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
// Settings API
|
// Settings API
|
||||||
public settings = {
|
public settings = {
|
||||||
getSettings: async (): Promise<{
|
getSettings: async (): Promise<{
|
||||||
|
|||||||
Reference in New Issue
Block a user