Files
2026-02-04 23:11:19 +01:00

139 lines
3.3 KiB
Go

package node
import (
"context"
"encoding/json"
"net/http"
"github.com/moby/moby/api/types/container"
"github.com/moby/moby/client"
log "gitlab.com/gdulai/simpleloglvl"
)
type BuildCommand struct {
Repository string `json:"repository"`
Branch string `json:"branch"`
Descriptor string `json:"descriptor"`
}
func HandleBuild(w http.ResponseWriter, r *http.Request) {
}
func build(command BuildCommand) {
}
func HandleStart(w http.ResponseWriter, r *http.Request) {
requestId := r.Context().Value("requestId")
decoder := json.NewDecoder(r.Body)
var containerId string
err := decoder.Decode(&containerId)
if err != nil {
log.LogError("Failed to decode node/start request body! (%s)\n%s", requestId, err)
w.WriteHeader(http.StatusBadRequest)
return
}
if containerId == "" {
log.LogError("Container id mus be specified for node/start! (%s)", requestId)
w.WriteHeader(http.StatusBadRequest)
return
}
err = start(containerId)
if err == nil {
log.LogInfo("Successfully container start: %s (%s)", containerId, requestId)
w.WriteHeader(http.StatusOK)
} else {
log.LogInfo("Failed container start! (%s)\n%s", requestId, err)
w.WriteHeader(http.StatusInternalServerError)
}
}
func start(containerId string) error {
cli := openDockerClient()
_, err := cli.ContainerStart(context.Background(), containerId, client.ContainerStartOptions{})
if err != nil {
return err
}
return nil
}
func HandleStop(w http.ResponseWriter, r *http.Request) {
requestId := r.Context().Value("requestId")
decoder := json.NewDecoder(r.Body)
var containerId string
err := decoder.Decode(&containerId)
if err != nil {
log.LogError("Failed to decode node/stop request body! (%s)", requestId)
w.WriteHeader(http.StatusBadRequest)
return
}
if containerId == "" {
log.LogError("Container id must be specified for node/stop! (%s)", requestId)
w.WriteHeader(http.StatusBadRequest)
return
}
err = stop(containerId)
if err == nil {
log.LogInfo("Successfully container stop: %s (%s)", containerId, requestId)
w.WriteHeader(http.StatusOK)
} else {
log.LogInfo("Failed container stop! (%s)\n%s", requestId, err)
w.WriteHeader(http.StatusInternalServerError)
}
}
func stop(containerId string) error {
cli := openDockerClient()
_, err := cli.ContainerStop(context.Background(), containerId, client.ContainerStopOptions{})
if err != nil {
return err
}
return nil
}
func HandleInfo(w http.ResponseWriter, r *http.Request) {
json.NewEncoder(w).Encode(info())
}
func info() []container.Summary {
cli := openDockerClient()
// List all containers (running and stopped)
containers, err := cli.ContainerList(context.Background(), client.ContainerListOptions{
All: true,
})
if err != nil {
log.LogFatalError("Failed to list containers: %v", err)
}
var summaries []container.Summary
// Print container info
for _, c := range containers.Items {
summaries = append(summaries, c)
name := ""
if len(c.Names) > 0 {
name = c.Names[0]
}
log.LogInfo("ID: %s Name: %s Image: %s Status: %s\n",
c.ID[:12], name, c.Image, c.Status)
}
return summaries
}
func openDockerClient() *client.Client {
cli, err := client.NewClientWithOpts(
client.FromEnv,
client.WithHost("unix:///var/run/docker.sock"),
)
if err != nil {
log.LogFatalError("Failed to create Docker client: %v", err)
}
return cli
}