telnet

package
v1.5.0-rc2 Latest Latest
Warning

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

Go to latest
Published: Jan 4, 2019 License: Apache-2.0 Imports: 8 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// Iac is Interpret as Command
	Iac  byte = 255
	Dont byte = 254
	Do   byte = 253
	Wont byte = 252
	Will byte = 251
	Null byte = 0

	Se  byte = 240 // Subnegotiation End
	Nop byte = 241 // No Operation
	Dm  byte = 242 // Data Mark
	Brk byte = 243 // Break
	IP  byte = 244 // Interrupt process
	Ao  byte = 245 // Abort output
	Ayt byte = 246 // Are You There
	Ec  byte = 247 // Erase Character
	El  byte = 248 // Erase Line
	Ga  byte = 249 // Go Ahead
	Sb  byte = 250 // Subnegotiation Begin

	Binary          byte = 0   // 8-bit data path
	Echo            byte = 1   // echo
	Rcp             byte = 2   // prepare to reconnect
	Sga             byte = 3   // suppress go ahead
	Nams            byte = 4   // approximate message size
	Status          byte = 5   // give status
	Tm              byte = 6   // timing mark
	Rcte            byte = 7   // remote controlled transmission and echo
	Naol            byte = 8   // negotiate about output line width
	Naop            byte = 9   // negotiate about output page size
	Naocrd          byte = 10  // negotiate about CR disposition
	Naohts          byte = 11  // negotiate about horizontal tabstops
	Naohtd          byte = 12  // negotiate about horizontal tab disposition
	Naoffd          byte = 13  // negotiate about formfeed disposition
	Naovts          byte = 14  // negotiate about vertical tab stops
	Naovtd          byte = 15  // negotiate about vertical tab disposition
	Naolfd          byte = 16  // negotiate about output LF disposition
	Xascii          byte = 17  // extended ascii character set
	Logout          byte = 18  // force logout
	Bm              byte = 19  // byte macro
	Det             byte = 20  // data entry terminal
	Supdup          byte = 21  // supdup protocol
	SupdupOutput    byte = 22  // supdup output
	SndLoc          byte = 23  // send location
	Ttype           byte = 24  // terminal type
	Eor             byte = 25  // end or record
	TuID            byte = 26  // TACACS user identification
	OutMrk          byte = 27  // output marking
	TtyLoc          byte = 28  // terminal location number
	Vt3270Regime    byte = 29  // 3270 regime
	X3Pad           byte = 30  // X.3 PAD
	Naws            byte = 31  // window size
	Tspeed          byte = 32  // terminal speed
	Lflow           byte = 33  // remote flow control
	LineMode        byte = 34  // Linemode option
	XDispLoc        byte = 35  // X Display Location
	OldEnviron      byte = 36  // Old - Environment variables
	Authentication  byte = 37  // Authenticate
	Encrypt         byte = 38  // Encryption option
	NewEnviron      byte = 39  // New - Environment variables
	TN3270E         byte = 40  // TN3270E
	XAuth           byte = 41  // XAUTH
	Charset         byte = 42  // CHARSET
	Rsp             byte = 43  // Telnet Remote Serial Port
	ComPortOption   byte = 44  // Com Port Control Option
	SupLocalEcho    byte = 45  // Telnet Suppress Local Echo
	TLS             byte = 46  // Telnet Start TLS
	Kermit          byte = 47  // KERMIT
	SendURL         byte = 48  // SEND-URL
	ForwardX        byte = 49  // FORWARD_X
	PragmaLogon     byte = 138 // TELOPT PRAGMA LOGON
	SspiLogin       byte = 139 // TELOPT SSPI LOGON
	PragmaHeartbeat byte = 140 // TELOPT PRAGMA HEARTBEAT
	ExtOptList      byte = 255 // Extended-Options-List
	NoOp            byte = 0
)

Telnet protocol specific values

Variables

This section is empty.

Functions

This section is empty.

Types

type CloseHandlerFunc

type CloseHandlerFunc func(tc *Conn)

CloseHandlerFunc is the callback function in the event of receiving EOF from the telnet client

type CmdHandlerFunc

type CmdHandlerFunc func(w io.Writer, cmd []byte, tc *Conn)

CmdHandlerFunc is the callback function in the event of receiving a command from the telnet client

type Conn

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

Conn is the struct representing the telnet connection

func (*Conn) IsClosed

func (c *Conn) IsClosed() bool

IsClosed returns true if the connection is already closed

func (*Conn) UnderlyingConnection

func (c *Conn) UnderlyingConnection() net.Conn

UnderlyingConnection returns the underlying TCP connection

func (*Conn) WriteData

func (c *Conn) WriteData(b []byte) (int, error)

WriteData writes telnet data to the underlying connection doubling every IAC

type DataHandlerFunc

type DataHandlerFunc func(w io.Writer, data []byte, tc *Conn)

DataHandlerFunc is the callback function in the event of receiving data from the telnet client

type Handlers

type Handlers struct {
	DataHandler  DataHandlerFunc
	CmdHandler   CmdHandlerFunc
	CloseHandler CloseHandlerFunc
}

type Server

type Server struct {
	ServerOptions map[byte]bool
	ClientOptions map[byte]bool

	Handlers
	// contains filtered or unexported fields
}

Server is the struct representing the telnet server

func NewServer

func NewServer(opts ServerOpts) *Server

NewServer is the constructor of the telnet server

func (*Server) Accept

func (ts *Server) Accept() (*Conn, error)

Accept accepts a connection and returns the Telnet connection

func (*Server) Close added in v1.5.0

func (ts *Server) Close() error

Close call close on the underlying net.Listener and ensures go routines are stopped

type ServerOpts

type ServerOpts struct {
	Addr       string
	ServerOpts []byte
	ClientOpts []byte

	Handlers
}

ServerOpts is the telnet server constructor options

Jump to

Keyboard shortcuts

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