-
Notifications
You must be signed in to change notification settings - Fork 4
/
logging.go
67 lines (59 loc) · 2.2 KB
/
logging.go
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
///////////////////////////////////////////////////////////////////////////////
//
// The MIT License (MIT)
// Copyright (c) 2017 Tom Kralidis
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
// USE OR OTHER DEALINGS IN THE SOFTWARE.
//
///////////////////////////////////////////////////////////////////////////////
package geocatalogo
import (
"os"
"github.com/go-spatial/geocatalogo/config"
"github.com/sirupsen/logrus"
)
// LogLevels provides a mapping between configuration and logging
// level types
var LogLevels = map[string]logrus.Level{
"DEBUG": logrus.DebugLevel,
"INFO": logrus.InfoLevel,
"WARN": logrus.WarnLevel,
"ERROR": logrus.ErrorLevel,
"FATAL": logrus.FatalLevel,
"NONE": logrus.PanicLevel,
}
// InitLog initializes the logging facility
func InitLog(cfg *config.Config, log *logrus.Logger) error {
// set defaults
log.Level = logrus.PanicLevel
log.Out = os.Stderr
log.Formatter = new(logrus.TextFormatter)
log.Hooks = make(logrus.LevelHooks)
// set to optionally write to logfile
if cfg.Logging.Logfile != "" {
f, err := os.OpenFile(cfg.Logging.Logfile, os.O_WRONLY|os.O_CREATE, 0644)
if err != nil {
return err
}
log.Out = f
}
// set debug level
log.SetLevel(LogLevels[cfg.Logging.Level])
return nil
}