Migrate first parts of backups view to vue

This commit is contained in:
Johannes Zellner
2025-02-04 15:10:38 +01:00
parent 55939f6320
commit 776e65bc5e
10 changed files with 631 additions and 16 deletions
+72
View File
@@ -0,0 +1,72 @@
import { fetcher } from 'pankow';
function create() {
const accessToken = localStorage.token;
const origin = import.meta.env.VITE_API_ORIGIN || window.location.origin;
return {
async list() {
const page = 1;
const per_page = 1000;
let error, result;
try {
result = await fetcher.get(`${origin}/api/v1/backups`, { page, per_page, access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body.backups];
},
async getConfig() {
let error, result;
try {
result = await fetcher.get(`${origin}/api/v1/backups/config`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
},
async getPolicy() {
let error, result;
try {
result = await fetcher.get(`${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(`${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(`${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];
},
};
}
export default {
create,
};