blob: ec5318462460c931253a7615bff4b6fad7f8c484 [file] [log] [blame]
/*-
* ============LICENSE_START==========================================
* ONAP Portal
* ===================================================================
* Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
* ===================================================================
*
* Unless otherwise specified, all software contained herein is licensed
* under the Apache License, Version 2.0 (the "License");
* you may not use this software except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Unless otherwise specified, all documentation contained herein is licensed
* under the Creative Commons License, Attribution 4.0 Intl. (the "License");
* you may not use this documentation except in compliance with the License.
* You may obtain a copy of the License at
*
* https://creativecommons.org/licenses/by/4.0/
*
* Unless required by applicable law or agreed to in writing, documentation
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* ============LICENSE_END============================================
*
*
*/
'use strict';
var app = angular.module('ecompApp', [
'ngCookies',
'ngResource',
'ngSanitize',
'ui.router',
'ecomp.conf',
'ngMessages',
'ui.select',
'angular-cache',
'ngDialog',
'gridster',
'angular-gestures',
'uuid',
'ui.bootstrap',
'ngMaterial',
'oc.lazyLoad',
'b2b.att'
])
.config(($stateProvider, $urlRouterProvider, $locationProvider, $httpProvider, ngDialogProvider, $controllerProvider, hammerDefaultOptsProvider, $sanitizeProvider) => {
app.controllerProvider = $controllerProvider;
$urlRouterProvider.otherwise('/error404');
$locationProvider.html5Mode(true);
//initialize get if not there
if (!$httpProvider.defaults.headers.get) {
$httpProvider.defaults.headers.get = {};
}
var myHostName;
myHostName = location.host;
//withCredentials flag on the XHR object - add cookie to XHR requests
if (!(myHostName.includes("localhost"))) { // Don't load this for Mock
$httpProvider.defaults.withCredentials = true;
}
$httpProvider.defaults.useXDomain = true;
$httpProvider.defaults.timeout = 30000;
//default configuration for ngDialog modal
ngDialogProvider.setDefaults({
className: 'ngdialog-theme-default',
showClose: true,
closeByDocument: false,
closeByEscape: false
});
//hammer defaults for gestures
hammerDefaultOptsProvider.set({
recognizers: [[Hammer.Pan, 'enabled']]
});
if (!(myHostName.includes("localhost"))) {
$httpProvider.defaults.headers.get['If-Modified-Since'] = 'Mon, 26 Jul 1997 05:00:00 GMT';
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
}
//interceptor here:
var interceptor = function ($q, $injector, $log) {
return {
'responseError': function (rejection) {
$log.error('Interceptor rejection: ' + JSON.stringify(rejection));
var $state = $injector.get('$state');
var $sanitize = $injector.get('$sanitize');
switch (rejection.status) {
case 401:
var globalLoginUrl = rejection.headers()['global-login-url'];
if (globalLoginUrl) {
window.location = $sanitize(globalLoginUrl +
(globalLoginUrl.indexOf('?') === -1 ? '?' : '') +
'&retUrl=' + encodeURI(window.location));
return;
}
break;
default:
//handle internal server error
}
return $q.reject(rejection);
}
};
};
$httpProvider.interceptors.push(interceptor);
}).run(($http, CacheFactory) => {
//default configuration for cache factory
$http.defaults.cache = CacheFactory('defaultCache', {
maxAge: 15 * 60 * 1000, // Items added to this cache expire after 15 minutes
cacheFlushInterval: 60 * 60 * 1000, // This cache will clear itself every hour
deleteOnExpire: 'aggressive' // Items will be deleted from this cache when they expire
});
});
angular.module( 'ecompApp' ).config( [
'$compileProvider',
function( $compileProvider )
{
$compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|ftp|mailto|chrome-extension):/);
}
]);