mirror of
				https://github.com/nabbar/golib.git
				synced 2025-10-31 11:06:23 +08:00 
			
		
		
		
	 f31950daef
			
		
	
	f31950daef
	
	
	
		
			
			- Rework logger - Remove deprecated functions - Split Logger to sub package (fields, level, config, ...) - Optimize dependencies - Rework Hookfile: fix error like FD still opened - Rework Hooksyslog: use same model like Hookfile, use network/protocol instead of self lib - Rework HookStd: use independent hook for std out & std err - Fix std config make generic options for files & syslog - Apply formatter to hook instead of main logger entry - optimize code Package ioutils: - rework PathCheckCreate funct: optimize code & fix some error Package Network: - create sub package protocol for all network protocl use - add encode function Package httpcli: - remove file network - use package network/protocol instead of network file Package archive: - apply change following rework of logger Package aws: - apply change following rework of logger Package cluster: - apply change following rework of logger Package cobra: - apply change following rework of logger Package Config Component: - apply change following rework of logger to component log - fix logger for monitoring - fix component following fix of package request / monitoring Package context: - apply change following rework of logger Package database: - apply change following rework of logger Package httpserver: - apply change following rework of logger Package ldap: - apply change following rework of logger Package monitor: - apply change following rework of logger - fix logger for monitoring - fix minor bugs Package nats: - apply change following rework of logger Package nutsdb: - apply change following rework of logger Package request: - apply change following rework of logger - fix minor bug - fix missing logger for monitoring - add one line for healthcheck (info or error) Package router: - apply change following rework of logger Package static: - apply change following rework of logger Package status: - apply change following rework of logger - fix bug with mandatory component Package viper: - apply change following rework of logger Other: - bump dependencies - github action workflow fix
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /***********************************************************************************************************************
 | |
|  *
 | |
|  *   MIT License
 | |
|  *
 | |
|  *   Copyright (c) 2021 Nicolas JUHEL
 | |
|  *
 | |
|  *   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 entry
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| 
 | |
| 	ginsdk "github.com/gin-gonic/gin"
 | |
| 	liberr "github.com/nabbar/golib/errors"
 | |
| 	logfld "github.com/nabbar/golib/logger/fields"
 | |
| 	loglvl "github.com/nabbar/golib/logger/level"
 | |
| 	"github.com/sirupsen/logrus"
 | |
| )
 | |
| 
 | |
| type Entry interface {
 | |
| 	SetLogger(fct func() *logrus.Logger) Entry
 | |
| 	SetLevel(lvl loglvl.Level) Entry
 | |
| 	SetMessageOnly(flag bool) Entry
 | |
| 	SetEntryContext(etime time.Time, stack uint64, caller, file string, line uint64, msg string) Entry
 | |
| 	SetGinContext(ctx *ginsdk.Context) Entry
 | |
| 
 | |
| 	DataSet(data interface{}) Entry
 | |
| 	Check(lvlNoErr loglvl.Level) bool
 | |
| 	Log()
 | |
| 
 | |
| 	FieldAdd(key string, val interface{}) Entry
 | |
| 	FieldMerge(fields logfld.Fields) Entry
 | |
| 	FieldSet(fields logfld.Fields) Entry
 | |
| 	FieldClean(keys ...string) Entry
 | |
| 
 | |
| 	ErrorClean() Entry
 | |
| 	ErrorSet(err []error) Entry
 | |
| 	ErrorAdd(cleanNil bool, err ...error) Entry
 | |
| 	ErrorAddLib(cleanNil bool, err ...liberr.Error) Entry
 | |
| }
 | |
| 
 | |
| func New(lvl loglvl.Level) Entry {
 | |
| 	return &entry{
 | |
| 		log:    nil,
 | |
| 		gin:    nil,
 | |
| 		clean:  false,
 | |
| 		Level:  lvl,
 | |
| 		Time:   time.Now(),
 | |
| 		Error:  make([]error, 0),
 | |
| 		Data:   nil,
 | |
| 		Fields: nil,
 | |
| 	}
 | |
| }
 |