summaryrefslogtreecommitdiff
path: root/service/pixelated/config/logger.py
blob: 52ecc4ed0a0fad321bc9906d6f4f6de06f11a22b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#
# Copyright (c) 2014 ThoughtWorks, Inc.
#
# Pixelated is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Pixelated is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with Pixelated. If not, see <http://www.gnu.org/licenses/>.

import logging
import os
from twisted.python import log


def init(debug=False):
    debug_enabled = debug or os.environ.get('DEBUG', False)
    logging_level = logging.DEBUG if debug_enabled else logging.WARN
    log_format = "%(asctime)s [%(name)s] %(levelname)s %(message)s"
    date_format = '%Y-%m-%d %H:%M:%S'

    logging.basicConfig(level=logging_level,
                        format=log_format,
                        datefmt=date_format,
                        filemode='a')

    observer = log.PythonLoggingObserver()
    logging.getLogger('pixelated').setLevel(logging.INFO)
    observer.start()