1 Star 0 Fork 0

infrastlabs / fk-container-web-tty

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
log.go 2.04 KB
一键复制 编辑 原始数据 按行查看 历史
package route
import (
"net/http"
"github.com/gin-gonic/gin"
log "github.com/sirupsen/logrus"
"github.com/yudai/gotty/webtty"
"gitee.com/infrastlabs/fk-container-web-tty/types"
"gitee.com/infrastlabs/fk-container-web-tty/util"
)
func (server *Server) handleLogs(c *gin.Context) {
ctx := c.Request.Context()
conn, err := server.upgrader.Upgrade(c.Writer, c.Request, nil)
if err != nil {
c.String(http.StatusInternalServerError, "server error: %s", err)
return
}
defer conn.Close()
initArg, err := server.readInitMessage(conn)
if err != nil {
c.String(http.StatusBadRequest, "read init message error: %s", err)
return
}
q, err := parseQuery(initArg)
if err != nil {
c.String(http.StatusBadRequest, err.Error())
return
}
follow := true
if v := q.Get("follow"); v != "1" && v != "" {
follow = false
}
tail := "10"
if v := q.Get("tail"); v != "" {
tail = v
}
opts := types.LogOptions{
ID: c.Param("cid"),
Follow: follow,
Tail: tail,
}
// container := server.containerCli.GetInfo(ctx, "containerd://7092b551cb8a28b37f424f5a860ea0d6fd0333ee7d35e50f626ccf9ea44c6635") //opts.ID)
container := server.containerCli.GetInfo(ctx, opts.ID)
log.Debugf("get logs of container: %s", container.ID)
logsReadCloser, err := server.containerCli.Logs(ctx, opts)
if err != nil {
c.String(http.StatusInternalServerError, "get logs error: %s", err)
return
}
defer logsReadCloser.Close()
titleBuf, err := server.makeTitleBuff(container)
if err != nil {
c.String(http.StatusInternalServerError, "failed to fill window title template: %s", err)
return
}
tty, err := webtty.New(
&wsWrapper{conn},
newSlave(util.NopRWCloser(logsReadCloser)),
[]webtty.Option{
webtty.WithWindowTitle(titleBuf),
webtty.WithPermitWrite(), // can type "enter"
}...,
)
if err != nil {
c.String(http.StatusInternalServerError, "failed to create webtty: %s", err)
return
}
if err := tty.Run(ctx); err != nil {
if err != webtty.ErrMasterClosed && err != webtty.ErrSlaveClosed {
log.Errorf("failed to run webtty: %s", err)
}
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/infrastlabs/fk-container-web-tty.git
git@gitee.com:infrastlabs/fk-container-web-tty.git
infrastlabs
fk-container-web-tty
fk-container-web-tty
v0.2.2

搜索帮助

344bd9b3 5694891 D2dac590 5694891