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

172 lines
4.7 KiB
JavaScript
Raw Normal View History

2025-01-03 15:06:41 +01:00
import { ROLES } from '../constants.js';
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-03 15:06:41 +01:00
return {
name: 'ProfileModel',
2025-01-14 14:52:10 +01:00
async logout() {
// destroy oidc session in the spirit of true SSO
await fetcher.del(`${origin}/api/v1/oidc/sessions`, { access_token: accessToken });
localStorage.removeItem('token');
window.location.href = '/';
},
2025-01-03 15:06:41 +01:00
async get() {
let error, result;
try {
result = await fetcher.get(`${origin}/api/v1/profile`, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) {
console.error('Failed to get profile.', error || result.status);
return [];
}
2025-02-04 15:10:38 +01:00
if (error || result.status !== 200) return [error || result];
2025-01-03 15:06:41 +01:00
result.body.isAtLeastAdmin = [ ROLES.OWNER, ROLES.ADMIN ].indexOf(result.body.role) !== -1;
2025-02-04 15:10:38 +01:00
result.body.isAtLeastOwner = [ ROLES.OWNER ].indexOf(result.body.role) !== -1;
2025-01-03 15:06:41 +01:00
2025-02-04 15:10:38 +01:00
return [null, result.body];
2025-01-03 15:06:41 +01:00
},
2025-01-14 14:52:10 +01:00
async setPassword(password, newPassword) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/password`, { password, newPassword }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 204) return result;
return null;
},
2025-01-14 10:27:27 +01:00
async setDisplayName(displayName) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/display_name`, { displayName }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 204) return result;
return null;
},
async setEmail(email, password) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/email`, { email, password }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 204) return result;
return null;
},
2025-01-14 11:54:19 +01:00
async setFallbackEmail(fallbackEmail, password) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/fallback_email`, { fallbackEmail, password }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 204) return result;
return null;
},
2025-01-14 10:27:27 +01:00
async setLanguage(language) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/language`, { language }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 204) return result;
2025-01-14 11:54:19 +01:00
return null;
},
2025-01-14 14:52:10 +01:00
async setAvatar(file) {
const fd = new FormData();
fd.append('avatar', file);
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/avatar`, fd, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 202) return result;
return null;
},
2025-01-14 11:54:19 +01:00
async sendPasswordReset(identifier) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/auth/password_reset_request`, { identifier }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error) return error;
if (result.status !== 202) return result;
2025-01-14 10:27:27 +01:00
return null;
},
2025-01-16 17:27:12 +01:00
async setTwoFASecret() {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/twofactorauthentication_secret`, {}, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 200) return [error || result];
return [null, result.body];
},
async enableTwoFA(totpToken) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/twofactorauthentication_enable`, { totpToken }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 204) return [error || result];
return [null];
},
async disableTwoFA(password) {
let error, result;
try {
result = await fetcher.post(`${origin}/api/v1/profile/twofactorauthentication_disable`, { password }, { access_token: accessToken });
} catch (e) {
error = e;
}
if (error || result.status !== 204) return [error || result];
return [null];
},
2025-01-03 15:06:41 +01:00
};
}
export default {
create,
};