78 lines
1.8 KiB
Go
78 lines
1.8 KiB
Go
|
// Copyright (C) 2015 Scaleway. All rights reserved.
|
||
|
// Use of this source code is governed by a MIT-style
|
||
|
// license that can be found in the LICENSE.md file.
|
||
|
|
||
|
package api
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"os"
|
||
|
)
|
||
|
|
||
|
// Logger handles logging concerns for the Scaleway API SDK
|
||
|
type Logger interface {
|
||
|
LogHTTP(*http.Request)
|
||
|
Fatalf(format string, v ...interface{})
|
||
|
Debugf(format string, v ...interface{})
|
||
|
Infof(format string, v ...interface{})
|
||
|
Warnf(format string, v ...interface{})
|
||
|
}
|
||
|
|
||
|
// NewDefaultLogger returns a logger which is configured for stdout
|
||
|
func NewDefaultLogger() Logger {
|
||
|
return &defaultLogger{
|
||
|
Logger: log.New(os.Stdout, "", log.LstdFlags),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
type defaultLogger struct {
|
||
|
*log.Logger
|
||
|
}
|
||
|
|
||
|
func (l *defaultLogger) LogHTTP(r *http.Request) {
|
||
|
l.Printf("%s %s\n", r.Method, r.URL.RawPath)
|
||
|
}
|
||
|
|
||
|
func (l *defaultLogger) Fatalf(format string, v ...interface{}) {
|
||
|
l.Printf("[FATAL] %s\n", fmt.Sprintf(format, v))
|
||
|
os.Exit(1)
|
||
|
}
|
||
|
|
||
|
func (l *defaultLogger) Debugf(format string, v ...interface{}) {
|
||
|
l.Printf("[DEBUG] %s\n", fmt.Sprintf(format, v))
|
||
|
}
|
||
|
|
||
|
func (l *defaultLogger) Infof(format string, v ...interface{}) {
|
||
|
l.Printf("[INFO ] %s\n", fmt.Sprintf(format, v))
|
||
|
}
|
||
|
|
||
|
func (l *defaultLogger) Warnf(format string, v ...interface{}) {
|
||
|
l.Printf("[WARN ] %s\n", fmt.Sprintf(format, v))
|
||
|
}
|
||
|
|
||
|
type disableLogger struct {
|
||
|
}
|
||
|
|
||
|
// NewDisableLogger returns a logger which is configured to do nothing
|
||
|
func NewDisableLogger() Logger {
|
||
|
return &disableLogger{}
|
||
|
}
|
||
|
|
||
|
func (d *disableLogger) LogHTTP(r *http.Request) {
|
||
|
}
|
||
|
|
||
|
func (d *disableLogger) Fatalf(format string, v ...interface{}) {
|
||
|
panic(fmt.Sprintf(format, v))
|
||
|
}
|
||
|
|
||
|
func (d *disableLogger) Debugf(format string, v ...interface{}) {
|
||
|
}
|
||
|
|
||
|
func (d *disableLogger) Infof(format string, v ...interface{}) {
|
||
|
}
|
||
|
|
||
|
func (d *disableLogger) Warnf(format string, v ...interface{}) {
|
||
|
}
|