131 lines
3.8 KiB
JavaScript
131 lines
3.8 KiB
JavaScript
import ngModule from '../module';
|
|
import UserError from 'core/lib/user-error';
|
|
|
|
/**
|
|
* Authentication service.
|
|
*
|
|
* @property {Boolean} loggedIn Whether the user is currently logged
|
|
*/
|
|
export default class Auth {
|
|
constructor($http, $q, $state, $transitions, $window, vnToken, vnModules, aclService) {
|
|
Object.assign(this, {
|
|
$http,
|
|
$q,
|
|
$state,
|
|
$transitions,
|
|
$window,
|
|
vnToken,
|
|
vnModules,
|
|
aclService,
|
|
loggedIn: false
|
|
});
|
|
}
|
|
|
|
initialize() {
|
|
let criteria = {
|
|
to: state => {
|
|
const outLayout = ['login', 'recover-password', 'reset-password', 'change-password', 'validate-email'];
|
|
return !outLayout.some(ol => ol == state.name);
|
|
}
|
|
};
|
|
this.$transitions.onStart(criteria, transition => {
|
|
if (this.loggedIn)
|
|
return true;
|
|
|
|
let redirectToLogin = () => {
|
|
return transition.router.stateService.target('login', {
|
|
continue: this.$window.location.hash
|
|
});
|
|
};
|
|
|
|
if (this.vnToken.token) {
|
|
return this.loadAcls()
|
|
.then(() => true)
|
|
.catch(redirectToLogin);
|
|
} else
|
|
return redirectToLogin();
|
|
});
|
|
}
|
|
|
|
login(user, password, remember) {
|
|
if (!user) {
|
|
let err = new UserError('Please enter your username');
|
|
err.code = 'EmptyLogin';
|
|
return this.$q.reject(err);
|
|
}
|
|
|
|
let params = {
|
|
user,
|
|
password: password || undefined
|
|
};
|
|
|
|
const now = new Date();
|
|
return this.$http.post('VnUsers/sign-in', params).then(
|
|
json => this.onLoginOk(json, now, remember));
|
|
}
|
|
|
|
validateCode(user, password, code, remember) {
|
|
if (!user) {
|
|
let err = new UserError('Please enter your username');
|
|
err.code = 'EmptyLogin';
|
|
return this.$q.reject(err);
|
|
}
|
|
|
|
let params = {
|
|
user: user,
|
|
password: password || undefined,
|
|
code: code
|
|
};
|
|
|
|
const now = new Date();
|
|
return this.$http.post('VnUsers/validate-auth', params)
|
|
.then(json => this.onLoginOk(json, now, remember));
|
|
}
|
|
|
|
onLoginOk(json, now, remember) {
|
|
return this.$http.get('VnUsers/ShareToken', {
|
|
headers: {Authorization: json.data.token}
|
|
}).then(({data}) => {
|
|
this.vnToken.set(json.data.token, data.multimediaToken.id, now, json.data.ttl, remember);
|
|
this.loadAcls().then(() => {
|
|
let continueHash = this.$state.params.continue;
|
|
if (continueHash)
|
|
this.$window.location = continueHash;
|
|
else
|
|
this.$state.go('home');
|
|
});
|
|
}).catch(() => {});
|
|
}
|
|
|
|
logout() {
|
|
this.$http.post('Accounts/logout', null, {headers: {'Authorization': this.vnToken.tokenMultimedia},
|
|
}).catch(() => {});
|
|
|
|
let promise = this.$http.post('VnUsers/logout', null, {
|
|
headers: {Authorization: this.vnToken.token}
|
|
}).catch(() => {});
|
|
this.vnToken.unset();
|
|
this.loggedIn = false;
|
|
this.vnModules.reset();
|
|
this.aclService.reset();
|
|
this.$state.go('login');
|
|
|
|
return promise;
|
|
}
|
|
|
|
loadAcls() {
|
|
return this.aclService.load()
|
|
.then(() => {
|
|
this.loggedIn = true;
|
|
this.vnModules.reset();
|
|
})
|
|
.catch(err => {
|
|
this.vnToken.unset();
|
|
throw err;
|
|
});
|
|
}
|
|
}
|
|
Auth.$inject = ['$http', '$q', '$state', '$transitions', '$window', 'vnToken', 'vnModules', 'aclService'];
|
|
|
|
ngModule.service('vnAuth', Auth);
|