Files
cloudron-box/dashboard/src/models/UpdaterModel.js
T

59 lines
1.5 KiB
JavaScript
Raw Normal View History

2025-01-24 14:00:33 +01:00
import { fetcher } from 'pankow';
2025-01-31 21:02:48 +01:00
function create() {
const accessToken = localStorage.token;
const origin = import.meta.env.VITE_API_ORIGIN || window.location.origin;
2025-01-24 14:00:33 +01:00
return {
async info() {
let error, result;
try {
result = await fetcher.get(`${origin}/api/v1/updater/updates`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body.update];
},
async getAutoupdatePattern() {
let error, result;
try {
result = await fetcher.get(`${origin}/api/v1/updater/autoupdate_pattern`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
},
async setAutoupdatePattern(pattern) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/updater/autoupdate_pattern`, { pattern }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null];
},
async check() {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/updater/check_for_updates`, {}, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null];
},
};
}
export default {
create,
};