-
Notifications
You must be signed in to change notification settings - Fork 0
/
logger.go
80 lines (66 loc) · 1.85 KB
/
logger.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
68
69
70
71
72
73
74
75
76
77
78
79
80
/*
* IONOS Cloud - Object Storage Management API
*
* Object Storage Management API is a RESTful API that manages the object storage service configuration for IONOS Cloud.
*
* API version: 0.1.0
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package ionoscloud
import (
"log"
"os"
"strings"
)
type LogLevel uint
func (l *LogLevel) Get() LogLevel {
if l != nil {
return *l
}
return Off
}
// Satisfies returns true if this LogLevel is at least high enough for v
func (l *LogLevel) Satisfies(v LogLevel) bool {
return l.Get() >= v
}
const (
Off LogLevel = 0x100 * iota
Debug
// Trace We recommend you only set this field for debugging purposes.
// Disable it in your production environments because it can log sensitive data.
// It logs the full request and response without encryption, even for an HTTPS call.
// Verbose request and response logging can also significantly impact your application's performance.
Trace
)
var LogLevelMap = map[string]LogLevel{
"off": Off,
"debug": Debug,
"trace": Trace,
}
// getLogLevelFromEnv - gets LogLevel type from env variable IONOS_LOG_LEVEL
// returns Off if an invalid log level is encountered
func getLogLevelFromEnv() LogLevel {
strLogLevel := "off"
if os.Getenv(IonosLogLevelEnvVar) != "" {
strLogLevel = os.Getenv(IonosLogLevelEnvVar)
}
logLevel, ok := LogLevelMap[strings.ToLower(strLogLevel)]
if !ok {
log.Printf("Cannot set logLevel for value: %s, setting loglevel to Off", strLogLevel)
}
return logLevel
}
type Logger interface {
Printf(format string, args ...interface{})
}
func NewDefaultLogger() Logger {
return &defaultLogger{
logger: log.New(os.Stderr, "IONOSLOG ", log.LstdFlags),
}
}
type defaultLogger struct {
logger *log.Logger
}
func (l defaultLogger) Printf(format string, args ...interface{}) {
l.logger.Printf(format, args...)
}