mirror of
https://github.com/d0zingcat/gocryptotrader.git
synced 2026-05-13 15:09:42 +00:00
* logger: reduce go routine generation * logger: shift most of processing and prep work to the worker pool, add pool for fields because each log we are pushing the struct to the heap, has better segregation now and includes a buffer in scope instead of relying on a pool * logger: shift fmt package calls to worker pool * logger: conform tests to new design * linter: fix issues * Update log/logger_test.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * Update log/logger_test.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * UN-GLORIOUS: nits * logger: Handle config variable * logger: NITERINOS BY GLORIOUS CODE * logger: revert * glorious: nits * Panic at the disco: fix * Panic at the disco: fix * logger: make sure logger closed and job channel emptied on start up error * fix tests * logger: reduce globals * logger: finished reduces globals, reduce workers to one too keep everything in line. * logger: remove comments * logger/exhchange: linter issues * db/test: fix linter * logger: add tests shift wait before unlock * logger: consolidate worker code; fix linter issue and make sure we can sustain writing for external testing. * logger: fix race and warn for conflict in config * logger: fix name and add to tests * logger: remove zero value field * glorious: panic fix and removal of code * logger: reinstate channels in close * logger: shift reinstate processing to SetupGlobalLogger * logger: segregate config.json from internal log.Config * logger: fix silly mistake that is silly * engine: Add protection for nil issues and implement new constructor in tests * logger: Force singular mutex usage throughout package, throw away funcs that are not used outside of this package, unexport a bunch. Fix tests. * logger: actually set advanced settings * Update log/loggers.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * Update log/loggers.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * Update log/loggers.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * Update log/loggers.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * Update log/logger_multiwriter.go Co-authored-by: Scott <gloriousCode@users.noreply.github.com> * glorious: nits * logger: test issue when not purging temp file and contents * loggertest: add more protections for the panics * linter: fix * glorious: nits * cleanup * logger: linter fix * linter: fix(?) :/ * linter: revert change * linter: fix Co-authored-by: Scott <gloriousCode@users.noreply.github.com> Co-authored-by: Ryan O'Hara-Reid <ryan.oharareid@thrasher.io>
253 lines
6.5 KiB
Go
253 lines
6.5 KiB
Go
package log
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
)
|
|
|
|
// Info takes a pointer subLogger struct and string sends to StageLogEvent
|
|
func Info(sl *SubLogger, data string) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.info {
|
|
fields.output.StageLogEvent(func() string { return data },
|
|
fields.logger.InfoHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Infoln takes a pointer subLogger struct and interface sends to StageLogEvent
|
|
func Infoln(sl *SubLogger, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.info {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintln(v...) },
|
|
fields.logger.InfoHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Infof takes a pointer subLogger struct, string and interface formats sends to StageLogEvent
|
|
func Infof(sl *SubLogger, data string, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.info {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintf(data, v...) },
|
|
fields.logger.InfoHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Debug takes a pointer subLogger struct and string sends to StageLogEvent
|
|
func Debug(sl *SubLogger, data string) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.debug {
|
|
fields.output.StageLogEvent(func() string { return data },
|
|
fields.logger.DebugHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Debugln takes a pointer subLogger struct, string and interface sends to StageLogEvent
|
|
func Debugln(sl *SubLogger, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.debug {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintln(v...) },
|
|
fields.logger.DebugHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Debugf takes a pointer subLogger struct, string and interface formats sends to StageLogEvent
|
|
func Debugf(sl *SubLogger, data string, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.debug {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintf(data, v...) },
|
|
fields.logger.DebugHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Warn takes a pointer subLogger struct & string and sends to StageLogEvent
|
|
func Warn(sl *SubLogger, data string) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.warn {
|
|
fields.output.StageLogEvent(func() string { return data },
|
|
fields.logger.WarnHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Warnln takes a pointer subLogger struct & interface formats and sends to StageLogEvent
|
|
func Warnln(sl *SubLogger, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.warn {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintln(v...) },
|
|
fields.logger.WarnHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Warnf takes a pointer subLogger struct, string and interface formats sends to StageLogEvent
|
|
func Warnf(sl *SubLogger, data string, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.warn {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintf(data, v...) },
|
|
fields.logger.WarnHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Error takes a pointer subLogger struct & interface formats and sends to StageLogEvent
|
|
func Error(sl *SubLogger, data ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.error {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprint(data...) },
|
|
fields.logger.ErrorHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Errorln takes a pointer subLogger struct, string & interface formats and sends to StageLogEvent
|
|
func Errorln(sl *SubLogger, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.error {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintln(v...) },
|
|
fields.logger.ErrorHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
// Errorf takes a pointer subLogger struct, string and interface formats sends to StageLogEvent
|
|
func Errorf(sl *SubLogger, data string, v ...interface{}) {
|
|
mu.RLock()
|
|
defer mu.RUnlock()
|
|
fields := sl.getFields()
|
|
if fields == nil {
|
|
return
|
|
}
|
|
if fields.error {
|
|
fields.output.StageLogEvent(func() string { return fmt.Sprintf(data, v...) },
|
|
fields.logger.ErrorHeader,
|
|
fields.name,
|
|
fields.logger.Spacer,
|
|
fields.logger.TimestampFormat,
|
|
fields.logger.ShowLogSystemName,
|
|
fields.logger.BypassJobChannelFilledWarning)
|
|
}
|
|
logFieldsPool.Put(fields)
|
|
}
|
|
|
|
func displayError(err error) {
|
|
if err != nil {
|
|
log.Printf("Logger write error: %v\n", err)
|
|
}
|
|
}
|