mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2025-04-04 00:17:06 +00:00
This adds a new section to the admin panel called "Activity", that supplies charts, graphs and details about messages entering and leaving the host. A new daemon captures details of system mail activity by monitoring the /var/log/mail.log file, summarizing it into a sqllite database that's kept in user-data.
93 lines
2.9 KiB
JavaScript
93 lines
2.9 KiB
JavaScript
class Me {
|
|
/* construct with return value from GET /me */
|
|
constructor(me) {
|
|
Object.assign(this, me);
|
|
}
|
|
|
|
is_authenticated() {
|
|
return this.api_key || this.user_id;
|
|
}
|
|
|
|
get_email() {
|
|
return this.user_email || this.user_id;
|
|
}
|
|
};
|
|
|
|
|
|
/*
|
|
* axios interceptors for authentication
|
|
*/
|
|
|
|
function init_axios_interceptors() {
|
|
|
|
// requests: attach non-session based auth (admin panel)
|
|
axios.interceptors.request.use(request => {
|
|
var api_credentials = null;
|
|
// code from templates/index.html for "recall saved user
|
|
// credentials" (but, without the split(':'))
|
|
if (typeof sessionStorage != 'undefined' && sessionStorage.getItem("miab-cp-credentials"))
|
|
api_credentials = sessionStorage.getItem("miab-cp-credentials");
|
|
else if (typeof localStorage != 'undefined' && localStorage.getItem("miab-cp-credentials"))
|
|
api_credentials = localStorage.getItem("miab-cp-credentials");
|
|
// end
|
|
|
|
if (api_credentials) {
|
|
request.headers.authorization = 'Basic ' + window.btoa(api_credentials);
|
|
}
|
|
return request;
|
|
});
|
|
|
|
|
|
// reponses: redirect on authorization failure
|
|
axios.interceptors.response.use(
|
|
response => {
|
|
if (response.data &&
|
|
response.data.status === 'invalid' &&
|
|
response.config.headers.authorization)
|
|
{
|
|
var url = response.config.url;
|
|
if (response.config.baseURL) {
|
|
var sep = ( response.config.baseURL.substr(-1) != '/' ?
|
|
'/' : '' );
|
|
url = response.config.baseURL + sep + url;
|
|
}
|
|
|
|
if (url == '/admin/me')
|
|
{
|
|
// non-session/admin login
|
|
throw new AuthenticationError(
|
|
null,
|
|
'not authenticated',
|
|
response
|
|
);
|
|
}
|
|
}
|
|
return response;
|
|
},
|
|
|
|
error => {
|
|
const auth_required_msg = 'Authentication required - you have been logged out of the server';
|
|
if (! error.response) {
|
|
throw error;
|
|
}
|
|
|
|
if (error.response.status == 403 &&
|
|
error.response.data == 'login_required')
|
|
{
|
|
// session login
|
|
throw new AuthenticationError(error, auth_required_msg);
|
|
}
|
|
else if ((error.response.status == 403 ||
|
|
error.response.status == 401) &&
|
|
error.response.data &&
|
|
error.response.data.status == 'error')
|
|
{
|
|
// admin
|
|
throw new AuthenticationError(error, auth_required_msg);
|
|
}
|
|
throw error;
|
|
}
|
|
);
|
|
}
|
|
|