2016-12-18 05:21:29 +00:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/portainer/portainer"
|
|
|
|
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
2016-12-25 20:34:02 +00:00
|
|
|
|
|
|
|
"github.com/gorilla/mux"
|
2016-12-18 05:21:29 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// SettingsHandler represents an HTTP API handler for managing settings.
|
|
|
|
type SettingsHandler struct {
|
|
|
|
*mux.Router
|
|
|
|
Logger *log.Logger
|
|
|
|
middleWareService *middleWareService
|
|
|
|
settings *portainer.Settings
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewSettingsHandler returns a new instance of SettingsHandler.
|
|
|
|
func NewSettingsHandler(middleWareService *middleWareService) *SettingsHandler {
|
|
|
|
h := &SettingsHandler{
|
|
|
|
Router: mux.NewRouter(),
|
|
|
|
Logger: log.New(os.Stderr, "", log.LstdFlags),
|
|
|
|
middleWareService: middleWareService,
|
|
|
|
}
|
|
|
|
h.HandleFunc("/settings", h.handleGetSettings)
|
|
|
|
return h
|
|
|
|
}
|
|
|
|
|
|
|
|
// handleGetSettings handles GET requests on /settings
|
|
|
|
func (handler *SettingsHandler) handleGetSettings(w http.ResponseWriter, r *http.Request) {
|
2016-12-25 20:34:02 +00:00
|
|
|
if r.Method != http.MethodGet {
|
|
|
|
handleNotAllowed(w, []string{http.MethodGet})
|
2016-12-18 05:21:29 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
encodeJSON(w, handler.settings, handler.Logger)
|
|
|
|
}
|