backups: make backup download config work

This commit is contained in:
Girish Ramakrishnan
2025-07-28 11:01:46 +02:00
parent b2c94adabf
commit 89388940ed
4 changed files with 176 additions and 108 deletions
+3 -93
View File
@@ -20,18 +20,7 @@ function create() {
if (error || result.status !== 200) return [error || result];
return [null, result.body.backups];
},
async create() {
let error, result;
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/create`, {}, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 202) return [error || result];
return [null, result.body.taskId];
},
async edit(id, label, preserveSecs) {
async update(id, label, preserveSecs) {
// if preserveSecs === -1 we will keep it
let error, result;
try {
@@ -43,94 +32,15 @@ function create() {
if (error || result.status !== 200) return [error || result];
return [null];
},
async getConfig() {
async get(id) {
let error, result;
try {
result = await fetcher.get(`${API_ORIGIN}/api/v1/backups/config`, { access_token: accessToken });
result = await fetcher.get(`${API_ORIGIN}/api/v1/backups/${id}`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
// ensure we have objects
if (!result.body.mountOptions) result.body.mountOptions = {};
if (!result.body.limits) result.body.limits = {};
return [null, result.body];
},
async setConfig(config, limits) {
let error, result;
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/config/storage`, config, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/config/limits`, limits, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null];
},
async getPolicy() {
let error, result;
try {
result = await fetcher.get(`${API_ORIGIN}/api/v1/backups/policy`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body.policy];
},
async setPolicy(policy) {
let error, result;
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/policy`, policy, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null];
},
async cleanup() {
let error, result;
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/cleanup`, {}, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 202) return [error || result];
return [null, result.body.taskId];
},
async mountStatus() {
let error, result;
try {
result = await fetcher.get(`${API_ORIGIN}/api/v1/backups/mount_status`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
},
async remount() {
let error, result;
try {
result = await fetcher.post(`${API_ORIGIN}/api/v1/backups/remount`, {}, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 202) return [error || result];
return [null, result.body];
},
};