blob: 39f5a6669f35386e7c6b26ee0494764759846931 [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
18
Matteo Scandolo17bf8242017-01-23 17:30:39 -080019export default function XosLogDecorator($provide: ng.auto.IProvideService) {
20 $provide.decorator('$log', function($delegate: any) {
21 const isLogEnabled = () => {
Matteo Scandolo1aee1982017-02-17 08:33:23 -080022 // NOTE to enable debug, in the broser console set: localStorage.debug = 'true'
23 // NOTE to disable debug, in the broser console set: localStorage.debug = 'false'
24 return window.localStorage.getItem('debug') === 'true';
Matteo Scandolo17bf8242017-01-23 17:30:39 -080025 };
26 // Save the original $log.debug()
27 let logFn = $delegate.log;
28 let infoFn = $delegate.info;
29 let warnFn = $delegate.warn;
Matteo Scandolo4e870232017-01-30 13:43:05 -080030 // let errorFn = $delegate.error;
Matteo Scandolo17bf8242017-01-23 17:30:39 -080031 let debugFn = $delegate.debug;
32
33 // create the replacement function
34 const replacement = (fn) => {
35 return function(){
36 if (!isLogEnabled()) {
37 return;
38 }
39
40 let args = [].slice.call(arguments);
41 let now = new Date();
42
43 // Prepend timestamp
Matteo Scandolo47860fe2017-02-02 12:05:55 -080044 args.unshift(`[${now.getHours()}:${now.getMinutes()}:${now.getSeconds()}]`);
Matteo Scandolo17bf8242017-01-23 17:30:39 -080045
46 // Call the original with the output prepended with formatted timestamp
47 fn.apply(null, args);
48 };
49 };
50
51 $delegate.info = replacement(infoFn);
52 $delegate.log = replacement(logFn);
53 $delegate.warn = replacement(warnFn);
Matteo Scandolo4e870232017-01-30 13:43:05 -080054 // $delegate.error = replacement(errorFn); // note this will prevent errors to be printed
Matteo Scandolo17bf8242017-01-23 17:30:39 -080055 $delegate.debug = replacement(debugFn);
56
57 return $delegate;
58 });
59}