mirror of https://github.com/portainer/portainer
38 lines
1.2 KiB
Go
38 lines
1.2 KiB
Go
package endpointedge
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
httperror "github.com/portainer/libhttp/error"
|
|
|
|
"github.com/gorilla/mux"
|
|
portainer "github.com/portainer/portainer/api"
|
|
"github.com/portainer/portainer/api/dataservices"
|
|
"github.com/portainer/portainer/api/http/security"
|
|
)
|
|
|
|
// Handler is the HTTP handler used to handle edge environment(endpoint) operations.
|
|
type Handler struct {
|
|
*mux.Router
|
|
requestBouncer *security.RequestBouncer
|
|
DataStore dataservices.DataStore
|
|
FileService portainer.FileService
|
|
ReverseTunnelService portainer.ReverseTunnelService
|
|
}
|
|
|
|
// NewHandler creates a handler to manage environment(endpoint) operations.
|
|
func NewHandler(bouncer *security.RequestBouncer) *Handler {
|
|
h := &Handler{
|
|
Router: mux.NewRouter(),
|
|
requestBouncer: bouncer,
|
|
}
|
|
|
|
h.Handle("/{id}/edge/status",
|
|
bouncer.PublicAccess(httperror.LoggerHandler(h.endpointEdgeStatusInspect))).Methods(http.MethodGet)
|
|
h.Handle("/{id}/edge/stacks/{stackId}",
|
|
bouncer.PublicAccess(httperror.LoggerHandler(h.endpointEdgeStackInspect))).Methods(http.MethodGet)
|
|
h.Handle("/{id}/edge/jobs/{jobID}/logs",
|
|
bouncer.PublicAccess(httperror.LoggerHandler(h.endpointEdgeJobsLogs))).Methods(http.MethodPost)
|
|
return h
|
|
}
|