2025-01-03 15:06:41 +01:00
|
|
|
|
|
|
|
|
import { ROLES } from '../constants.js';
|
|
|
|
|
import { fetcher } from 'pankow';
|
|
|
|
|
|
|
|
|
|
function create(origin, accessToken) {
|
|
|
|
|
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 [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
result.body.isAtLeastAdmin = [ ROLES.OWNER, ROLES.ADMIN ].indexOf(result.body.role) !== -1;
|
|
|
|
|
|
|
|
|
|
return result.body;
|
|
|
|
|
},
|
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;
|
|
|
|
|
},
|
2025-01-14 11:09:13 +01:00
|
|
|
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,
|
|
|
|
|
};
|