- auto redirect from ./ to ./admin - enabled two auth flows (admin and update) - disabled auth for admin by skipping env variable DDNS_ADMIN_LOGIN - introduced optional env variable DDNS_TITLE for dynamic UI title (default TheBBCloudDynDNS) - set copyright date in footer dynamic on startup - moved all remote js/css packages into static in order to avoid external dependencies - added "copy to clipboard button" on host overview page - replaced all fmt.Println to log... - introduced new optional env variable DDNS_CLEAR_LOG_INTERVAL to clear logs after n days (int). (check runs daily once if update request received) - newest logs are shown from top to button on logs page
67 lines
1.8 KiB
Go
67 lines
1.8 KiB
Go
package handler
|
|
|
|
import (
|
|
"log"
|
|
"net/http"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/benjaminbear/docker-ddns-server/dyndns/model"
|
|
"github.com/labstack/echo/v4"
|
|
)
|
|
|
|
// CreateLogEntry simply adds a log entry to the database.
|
|
func (h *Handler) CreateLogEntry(log *model.Log) (err error) {
|
|
if err = h.DB.Create(log).Error; err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// ShowLogs fetches all log entries from all hosts and renders them to the website.
|
|
func (h *Handler) ShowLogs(c echo.Context) (err error) {
|
|
if !h.AuthAdmin {
|
|
return c.JSON(http.StatusUnauthorized, &Error{UNAUTHORIZED})
|
|
}
|
|
|
|
logs := new([]model.Log)
|
|
if err = h.DB.Preload("Host").Limit(30).Order("created_at desc").Find(logs).Error; err != nil {
|
|
return c.JSON(http.StatusBadRequest, &Error{err.Error()})
|
|
}
|
|
|
|
return c.Render(http.StatusOK, "listlogs", echo.Map{
|
|
"logs": logs,
|
|
"title": h.Title,
|
|
})
|
|
}
|
|
|
|
// ShowHostLogs fetches all log entries of a specific host by "id" and renders them to the website.
|
|
func (h *Handler) ShowHostLogs(c echo.Context) (err error) {
|
|
if !h.AuthAdmin {
|
|
return c.JSON(http.StatusUnauthorized, &Error{UNAUTHORIZED})
|
|
}
|
|
|
|
id, err := strconv.Atoi(c.Param("id"))
|
|
if err != nil {
|
|
return c.JSON(http.StatusBadRequest, &Error{err.Error()})
|
|
}
|
|
|
|
logs := new([]model.Log)
|
|
if err = h.DB.Preload("Host").Where(&model.Log{HostID: uint(id)}).Order("created_at desc").Limit(30).Find(logs).Error; err != nil {
|
|
return c.JSON(http.StatusBadRequest, &Error{err.Error()})
|
|
}
|
|
|
|
return c.Render(http.StatusOK, "listlogs", echo.Map{
|
|
"logs": logs,
|
|
"title": h.Title,
|
|
})
|
|
}
|
|
|
|
func (h *Handler) ClearLogs() {
|
|
var clearInterval = strconv.FormatUint(h.ClearInterval, 10) + " days"
|
|
h.DB.Exec("DELETE FROM LOGS WHERE created_at < datetime('now', '" + clearInterval + "');REINDEX LOGS;")
|
|
h.LastClearedLogs = time.Now()
|
|
log.Print("logs cleared")
|
|
}
|