logger.go 600 B

1234567891011121314151617181920212223
  1. package controller
  2. import (
  3. "fmt"
  4. "net/http"
  5. "time"
  6. "github.com/gorilla/mux"
  7. "github.com/gravitl/netmaker/logger"
  8. "github.com/gravitl/netmaker/logic"
  9. )
  10. func loggerHandlers(r *mux.Router) {
  11. r.HandleFunc("/api/logs", logic.SecurityCheck(true, http.HandlerFunc(getLogs))).Methods("GET")
  12. }
  13. func getLogs(w http.ResponseWriter, r *http.Request) {
  14. var currentTime = time.Now().Format(logger.TimeFormatDay)
  15. var currentFilePath = fmt.Sprintf("data/netmaker.log.%s", currentTime)
  16. logger.DumpFile(currentFilePath)
  17. w.WriteHeader(http.StatusOK)
  18. w.Write([]byte(logger.Retrieve(currentFilePath)))
  19. }