/
logger.go
81 lines (67 loc) · 2.44 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
81
/*
* VM Auto Scaling API
*
* The VM Auto Scaling Service enables IONOS clients to horizontally scale the number of VM replicas based on configured rules. You can use VM Auto Scaling to ensure that you have a sufficient number of replicas to handle your application loads at all times. For this purpose, create a VM Auto Scaling Group that contains the server replicas. The VM Auto Scaling Service ensures that the number of replicas in the group is always within the defined limits. When scaling policies are set, VM Auto Scaling creates or deletes replicas according to the requirements of your applications. For each policy, specified 'scale-in' and 'scale-out' actions are performed when the corresponding thresholds are reached.
*
* API version: 1-SDK.1
* Contact: support@cloud.ionos.com
*/
// 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...)
}