2015-12-09 04:35:05 +01:00
|
|
|
angular
|
|
|
|
.module('bit')
|
|
|
|
|
|
|
|
.config(function ($stateProvider, $urlRouterProvider, $httpProvider, jwtInterceptorProvider, $uibTooltipProvider, toastrConfig) {
|
2016-07-14 01:49:26 +02:00
|
|
|
jwtInterceptorProvider.urlParam = 'access_token';
|
2015-12-09 04:35:05 +01:00
|
|
|
jwtInterceptorProvider.tokenGetter = /*@ngInject*/ function (config, appSettings, tokenService) {
|
|
|
|
if (config.url.indexOf(appSettings.apiUri) === 0) {
|
|
|
|
return tokenService.getToken();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
angular.extend(toastrConfig, {
|
|
|
|
closeButton: true,
|
|
|
|
progressBar: true,
|
|
|
|
showMethod: 'slideDown',
|
|
|
|
target: '.toast-target'
|
|
|
|
});
|
|
|
|
|
|
|
|
$uibTooltipProvider.options({
|
|
|
|
popupDelay: 600
|
|
|
|
});
|
|
|
|
|
2016-07-14 01:49:26 +02:00
|
|
|
if ($httpProvider.defaults.headers.post) {
|
|
|
|
$httpProvider.defaults.headers.post = {};
|
2015-12-09 04:35:05 +01:00
|
|
|
}
|
|
|
|
|
2016-07-14 01:49:26 +02:00
|
|
|
$httpProvider.defaults.headers.post['Content-Type'] = 'text/plain; charset=utf-8';
|
2015-12-09 04:35:05 +01:00
|
|
|
|
|
|
|
$httpProvider.interceptors.push('apiInterceptor');
|
|
|
|
$httpProvider.interceptors.push('jwtInterceptor');
|
|
|
|
|
|
|
|
$urlRouterProvider.otherwise('/');
|
|
|
|
|
|
|
|
$stateProvider
|
|
|
|
// Backend
|
|
|
|
.state('backend', {
|
|
|
|
templateUrl: 'app/views/backendLayout.html',
|
|
|
|
abstract: true,
|
|
|
|
data: {
|
|
|
|
authorize: true
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('backend.vault', {
|
|
|
|
url: '^/',
|
|
|
|
templateUrl: 'app/vault/views/vault.html',
|
|
|
|
controller: 'vaultController',
|
|
|
|
data: { pageTitle: 'My Vault' }
|
|
|
|
})
|
|
|
|
.state('backend.settings', {
|
|
|
|
url: '^/settings',
|
|
|
|
templateUrl: 'app/settings/views/settings.html',
|
|
|
|
controller: 'settingsController',
|
|
|
|
data: { pageTitle: 'Settings' }
|
|
|
|
})
|
|
|
|
.state('backend.tools', {
|
|
|
|
url: '^/tools',
|
|
|
|
templateUrl: 'app/tools/views/tools.html',
|
|
|
|
controller: 'toolsController',
|
|
|
|
data: { pageTitle: 'Tools' }
|
|
|
|
})
|
|
|
|
|
|
|
|
// Frontend
|
|
|
|
.state('frontend', {
|
|
|
|
templateUrl: 'app/views/frontendLayout.html',
|
|
|
|
abstract: true,
|
|
|
|
data: {
|
|
|
|
authorize: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('frontend.login', {
|
|
|
|
templateUrl: 'app/accounts/views/accountsLogin.html',
|
|
|
|
controller: 'accountsLoginController',
|
|
|
|
data: {
|
|
|
|
bodyClass: 'login-page'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('frontend.login.info', {
|
|
|
|
url: '^/login',
|
|
|
|
templateUrl: 'app/accounts/views/accountsLoginInfo.html',
|
|
|
|
data: {
|
|
|
|
pageTitle: 'Log In'
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('frontend.login.twoFactor', {
|
|
|
|
url: '^/login/two-factor',
|
|
|
|
templateUrl: 'app/accounts/views/accountsLoginTwoFactor.html',
|
|
|
|
data: {
|
|
|
|
pageTitle: 'Log In (Two Factor)',
|
|
|
|
authorizeTwoFactor: true
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('frontend.logout', {
|
|
|
|
url: '^/logout',
|
|
|
|
controller: 'accountsLogoutController',
|
|
|
|
data: {
|
|
|
|
authorize: true
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('frontend.passwordHint', {
|
|
|
|
url: '^/password-hint',
|
|
|
|
templateUrl: 'app/accounts/views/accountsPasswordHint.html',
|
|
|
|
controller: 'accountsPasswordHintController',
|
|
|
|
data: {
|
|
|
|
pageTitle: 'Master Password Hint',
|
|
|
|
bodyClass: 'login-page'
|
|
|
|
}
|
|
|
|
})
|
2016-11-15 05:31:54 +01:00
|
|
|
.state('frontend.recover', {
|
|
|
|
url: '^/recover',
|
|
|
|
templateUrl: 'app/accounts/views/accountsRecover.html',
|
|
|
|
controller: 'accountsRecoverController',
|
|
|
|
data: {
|
|
|
|
pageTitle: 'Recover Account',
|
|
|
|
bodyClass: 'login-page'
|
|
|
|
}
|
|
|
|
})
|
2015-12-09 04:35:05 +01:00
|
|
|
.state('frontend.register', {
|
|
|
|
url: '^/register',
|
|
|
|
templateUrl: 'app/accounts/views/accountsRegister.html',
|
|
|
|
controller: 'accountsRegisterController',
|
|
|
|
data: {
|
|
|
|
pageTitle: 'Register',
|
|
|
|
bodyClass: 'register-page'
|
|
|
|
}
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.run(function ($rootScope, authService, jwtHelper, tokenService, $state) {
|
|
|
|
$rootScope.$on('$stateChangeStart', function (event, toState, toParams) {
|
|
|
|
if (!toState.data || !toState.data.authorize) {
|
|
|
|
if (authService.isAuthenticated() && !jwtHelper.isTokenExpired(tokenService.getToken())) {
|
|
|
|
event.preventDefault();
|
|
|
|
$state.go('backend.vault');
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!authService.isAuthenticated() || jwtHelper.isTokenExpired(tokenService.getToken())) {
|
|
|
|
event.preventDefault();
|
|
|
|
authService.logOut();
|
|
|
|
$state.go('frontend.login.info');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|