socket

package
v0.0.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 15, 2022 License: AGPL-3.0 Imports: 25 Imported by: 0

Documentation

Index

Constants

View Source
const (
	OpStdout = "stdout"
	OpStdin  = "stdin"
	OpResize = "resize"
	OpToast  = "toast"
)
View Source
const END_OF_TRANSMISSION = "\u0004"
View Source
const ETX = "\u0003"

Variables

Functions

func GenMyPtyHandlerId

func GenMyPtyHandlerId() (string, error)

GenMyPtyHandlerId generates a random session ID string. The format is not really interesting. This ID is used to identify the session when the client opens the SockJS connection. Not the same as the SockJS session id! We can't use that as that is generated on the client side and we don't have it yet at this point.

func HandleExecShell

func HandleExecShell(input *websocket_pb.WsHandleExecShellInput, conn *WsConn) (string, error)

func HandleWsAuthorize

func HandleWsAuthorize(c *WsConn, t websocket_pb.Type, message []byte)

func HandleWsHandleCloseShell

func HandleWsHandleCloseShell(c *WsConn, t websocket_pb.Type, message []byte)

func HandleWsHandleExecShell

func HandleWsHandleExecShell(c *WsConn, t websocket_pb.Type, message []byte)

func HandleWsHandleExecShellMsg

func HandleWsHandleExecShellMsg(c *WsConn, t websocket_pb.Type, message []byte)

func WaitForTerminal

func WaitForTerminal(conn *WsConn, k8sClient kubernetes.Interface, cfg *rest.Config, container *Container, shell, sessionId string)

WaitForTerminal is called from apihandler.handleAttach as a goroutine Waits for the SockJS connection to be opened by the client the session to be bound in handleMyPtyHandler

Types

type Container

type Container struct {
	Namespace string `json:"namespace"`
	Pod       string `json:"pod"`
	Container string `json:"container"`
	ClusterID int64  `json:"cluster_id"`
}

type HandleRequestFunc

type HandleRequestFunc func(c *WsConn, t websocket_pb.Type, message []byte)

type Msger

type Msger interface {
	SendEndError(error)
	SendError(error)
	SendMsg(string)
	SendProtoMsg(plugins.WebsocketMessage)
}

func NewMessageSender

func NewMessageSender(conn *WsConn, slugName string, wsType websocket_pb.Type) Msger

type MyPtyHandler

type MyPtyHandler struct {
	Container
	// contains filtered or unexported fields
}

func (*MyPtyHandler) Close

func (t *MyPtyHandler) Close(reason string)

func (*MyPtyHandler) Next

func (*MyPtyHandler) Read

func (t *MyPtyHandler) Read(p []byte) (n int, err error)

func (*MyPtyHandler) Toast

func (t *MyPtyHandler) Toast(p string) error

Toast can be used to send the user any OOB messages hterm puts these in the center of the terminal

func (*MyPtyHandler) Write

func (t *MyPtyHandler) Write(p []byte) (n int, err error)

type PtyHandler

type PtyHandler interface {
	io.Reader
	io.Writer
	remotecommand.TerminalSizeQueue
}

PtyHandler is what remotecommand expects from a pty

type SessionMap

type SessionMap struct {
	Sessions map[string]*MyPtyHandler
	// contains filtered or unexported fields
}

SessionMap stores a map of all MyPtyHandler objects and a sessLock to avoid concurrent conflict

func (*SessionMap) Close

func (sm *SessionMap) Close(sessionId string, status uint32, reason string)

Close shuts down the SockJS connection and sends the status code and reason to the client Can happen if the process exits or if there is an error starting up the process For now the status code is unused and reason is shown to the user (unless "")

func (*SessionMap) CloseAll

func (sm *SessionMap) CloseAll()

func (*SessionMap) Get

func (sm *SessionMap) Get(sessionId string) (*MyPtyHandler, bool)

Get return a given terminalSession by sessionId

func (*SessionMap) Send

func (*SessionMap) Set

func (sm *SessionMap) Set(sessionId string, session *MyPtyHandler)

Set store a MyPtyHandler to SessionMap

type SessionMapper

type SessionMapper interface {
	Send(message *websocket_pb.TerminalMessage)
	Get(sessionId string) (*MyPtyHandler, bool)
	Set(sessionId string, session *MyPtyHandler)
	CloseAll()
	Close(sessionId string, status uint32, reason string)
}

type TerminalResponse

type TerminalResponse struct {
	ID string `json:"id"`
}

type WaitSocketExit

type WaitSocketExit struct {
	// contains filtered or unexported fields
}

func NewWaitSocketExit

func NewWaitSocketExit() *WaitSocketExit

func (*WaitSocketExit) Count

func (w *WaitSocketExit) Count() int

func (*WaitSocketExit) Dec

func (w *WaitSocketExit) Dec()

func (*WaitSocketExit) Inc

func (w *WaitSocketExit) Inc()

func (*WaitSocketExit) Wait

func (w *WaitSocketExit) Wait()

type WebsocketManager

type WebsocketManager struct{}

func NewWebsocketManager

func NewWebsocketManager() *WebsocketManager

func (*WebsocketManager) Info

func (wc *WebsocketManager) Info(writer http.ResponseWriter, request *http.Request)

func (*WebsocketManager) Ws

type WsConn

type WsConn struct {
	// contains filtered or unexported fields
}

func (*WsConn) GetShellChannel

func (c *WsConn) GetShellChannel(sessionID string) (chan *websocket_pb.TerminalMessage, error)

func (*WsConn) GetUser

func (c *WsConn) GetUser() contracts.UserInfo

func (*WsConn) SetUser

func (c *WsConn) SetUser(info contracts.UserInfo)

func (*WsConn) Shutdown

func (c *WsConn) Shutdown()

type WsResponse

type WsResponse = websocket_pb.WsMetadataResponse

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL