feat: enable proxy toggle on quick deploy, event log clearing, and UX fixes
- Add enable_proxy toggle to Quick Deploy form (defaults to on)
- Add DELETE /api/events/log/{id} and DELETE /api/events/log endpoints
- Add Clear All button with confirmation on Events page
- Rename "NPM Proxy" to "Enable Proxy" on stage form (provider-agnostic)
- Fix polling interval validation (min 60s) and number input trim errors
- Fix domain field no longer required in settings
This commit is contained in:
+12
-6
@@ -96,12 +96,13 @@ func (s *Server) inspectImage(w http.ResponseWriter, r *http.Request) {
|
||||
|
||||
// quickDeployRequest is the expected JSON body for POST /api/deploy/quick.
|
||||
type quickDeployRequest struct {
|
||||
Name string `json:"name"`
|
||||
Image string `json:"image"`
|
||||
Tag string `json:"tag"`
|
||||
Registry string `json:"registry"`
|
||||
Port int `json:"port"`
|
||||
Force bool `json:"force"` // skip duplicate check
|
||||
Name string `json:"name"`
|
||||
Image string `json:"image"`
|
||||
Tag string `json:"tag"`
|
||||
Registry string `json:"registry"`
|
||||
Port int `json:"port"`
|
||||
Force bool `json:"force"` // skip duplicate check
|
||||
EnableProxy *bool `json:"enable_proxy"` // nil defaults to true
|
||||
}
|
||||
|
||||
// quickDeploy handles POST /api/deploy/quick.
|
||||
@@ -167,12 +168,17 @@ func (s *Server) quickDeploy(w http.ResponseWriter, r *http.Request) {
|
||||
}
|
||||
|
||||
// Create default stage.
|
||||
enableProxy := true
|
||||
if req.EnableProxy != nil {
|
||||
enableProxy = *req.EnableProxy
|
||||
}
|
||||
stage, err := s.store.CreateStage(store.Stage{
|
||||
ProjectID: project.ID,
|
||||
Name: "dev",
|
||||
TagPattern: "*",
|
||||
AutoDeploy: true,
|
||||
MaxInstances: 1,
|
||||
EnableProxy: enableProxy,
|
||||
})
|
||||
if err != nil {
|
||||
slog.Error("failed to create stage", "error", err)
|
||||
|
||||
@@ -5,6 +5,8 @@ import (
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"github.com/go-chi/chi/v5"
|
||||
|
||||
"github.com/alexei/docker-watcher/internal/store"
|
||||
)
|
||||
|
||||
@@ -46,3 +48,29 @@ func (s *Server) getEventLogStats(w http.ResponseWriter, r *http.Request) {
|
||||
|
||||
respondJSON(w, http.StatusOK, stats)
|
||||
}
|
||||
|
||||
// deleteEvent handles DELETE /api/events/log/{id}.
|
||||
func (s *Server) deleteEvent(w http.ResponseWriter, r *http.Request) {
|
||||
id, err := strconv.ParseInt(chi.URLParam(r, "id"), 10, 64)
|
||||
if err != nil {
|
||||
respondError(w, http.StatusBadRequest, "invalid event ID")
|
||||
return
|
||||
}
|
||||
if err := s.store.DeleteEvent(id); err != nil {
|
||||
slog.Error("failed to delete event", "id", id, "error", err)
|
||||
respondError(w, http.StatusInternalServerError, "internal server error")
|
||||
return
|
||||
}
|
||||
respondJSON(w, http.StatusOK, map[string]string{"status": "deleted"})
|
||||
}
|
||||
|
||||
// clearEvents handles DELETE /api/events/log.
|
||||
func (s *Server) clearEvents(w http.ResponseWriter, r *http.Request) {
|
||||
cleared, err := s.store.ClearAllEvents()
|
||||
if err != nil {
|
||||
slog.Error("failed to clear events", "error", err)
|
||||
respondError(w, http.StatusInternalServerError, "internal server error")
|
||||
return
|
||||
}
|
||||
respondJSON(w, http.StatusOK, map[string]any{"status": "cleared", "count": cleared})
|
||||
}
|
||||
|
||||
@@ -274,6 +274,10 @@ func (s *Server) Router() chi.Router {
|
||||
// Config export (reveals project/infra details).
|
||||
r.Get("/config/export", s.exportConfig)
|
||||
|
||||
// Event log management.
|
||||
r.Delete("/events/log/{id}", s.deleteEvent)
|
||||
r.Delete("/events/log", s.clearEvents)
|
||||
|
||||
// Auth management.
|
||||
r.Get("/auth/settings", s.getAuthSettings)
|
||||
r.Put("/auth/settings", s.updateAuthSettings)
|
||||
|
||||
Reference in New Issue
Block a user