| /** |
| * A module which contains the definition of the application and the base of configuration |
| * |
| * @module app/index/services/index |
| * @exports app/index |
| * |
| * @author Developer Developer |
| * @version 0.10.0 |
| * @since 0.0.1 |
| */ |
| |
| window.angular && (function (angular) { |
| 'use strict'; |
| |
| angular |
| .module('app', [ |
| // Dependencies |
| 'ngRoute', |
| 'angular-clipboard', |
| 'angularUtils.directives.dirPagination', |
| // Basic resources |
| 'app.constants', |
| 'app.templates', |
| 'app.vendors', |
| 'app.common.services', |
| 'app.common.directives', |
| 'app.common.filters', |
| // Model resources |
| 'app.login', |
| 'app.overview', |
| 'app.serverControl', |
| 'app.serverHealth', |
| 'app.configuration', |
| 'app.users', |
| 'app.multiServer' |
| ]) |
| // Route configuration |
| .config(['$routeProvider', '$locationProvider', function ($routeProvider, $locationProvider) { |
| $locationProvider.hashPrefix(''); |
| $routeProvider |
| .otherwise({ |
| 'redirectTo': '/login' |
| }); |
| }]) |
| .config(['$compileProvider', function ($compileProvider) { |
| $compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|ftp|mailto|tel|file|data|blob):/); |
| }]) |
| .config(['$httpProvider', function($httpProvider){ |
| $httpProvider.defaults.timeout = 20000; |
| $httpProvider.interceptors.push('apiInterceptor'); |
| }]) |
| .run(['$rootScope', '$location', 'dataService', 'userModel', |
| function($rootScope, $location, dataService, userModel){ |
| $rootScope.dataService = dataService; |
| dataService.path = $location.path(); |
| $rootScope.$on('$routeChangeStart', function(event, next, current){ |
| |
| if(next.$$route == null || next.$$route == undefined) return; |
| if(next.$$route.authenticated){ |
| if(!userModel.isLoggedIn()){ |
| $location.path('/login'); |
| } |
| } |
| |
| if(next.$$route.originalPath == '/' || |
| next.$$route.originalPath == '/login'){ |
| if(userModel.isLoggedIn()){ |
| if(current && current.$$route){ |
| $location.path(current.$$route.originalPath); |
| }else{ |
| $location.path('/overview/server'); |
| } |
| } |
| } |
| }); |
| $rootScope.$on('$locationChangeSuccess', function(event){ |
| var path = $location.path(); |
| dataService.path = path; |
| if(['/','/login','/logout'].indexOf(path) == -1 && |
| path.indexOf('/login') == -1){ |
| dataService.showNavigation = true; |
| }else{ |
| dataService.showNavigation = false; |
| } |
| }); |
| |
| $rootScope.$on('timedout-user', function(){ |
| if(sessionStorage.getItem('LOGIN_ID') == 'FAKE_ID'){ |
| return; |
| } |
| |
| sessionStorage.removeItem('LOGIN_ID'); |
| $location.path('/login'); |
| }); |
| } |
| ]); |
| |
| })(window.angular); |