Exemple #1
0
func main() {
	log = logger.New(logger.Config{
		Level:  logger.All,
		Err:    "error.log",
		Warn:   "error.log",
		Debug:  "rec.log",
		Info:   "rec.log",
		Access: "access.log",
	})

	log.Error("Error", logger.Data{
		"data": "Data details here",
	})

	log.Warn("Warning", logger.Data{
		"data": "Data details here",
		"code": 123,
	})

	log.Debug("Debug", logger.Data{
		"data": "Data details here",
		"code": 123,
	})

	log.Info("Info", logger.Data{
		"data": "Data details here",
		"code": 123,
	})

	http.ListenAndServe("10.10.13.25:3000", SampleLogMiddleware(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
		fmt.Fprintf(w, "helllo")
	})))

}
func LoggerMiddleware(h http.Handler) http.Handler {

	return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
		var log *logger.Logger

		log = logger.New(logger.Config{
			Level:  logger.Access,
			Access: "access.log",
		})

		start := time.Now()

		defer func() {
			log.Access(start, w, r)
		}()

		h.ServeHTTP(w, r)
	})

}