blob: ab80a39215c357cbe9572b33d24afe2194c034ee [file] [log] [blame]
Matteo Scandolofb46ae62017-08-08 09:10:50 -07001
2/*
3 * Copyright 2017-present Open Networking Foundation
4
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8
9 * http://www.apache.org/licenses/LICENSE-2.0
10
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
Matteo Scandolo17bf8242017-01-23 17:30:39 -080018export default function XosLogDecorator($provide: ng.auto.IProvideService) {
19 $provide.decorator('$log', function($delegate: any) {
20 const isLogEnabled = () => {
Matteo Scandoloc3804aa2017-08-09 16:00:43 -070021 // NOTE to enable debug, in the browser console set: localStorage.debug = 'true'
22 // NOTE to disable debug, in the browser console set: localStorage.debug = 'false'
Matteo Scandolobcac2dc2017-08-21 14:13:45 -070023 return window.localStorage.getItem('debug-global') === 'true';
Matteo Scandolo17bf8242017-01-23 17:30:39 -080024 };
Matteo Scandoloc3804aa2017-08-09 16:00:43 -070025
26 const isEventLogEnabled = () => {
Matteo Scandolobcac2dc2017-08-21 14:13:45 -070027 return window.localStorage.getItem('debug-events') === 'true';
Matteo Scandoloc3804aa2017-08-09 16:00:43 -070028 };
29
Matteo Scandolo17bf8242017-01-23 17:30:39 -080030 // Save the original $log.debug()
31 let logFn = $delegate.log;
32 let infoFn = $delegate.info;
33 let warnFn = $delegate.warn;
Matteo Scandolo4e870232017-01-30 13:43:05 -080034 // let errorFn = $delegate.error;
Matteo Scandolo17bf8242017-01-23 17:30:39 -080035 let debugFn = $delegate.debug;
36
37 // create the replacement function
38 const replacement = (fn) => {
39 return function(){
Matteo Scandoloc3804aa2017-08-09 16:00:43 -070040 // TODO
41 // Provide more structure a way to group log message and hide/show them
42 // eg: the first parameter is the group name
43
44 const msg = arguments[0];
Matteo Scandolo31daa802017-09-01 12:19:56 -070045
46 if (!isLogEnabled() && msg.indexOf('WebSocket') === -1) {
Matteo Scandolo17bf8242017-01-23 17:30:39 -080047 return;
48 }
49
Matteo Scandolo31daa802017-09-01 12:19:56 -070050 if (!isEventLogEnabled() && msg.indexOf('WebSocket') > -1) {
Matteo Scandoloc3804aa2017-08-09 16:00:43 -070051 return;
52 }
53
Matteo Scandolo17bf8242017-01-23 17:30:39 -080054 let args = [].slice.call(arguments);
55 let now = new Date();
56
57 // Prepend timestamp
Matteo Scandolo47860fe2017-02-02 12:05:55 -080058 args.unshift(`[${now.getHours()}:${now.getMinutes()}:${now.getSeconds()}]`);
Matteo Scandolo17bf8242017-01-23 17:30:39 -080059
60 // Call the original with the output prepended with formatted timestamp
61 fn.apply(null, args);
62 };
63 };
64
65 $delegate.info = replacement(infoFn);
66 $delegate.log = replacement(logFn);
67 $delegate.warn = replacement(warnFn);
Matteo Scandolo4e870232017-01-30 13:43:05 -080068 // $delegate.error = replacement(errorFn); // note this will prevent errors to be printed
Matteo Scandolo17bf8242017-01-23 17:30:39 -080069 $delegate.debug = replacement(debugFn);
70
71 return $delegate;
72 });
73}