mirror of
https://github.com/yusing/godoxy.git
synced 2025-05-20 12:42:34 +02:00

* feat: idle sleep for proxmox LXCs * refactor: replace deprecated docker api types * chore(api): remove debug task list endpoint * refactor: move servemux to gphttp/servemux; favicon.go to v1/favicon * refactor: introduce Pool interface, move agent_pool to agent module * refactor: simplify api code * feat: introduce debug api * refactor: remove net.URL and net.CIDR types, improved unmarshal handling * chore: update Makefile for debug build tag, update README * chore: add gperr.Unwrap method * feat: relative time and duration formatting * chore: add ROOT_DIR environment variable, refactor * migration: move homepage override and icon cache to $BASE_DIR/data, add migration code * fix: nil dereference on marshalling service health * fix: wait for route deletion * chore: enhance tasks debuggability * feat: stdout access logger and MultiWriter * fix(agent): remove agent properly on verify error * fix(metrics): disk exclusion logic and added corresponding tests * chore: update schema and prettify, fix package.json and Makefile * fix: I/O buffer not being shrunk before putting back to pool * feat: enhanced error handling module * chore: deps upgrade * feat: better value formatting and handling --------- Co-authored-by: yusing <yusing@6uo.me>
69 lines
1.6 KiB
Go
69 lines
1.6 KiB
Go
package dockerapi
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/coder/websocket"
|
|
"github.com/docker/docker/api/types/container"
|
|
"github.com/docker/docker/pkg/stdcopy"
|
|
"github.com/yusing/go-proxy/internal/logging"
|
|
"github.com/yusing/go-proxy/internal/net/gphttp"
|
|
"github.com/yusing/go-proxy/internal/net/gphttp/gpwebsocket"
|
|
"github.com/yusing/go-proxy/internal/utils/strutils"
|
|
)
|
|
|
|
func Logs(w http.ResponseWriter, r *http.Request) {
|
|
query := r.URL.Query()
|
|
server := r.PathValue("server")
|
|
containerID := r.PathValue("container")
|
|
stdout := strutils.ParseBool(query.Get("stdout"))
|
|
stderr := strutils.ParseBool(query.Get("stderr"))
|
|
since := query.Get("from")
|
|
until := query.Get("to")
|
|
levels := query.Get("levels") // TODO: implement levels
|
|
|
|
dockerClient, found, err := getDockerClient(server)
|
|
if err != nil {
|
|
gphttp.BadRequest(w, err.Error())
|
|
return
|
|
}
|
|
if !found {
|
|
gphttp.NotFound(w, "server not found")
|
|
return
|
|
}
|
|
|
|
opts := container.LogsOptions{
|
|
ShowStdout: stdout,
|
|
ShowStderr: stderr,
|
|
Since: since,
|
|
Until: until,
|
|
Timestamps: true,
|
|
Follow: true,
|
|
Tail: "100",
|
|
}
|
|
if levels != "" {
|
|
opts.Details = true
|
|
}
|
|
|
|
logs, err := dockerClient.ContainerLogs(r.Context(), containerID, opts)
|
|
if err != nil {
|
|
gphttp.BadRequest(w, err.Error())
|
|
return
|
|
}
|
|
defer logs.Close()
|
|
|
|
conn, err := gpwebsocket.Initiate(w, r)
|
|
if err != nil {
|
|
return
|
|
}
|
|
defer conn.CloseNow()
|
|
|
|
writer := gpwebsocket.NewWriter(r.Context(), conn, websocket.MessageText)
|
|
_, err = stdcopy.StdCopy(writer, writer, logs) // de-multiplex logs
|
|
if err != nil {
|
|
logging.Err(err).
|
|
Str("server", server).
|
|
Str("container", containerID).
|
|
Msg("failed to de-multiplex logs")
|
|
}
|
|
}
|