mirror of
https://github.com/bstansell/conserver.git
synced 2025-01-08 22:12:38 +00:00
303 lines
12 KiB
Plaintext
303 lines
12 KiB
Plaintext
Conserver Protocol
|
|
==================
|
|
|
|
|
|
What Is This?
|
|
-------------
|
|
|
|
The following is an attempt to describe the client/server protocol used
|
|
between the server (conserver) and the client (console). This document
|
|
bases its information on conserver version 8.1.4, as it's the release
|
|
currently available. If there are changes to the client/server
|
|
protocol, the INSTALL file should reference them and, ideally, this
|
|
document will be updated.
|
|
|
|
The information is looked at from the point of the server, since it's
|
|
the server that controls all information and triggers actions on the
|
|
client (like a suspend). The client's perspective should be obvious
|
|
from this information.
|
|
|
|
|
|
SSL
|
|
---
|
|
|
|
The client and server can negotiate an SSL connection. As far as the
|
|
code is concerned, the SSL "layer" is transparent. Data is sent and
|
|
received just as if it was unencrypted. Therefore, aside bringing up
|
|
the SSL connection, the SSL bits are unimportant from a protocol
|
|
standpoint. The client and server still send and receive the same
|
|
information - it just happens to be encrypted to everyone else.
|
|
|
|
|
|
"On-The-Wire" Data
|
|
------------------
|
|
|
|
The low-level, "on-the-wire" data is encapsulated similar to the telnet
|
|
protocol. All data is sent "as-is" with the exception of 0xFF. 0xFF is
|
|
used as a "command character" and both the client and server expect to
|
|
see a predefined option after it. The possible options are: 0xFF, 'E',
|
|
'G', 'Z', and '.'.
|
|
|
|
The 0xFF option says to use the literal character 0xFF. So, if there is
|
|
a 0xFF character in the data stream to be sent, the code will send two
|
|
0xFF characters (it's similar to using '\\' in C strings to embed a
|
|
'\').
|
|
|
|
The other options are used in various contexts, which will be described
|
|
in detail below.
|
|
|
|
|
|
Life As A Server
|
|
----------------
|
|
|
|
There are three different interfaces presented to clients by the server.
|
|
I'm going to name the three modes "master", "group", and "console". The
|
|
first two are line-based, and the third is character-based.
|
|
|
|
To understand the differences, I must outline how conserver manages
|
|
consoles. When conserver starts, it reads the configuration file,
|
|
listens on the master socket, and, for each group of consoles it must
|
|
manage (where the group size is set by -m), it forks off a copy of
|
|
itself. Those child processes are what actually connect to the consoles
|
|
and they each listen on a new socket for client connections. So, you
|
|
end up with a parent process (that knows about all consoles) that
|
|
manages the child processes (that know only about consoles it manages),
|
|
and everyone is listening on an individual socket for connections from
|
|
clients.
|
|
|
|
The parent process interacts with clients in "master" mode. That mode
|
|
expects line-based commands and responds similarly. Because it's the
|
|
master, it understands a certain set of commands that are different than
|
|
in "group" mode.
|
|
|
|
The child processes interact with clients in "group" mode first, and
|
|
negotiate a change to "console" mode when a client requests a connection
|
|
to a specific console.
|
|
|
|
|
|
"master" Mode
|
|
-------------
|
|
|
|
When parent process gets a connection from a client, it either sends an
|
|
"ok" string to signal it's ready or an error message (like "access from
|
|
your host is refused") and the connection is dropped. At this point,
|
|
there are a small number of commands recognized by the server, since
|
|
most are restricted to "logged in" clients. Here's the list of
|
|
available commands:
|
|
|
|
exit disconnect
|
|
help this help message
|
|
login log in
|
|
ssl start ssl session
|
|
|
|
An "exit" is sent a "goodbye" response and the connection is dropped. A
|
|
"help" is sent the list above. A "ssl" is sent an "ok" response and
|
|
then the server expects the client to negotiate an ssl connection. A
|
|
"login" requires one argument (the username) and is either sent an "ok",
|
|
meaning the client is logged in, or a "passwd?" followed by the local
|
|
hostname, asking for the user's password, which it expects next. If the
|
|
client sends a valid password, an "ok" is sent, otherwise an error
|
|
message and the connection is dropped.
|
|
|
|
Upon successful login, the commands available are:
|
|
|
|
call provide port for given console
|
|
exit disconnect
|
|
groups provide ports for group leaders
|
|
help this help message
|
|
master provide a list of master servers
|
|
newlogs* close and open all logfiles (SIGUSR2)
|
|
pid provide pid of master process
|
|
quit* terminate conserver (SIGTERM)
|
|
restart* restart conserver (SIGHUP) - deprecated
|
|
reconfig* reread config file (SIGHUP)
|
|
version provide version info for server
|
|
up* bring up all downed consoles (SIGUSR1)
|
|
* = requires admin privileges
|
|
|
|
"exit" and "help" are the same as before the client logged login.
|
|
|
|
The "call" command expects one argument, the console name to connect to.
|
|
The server will respond with either a port number (if it's a locally
|
|
managed console), an "@hostname" where hostname is the name of the
|
|
remote conserver host managing the console (if it's a remotely managed
|
|
console), or an error message (possibly multi-line). The client is not
|
|
disconnected, whatever the response.
|
|
|
|
The "groups" command responds with a colon-separated list of port
|
|
numbers, which correspond to each of the child processes running on the
|
|
local host. The client is not disconnected.
|
|
|
|
The "master" command responds with a colon-separated list of "@hostname"
|
|
names. The list includes any hosts (including the possibility of the
|
|
local host) which have locally managed consoles. The client is not
|
|
disconnected.
|
|
|
|
The "newlogs" command reopens all logfiles used by conserver, assuming
|
|
the user has administrative access. It responds with a message starting
|
|
with "ok" if successful and an error message otherwise (like
|
|
"unauthorized command"). The client is disconnected if it's successful.
|
|
|
|
The "pid" command responds with the pid of the master process (in this
|
|
case, the one the client is talking to). The client is not
|
|
disconnected.
|
|
|
|
The "quit" command will shut down conserver, assuming the user has
|
|
administrative access. It responds with a message starting with "ok" if
|
|
successful and an error message otherwise (like "unauthorized command").
|
|
The client is disconnected if it's successful.
|
|
|
|
The "restart" command has been deprecated. You should use "reconfig".
|
|
|
|
The "reconfig" command will cause conserver to reread the configuration
|
|
file and apply any changes, assuming the user has administrative access.
|
|
It responds with a message starting with "ok" if successful and an error
|
|
message otherwise (like "unauthorized command"). The client is not
|
|
disconnected.
|
|
|
|
The "version" command responds with the version string. The client is
|
|
not disconnected.
|
|
|
|
The "up" command tries to "bring up" all disconnected consoles, assuming
|
|
the user has administrative access. It responds with a message starting
|
|
with "ok" if successful and an error message otherwise (like
|
|
"unauthorized command"). The client is disconnected if it's successful.
|
|
|
|
|
|
"group" Mode
|
|
------------
|
|
|
|
When a child process gets a connection from a client, it either sends an
|
|
"ok" string to signal it's ready or an error message (like "access from
|
|
your host is refused") and the connection is dropped. At this point,
|
|
"group" mode acts just like "master" mode. Once the client successfully
|
|
logs in, however, "group" mode has the recognizes the following
|
|
commands:
|
|
|
|
broadcast send broadcast message
|
|
call connect to given console
|
|
disconnect* disconnect the given user(s)
|
|
examine examine port and baud rates
|
|
exit disconnect
|
|
group show users in this group
|
|
help this help message
|
|
hosts show host status and user
|
|
info show console information
|
|
textmsg send a text message
|
|
* = requires admin privileges
|
|
|
|
The "exit" and "help" commands are like the others documented above.
|
|
|
|
The "broadcast" command expects a text string of the message to be sent
|
|
to all users connected to this process. An "ok" is sent as a response.
|
|
|
|
The "call" command expects one argument, the console name to connect to,
|
|
just like in "master" mode. The difference here is that this requests
|
|
the server to attach the client to the console and go into "console"
|
|
mode. If the attachment is successful, the response will begin with a
|
|
'[' character. If not, an error message is returned. The success
|
|
responses are:
|
|
|
|
[console is read-only] - console is read only
|
|
[read-only -- initializing] - console is initializing, and
|
|
read-only for the time being
|
|
[line to console is down] - console is down
|
|
[attached] - attached read-write
|
|
[spy] - attached read-only
|
|
|
|
|
|
The "disconnect" command expects an argument of the form "user@console"
|
|
where either the "user" or "@console" part may be omitted. Upon
|
|
success, a response of the form "ok -- disconnected X users" is sent,
|
|
where X is the number of users disconnected. If a user is unauthorized
|
|
or some other problem occurs, an error message (like "unauthorized
|
|
command") is sent.
|
|
|
|
The "examine" command returns a list of console information of the form
|
|
that 'console -x' shows.
|
|
|
|
The "group" command returns a list of console information of the form
|
|
that 'console -w' shows.
|
|
|
|
The "hosts" command returns a list of console information of the form
|
|
that 'console -u' shows.
|
|
|
|
The "info" command returns a list of console information of the form
|
|
that 'console -i' shows.
|
|
|
|
The "textmsg" command expects two arguments, the first being the
|
|
recipient of the message in the form "user@console" (again, where the
|
|
"user" or "@console" portion may be omitted) and the second being the
|
|
string, like the "broadcast" command. The server returns "ok".
|
|
|
|
|
|
"console" Mode
|
|
--------------
|
|
|
|
As mentioned above, "console" mode is obtained by using the "call"
|
|
command when connected to a child processes operating in "group" mode.
|
|
|
|
"console" mode should look very familiar to a user of conserver, as it's
|
|
what the user interacts with when connected to a console. There's
|
|
really nothings special here. Each character received from the client
|
|
is compared to the escape sequence, and if it matches, an action occurs
|
|
on the server side. If it doesn't match the escape sequence, the data
|
|
is sent on to the console. All data received from the console is sent
|
|
to the client(s). Of course, there are certain exceptions to these
|
|
rules, based on the state of the console and the state of the client.
|
|
And, certain escape sequences cause special behaviors to occur.
|
|
|
|
Most escape sequences cause the server to send information back to the
|
|
user. Stuff like "^Ecw", "^Eci", and "^Ecu" are examples. The escape
|
|
sequence is absorbed by the server, the server sends the client a
|
|
variety of information, and things continue as before.
|
|
|
|
The more "interesting" escape sequences are the following.
|
|
|
|
"^Ec;" The server sends a 0xFF,'G' command sequence to the client, to
|
|
signal a wish to move to a new console. The client then gets
|
|
put into the same state as the "^Ecz" sequence (paused), which
|
|
gives the client a chance to either resume the connection or
|
|
disconnect.
|
|
|
|
"^Ec|" The server sends a 0xFF,'E' command sequence to the client, to
|
|
signal a wish to have the client program interact with a
|
|
program, as opposed to the user. The server discards all data
|
|
until it receives one of the following command sequences from
|
|
the client:
|
|
|
|
0xFF,'E' Signals successful redirection of interaction to
|
|
a program. The server then responds with "[rw]"
|
|
or "[ro]" to tell the client whether or not they
|
|
have read-write access. If not, the client
|
|
should abort the program and send the abort
|
|
command sequence below, as other data received by
|
|
the server will just get dropped.
|
|
|
|
0xFF,'.' Abort the operation. The server assumes the
|
|
redirection didn't happen and returns the client
|
|
to it's normal mode.
|
|
|
|
The server keeps the client in the "redirected" state until it
|
|
receives a 0xFF,'.' command sequence from the client (which
|
|
usually occurs when the client command terminates).
|
|
|
|
If the client is "bumped" from read-write to read-only by
|
|
another user, the server will send the client a 0xFF,'.' command
|
|
sequence to tell it to abort the redirection and return control
|
|
back to the user.
|
|
|
|
"^Ecz" The server sends a 0xFF,'Z' command sequence to the client, to
|
|
signal a wish to suspend to client process. The client is then
|
|
put into a "paused" state where it receives no more data from
|
|
the server. When the client is ready to resume receiving data,
|
|
it sends a character of data to the server, at which point the
|
|
server discards the character and sends back a status message of
|
|
the form " -- MSG]". The current set of possible messages are:
|
|
|
|
" -- line down]"
|
|
" -- read-only]"
|
|
" -- attached (nologging)]"
|
|
" -- attached]"
|
|
" -- spy mode]"
|