Add dcae-cli and component-json-schemas projects
[dcaegen2/platform/cli.git] / dcae-cli / dcae_cli / util / logger.py
1 # ============LICENSE_START=======================================================
2 # org.onap.dcae
3 # ================================================================================
4 # Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
5 # ================================================================================
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #      http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 # ============LICENSE_END=========================================================
18 #
19 # ECOMP is a trademark and service mark of AT&T Intellectual Property.
20
21 # -*- coding: utf-8 -*-
22 """
23 Provides logger utilities
24 """
25 import logging
26
27 import click
28
29
30 class ClickHandler(logging.StreamHandler):
31
32     def emit(self, record):
33         msg = self.format(record)
34         click.echo(msg)
35
36
37 _clihandler = ClickHandler()
38 _formatter = logging.Formatter('%(name)s | %(levelname)s | %(message)s')
39 _clihandler.setFormatter(_formatter)
40
41 _root = logging.getLogger('DCAE')
42 _root.setLevel(logging.WARNING)
43 _root.handlers = [_clihandler, ]
44 _root.propagate = False
45
46
47 def get_logger(name=None):
48     return _root if name is None else _root.getChild(name)
49
50
51 def set_verbose():
52     _root.setLevel(logging.INFO)
53
54
55 def set_quiet():
56     _root.setLevel(logging.WARNING)