The telnet version with encryption in in.
Reviewed by: geoff.
This commit is contained in:
parent
dcaf997105
commit
23c56ec341
73
secure/usr.bin/telnet/Makefile
Normal file
73
secure/usr.bin/telnet/Makefile
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 1990 The Regents of the University of California.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions
|
||||||
|
# are met:
|
||||||
|
# 1. Redistributions of source code must retain the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer.
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
# notice, this list of conditions and the following disclaimer in the
|
||||||
|
# documentation and/or other materials provided with the distribution.
|
||||||
|
# 3. All advertising materials mentioning features or use of this software
|
||||||
|
# must display the following acknowledgement:
|
||||||
|
# This product includes software developed by the University of
|
||||||
|
# California, Berkeley and its contributors.
|
||||||
|
# 4. Neither the name of the University nor the names of its contributors
|
||||||
|
# may be used to endorse or promote products derived from this software
|
||||||
|
# without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
# SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
# @(#)Makefile 8.1 (Berkeley) 6/6/93
|
||||||
|
#
|
||||||
|
|
||||||
|
PROG= telnet
|
||||||
|
|
||||||
|
CFLAGS+=-DTERMCAP -DKLUDGELINEMODE -DUSE_TERMIO #-DAUTHENTICATION -DENCRYPTION
|
||||||
|
CFLAGS+=-DENV_HACK
|
||||||
|
CFLAGS+=-I${.CURDIR}/../../lib
|
||||||
|
|
||||||
|
#CFLAGS+= -DKRB4
|
||||||
|
|
||||||
|
LDADD= -ltermcap -ltelnet
|
||||||
|
#LDADD+= -lkrb -ldes
|
||||||
|
DPADD= ${LIBTERMCAP}
|
||||||
|
|
||||||
|
SRCS= authenc.c commands.c main.c network.c ring.c sys_bsd.c telnet.c \
|
||||||
|
terminal.c tn3270.c utilities.c
|
||||||
|
|
||||||
|
# These are the sources that have encryption stuff in them.
|
||||||
|
CRYPT_SRC= authenc.c commands.c externs.h main.c network.c
|
||||||
|
CRYPT_SRC+= ring.c ring.h telnet.c terminal.c utilities.c Makefile
|
||||||
|
NOCRYPT_DIR=${.CURDIR}/Nocrypt
|
||||||
|
|
||||||
|
.include <bsd.prog.mk>
|
||||||
|
|
||||||
|
nocrypt:
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
@for i in ${CRYPT_SRC}; do \
|
||||||
|
if [ ! -d ${NOCRYPT_DIR} ]; then \
|
||||||
|
echo Creating subdirectory ${NOCRYPT_DIR}; \
|
||||||
|
mkdir ${NOCRYPT_DIR}; \
|
||||||
|
fi; \
|
||||||
|
echo ${NOCRYPT_DIR}/$$i; \
|
||||||
|
unifdef -UENCRYPTION ${.CURDIR}/$$i | \
|
||||||
|
sed "s/ || defined(ENCRYPTION)//" > ${NOCRYPT_DIR}/$$i; \
|
||||||
|
done
|
||||||
|
|
||||||
|
placeholder:
|
||||||
|
#else /* ENCRYPTION */
|
||||||
|
@echo "Encryption code already removed."
|
||||||
|
#endif /* ENCRYPTION */
|
566
secure/usr.bin/telnet/README
Normal file
566
secure/usr.bin/telnet/README
Normal file
@ -0,0 +1,566 @@
|
|||||||
|
|
||||||
|
|
||||||
|
This is a distribution of both client and server telnet. These programs
|
||||||
|
have been compiled on:
|
||||||
|
telnet telnetd
|
||||||
|
BSD 4.3 Reno X X
|
||||||
|
UNICOS 5.1 X X
|
||||||
|
UNICOS 6.0 X X
|
||||||
|
UNICOS 6.1 X X
|
||||||
|
UNICOS 7.0 X X
|
||||||
|
SunOs 3.5 X X (no linemode in server)
|
||||||
|
SunOs 4.1 X X (no linemode in server)
|
||||||
|
DYNIX V3.0.17.9 X X (no linemode in server)
|
||||||
|
Ultrix 3.1 X X (no linemode in server)
|
||||||
|
Ultrix 4.0 X X (no linemode in server)
|
||||||
|
|
||||||
|
In addition, previous versions have been compiled on the following
|
||||||
|
machines, but were not available for testing this version.
|
||||||
|
telnet telnetd
|
||||||
|
SunOs 4.0.3c X X (no linemode in server)
|
||||||
|
BSD 4.3 X X (no linemode in server)
|
||||||
|
DYNIX V3.0.12 X X (no linemode in server)
|
||||||
|
|
||||||
|
Februrary 22, 1991:
|
||||||
|
|
||||||
|
Features:
|
||||||
|
|
||||||
|
This version of telnet/telnetd has support for both
|
||||||
|
the AUTHENTICATION and ENCRYPTION options. The
|
||||||
|
AUTHENTICATION option is fairly well defined, and
|
||||||
|
an option number has been assigned to it. The
|
||||||
|
ENCRYPTION option is still in a state of flux; an
|
||||||
|
option number has NOT been assigned to it yet.
|
||||||
|
The code is provided in this release for experimental
|
||||||
|
and testing purposes.
|
||||||
|
|
||||||
|
The telnet "send" command can now be used to send
|
||||||
|
do/dont/will/wont commands, with any telnet option
|
||||||
|
name. The rules for when do/dont/will/wont are sent
|
||||||
|
are still followed, so just because the user requests
|
||||||
|
that one of these be sent doesn't mean that it will
|
||||||
|
be sent...
|
||||||
|
|
||||||
|
The telnet "getstatus" command no longer requires
|
||||||
|
that option printing be enabled to see the response
|
||||||
|
to the "DO STATUS" command.
|
||||||
|
|
||||||
|
A -n flag has been added to telnetd to disable
|
||||||
|
keepalives.
|
||||||
|
|
||||||
|
A new telnet command, "auth" has been added (if
|
||||||
|
AUTHENTICATE is defined). It has four sub-commands,
|
||||||
|
"status", "debug", "disable", "enable" and "help".
|
||||||
|
|
||||||
|
A new telnet command, "encrypt" has been added (if
|
||||||
|
ENCRYPT is defined). It has many sub-commands:
|
||||||
|
"enable", "type", "start", "stop", "input",
|
||||||
|
"-input", "output", "-output", "status", "auto",
|
||||||
|
"verbose", "debug", and "help".
|
||||||
|
|
||||||
|
An "rlogin" interface has been added. If the program
|
||||||
|
is named "rlogin", or the "-r" flag is given, then
|
||||||
|
an rlogin type of interface will be used.
|
||||||
|
~. Terminates the session
|
||||||
|
~<susp> Suspend the session
|
||||||
|
~^] Escape to telnet command mode
|
||||||
|
~~ Pass through the ~.
|
||||||
|
BUG: If you type the rlogin escape character
|
||||||
|
in the middle of a line while in rlogin
|
||||||
|
mode, you cannot erase it or any characters
|
||||||
|
before it. Hopefully this can be fixed
|
||||||
|
in a future release...
|
||||||
|
|
||||||
|
General changes:
|
||||||
|
|
||||||
|
A "libtelnet.a" has now been created. This libraray
|
||||||
|
contains code that is common to both telnet and
|
||||||
|
telnetd. This is also where library routines that
|
||||||
|
are needed, but are not in the standard C library,
|
||||||
|
are placed.
|
||||||
|
|
||||||
|
The makefiles have been re-done. All of the site
|
||||||
|
specific configuration information has now been put
|
||||||
|
into a single "Config.generic" file, in the top level
|
||||||
|
directory. Changing this one file will take care of
|
||||||
|
all three subdirectories. Also, to add a new/local
|
||||||
|
definition, a "Config.local" file may be created
|
||||||
|
at the top level; if that file exists, the subdirectories
|
||||||
|
will use that file instead of "Config.generic".
|
||||||
|
|
||||||
|
Many 1-2 line functions in commands.c have been
|
||||||
|
removed, and just inserted in-line, or replaced
|
||||||
|
with a macro.
|
||||||
|
|
||||||
|
Bug Fixes:
|
||||||
|
|
||||||
|
The non-termio code in both telnet and telnetd was
|
||||||
|
setting/clearing CTLECH in the sg_flags word. This
|
||||||
|
was incorrect, and has been changed to set/clear the
|
||||||
|
LCTLECH bit in the local mode word.
|
||||||
|
|
||||||
|
The SRCRT #define has been removed. If IP_OPTIONS
|
||||||
|
and IPPROTO_IP are defined on the system, then the
|
||||||
|
source route code is automatically enabled.
|
||||||
|
|
||||||
|
The NO_GETTYTAB #define has been removed; there
|
||||||
|
is a compatability routine that can be built into
|
||||||
|
libtelnet to achive the same results.
|
||||||
|
|
||||||
|
The server, telnetd, has been switched to use getopt()
|
||||||
|
for parsing the argument list.
|
||||||
|
|
||||||
|
The code for getting the input/output speeds via
|
||||||
|
cfgetispeed()/cfgetospeed() was still not quite
|
||||||
|
right in telnet. Posix says if the ispeed is 0,
|
||||||
|
then it is really equal to the ospeed.
|
||||||
|
|
||||||
|
The suboption processing code in telnet now has
|
||||||
|
explicit checks to make sure that we received
|
||||||
|
the entire suboption (telnetd was already doing this).
|
||||||
|
|
||||||
|
The telnet code for processing the terminal type
|
||||||
|
could cause a core dump if an existing connection
|
||||||
|
was closed, and a new connection opened without
|
||||||
|
exiting telnet.
|
||||||
|
|
||||||
|
Telnetd was doing a TCSADRAIN when setting the new
|
||||||
|
terminal settings; This is not good, because it means
|
||||||
|
that the tcsetattr() will hang waiting for output to
|
||||||
|
drain, and telnetd is the only one that will drain
|
||||||
|
the output... The fix is to use TCSANOW which does
|
||||||
|
not wait.
|
||||||
|
|
||||||
|
Telnetd was improperly setting/clearing the ISTRIP
|
||||||
|
flag in the c_lflag field, it should be using the
|
||||||
|
c_iflag field.
|
||||||
|
|
||||||
|
When the child process of telnetd was opening the
|
||||||
|
slave side of the pty, it was re-setting the EXTPROC
|
||||||
|
bit too early, and some of the other initialization
|
||||||
|
code was wiping it out. This would cause telnetd
|
||||||
|
to go out of linemode and into single character mode.
|
||||||
|
|
||||||
|
One instance of leaving linemode in telnetd forgot
|
||||||
|
to send a WILL ECHO to the client, the net result
|
||||||
|
would be that the user would see double character
|
||||||
|
echo.
|
||||||
|
|
||||||
|
If the MODE was being changed several times very
|
||||||
|
quickly, telnetd could get out of sync with the
|
||||||
|
state changes and the returning acks; and wind up
|
||||||
|
being left in the wrong state.
|
||||||
|
|
||||||
|
September 14, 1990:
|
||||||
|
|
||||||
|
Switch the client to use getopt() for parsing the
|
||||||
|
argument list. The 4.3Reno getopt.c is included for
|
||||||
|
systems that don't have getopt().
|
||||||
|
|
||||||
|
Use the posix _POSIX_VDISABLE value for what value
|
||||||
|
to use when disabling special characters. If this
|
||||||
|
is undefined, it defaults to 0x3ff.
|
||||||
|
|
||||||
|
For non-termio systems, TIOCSETP was being used to
|
||||||
|
change the state of the terminal. This causes the
|
||||||
|
input queue to be flushed, which we don't want. This
|
||||||
|
is now changed to TIOCSETN.
|
||||||
|
|
||||||
|
Take out the "#ifdef notdef" around the code in the
|
||||||
|
server that generates a "sync" when the pty oputput
|
||||||
|
is flushed. The potential problem is that some older
|
||||||
|
telnet clients may go into an infinate loop when they
|
||||||
|
receive a "sync", if so, the server can be compiled
|
||||||
|
with "NO_URGENT" defined.
|
||||||
|
|
||||||
|
Fix the client where it was setting/clearing the OPOST
|
||||||
|
bit in the c_lflag field, not the c_oflag field.
|
||||||
|
|
||||||
|
Fix the client where it was setting/clearing the ISTRIP
|
||||||
|
bit in the c_lflag field, not the c_iflag field. (On
|
||||||
|
4.3Reno, this is the ECHOPRT bit in the c_lflag field.)
|
||||||
|
The client also had its interpretation of WILL BINARY
|
||||||
|
and DO BINARY reversed.
|
||||||
|
|
||||||
|
Fix a bug in client that would cause a core dump when
|
||||||
|
attempting to remove the last environment variable.
|
||||||
|
|
||||||
|
In the client, there were a few places were switch()
|
||||||
|
was being passed a character, and if it was a negative
|
||||||
|
value, it could get sign extended, and not match
|
||||||
|
the 8 bit case statements. The fix is to and the
|
||||||
|
switch value with 0xff.
|
||||||
|
|
||||||
|
Add a couple more printoption() calls in the client, I
|
||||||
|
don't think there are any more places were a telnet
|
||||||
|
command can be received and not printed out when
|
||||||
|
"options" is on.
|
||||||
|
|
||||||
|
A new flag has been added to the client, "-a". Currently,
|
||||||
|
this just causes the USER name to be sent across, in
|
||||||
|
the future this may be used to signify that automatic
|
||||||
|
authentication is requested.
|
||||||
|
|
||||||
|
The USER variable is now only sent by the client if
|
||||||
|
the "-a" or "-l user" options are explicity used, or
|
||||||
|
if the user explicitly asks for the "USER" environment
|
||||||
|
variable to be exported. In the server, if it receives
|
||||||
|
the "USER" environment variable, it won't print out the
|
||||||
|
banner message, so that only "Password:" will be printed.
|
||||||
|
This makes the symantics more like rlogin, and should be
|
||||||
|
more familiar to the user. (People are not used to
|
||||||
|
getting a banner message, and then getting just a
|
||||||
|
"Password:" prompt.)
|
||||||
|
|
||||||
|
Re-vamp the code for starting up the child login
|
||||||
|
process. The code was getting ugly, and it was
|
||||||
|
hard to tell what was really going on. What we
|
||||||
|
do now is after the fork(), in the child:
|
||||||
|
1) make sure we have no controlling tty
|
||||||
|
2) open and initialize the tty
|
||||||
|
3) do a setsid()/setpgrp()
|
||||||
|
4) makes the tty our controlling tty.
|
||||||
|
On some systems, #2 makes the tty our controlling
|
||||||
|
tty, and #4 is a no-op. The parent process does
|
||||||
|
a gets rid of any controlling tty after the child
|
||||||
|
is fork()ed.
|
||||||
|
|
||||||
|
Use the strdup() library routine in telnet, instead
|
||||||
|
of the local savestr() routine. If you don't have
|
||||||
|
strdup(), you need to define NO_STRDUP.
|
||||||
|
|
||||||
|
Add support for ^T (SIGINFO/VSTATUS), found in the
|
||||||
|
4.3Reno distribution. This maps to the AYT character.
|
||||||
|
You need a 4-line bugfix in the kernel to get this
|
||||||
|
to work properly:
|
||||||
|
|
||||||
|
> *** tty_pty.c.ORG Tue Sep 11 09:41:53 1990
|
||||||
|
> --- tty_pty.c Tue Sep 11 17:48:03 1990
|
||||||
|
> ***************
|
||||||
|
> *** 609,613 ****
|
||||||
|
> if ((tp->t_lflag&NOFLSH) == 0)
|
||||||
|
> ttyflush(tp, FREAD|FWRITE);
|
||||||
|
> ! pgsignal(tp->t_pgrp, *(unsigned int *)data);
|
||||||
|
> return(0);
|
||||||
|
> }
|
||||||
|
> --- 609,616 ----
|
||||||
|
> if ((tp->t_lflag&NOFLSH) == 0)
|
||||||
|
> ttyflush(tp, FREAD|FWRITE);
|
||||||
|
> ! pgsignal(tp->t_pgrp, *(unsigned int *)data, 1);
|
||||||
|
> ! if ((*(unsigned int *)data == SIGINFO) &&
|
||||||
|
> ! ((tp->t_lflag&NOKERNINFO) == 0))
|
||||||
|
> ! ttyinfo(tp);
|
||||||
|
> return(0);
|
||||||
|
> }
|
||||||
|
|
||||||
|
The client is now smarter when setting the telnet escape
|
||||||
|
character; it only sets it to one of VEOL and VEOL2 if
|
||||||
|
one of them is undefined, and the other one is not already
|
||||||
|
defined to the telnet escape character.
|
||||||
|
|
||||||
|
Handle TERMIOS systems that have seperate input and output
|
||||||
|
line speed settings imbedded in the flags.
|
||||||
|
|
||||||
|
Many other minor bug fixes.
|
||||||
|
|
||||||
|
June 20, 1990:
|
||||||
|
Re-organize makefiles and source tree. The telnet/Source
|
||||||
|
directory is now gone, and all the source that was in
|
||||||
|
telnet/Source is now just in the telnet directory.
|
||||||
|
|
||||||
|
Seperate makefile for each system are now gone. There
|
||||||
|
are two makefiles, Makefile and Makefile.generic.
|
||||||
|
The "Makefile" has the definitions for the various
|
||||||
|
system, and "Makefile.generic" does all the work.
|
||||||
|
There is a variable called "WHAT" that is used to
|
||||||
|
specify what to make. For example, in the telnet
|
||||||
|
directory, you might say:
|
||||||
|
make 4.4bsd WHAT=clean
|
||||||
|
to clean out the directory.
|
||||||
|
|
||||||
|
Add support for the ENVIRON and XDISPLOC options.
|
||||||
|
In order for the server to work, login has to have
|
||||||
|
the "-p" option to preserve environment variables.
|
||||||
|
|
||||||
|
Add the SOFT_TAB and LIT_ECHO modes in the LINEMODE support.
|
||||||
|
|
||||||
|
Add the "-l user" option to command line and open command
|
||||||
|
(This is passed through the ENVIRON option).
|
||||||
|
|
||||||
|
Add the "-e" command line option, for setting the escape
|
||||||
|
character.
|
||||||
|
|
||||||
|
Add the "-D", diagnostic, option to the server. This allows
|
||||||
|
the server to print out debug information, which is very
|
||||||
|
useful when trying to debug a telnet that doesn't have any
|
||||||
|
debugging ability.
|
||||||
|
|
||||||
|
Turn off the literal next character when not in LINEMODE.
|
||||||
|
|
||||||
|
Don't recognize ^Y locally, just pass it through.
|
||||||
|
|
||||||
|
Make minor modifications for Sun4.0 and Sun4.1
|
||||||
|
|
||||||
|
Add support for both FORW1 and FORW2 characters. The
|
||||||
|
telnet escpape character is set to whichever of the
|
||||||
|
two is not being used. If both are in use, the escape
|
||||||
|
character is not set, so when in linemode the user will
|
||||||
|
have to follow the escape character with a <CR> or <EOF)
|
||||||
|
to get it passed through.
|
||||||
|
|
||||||
|
Commands can now be put in single and double quotes, and
|
||||||
|
a backslash is now an escape character. This is needed
|
||||||
|
for allowing arbitrary strings to be assigned to environment
|
||||||
|
variables.
|
||||||
|
|
||||||
|
Switch telnetd to use macros like telnet for keeping
|
||||||
|
track of the state of all the options.
|
||||||
|
|
||||||
|
Fix telnetd's processing of options so that we always do
|
||||||
|
the right processing of the LINEMODE option, regardless
|
||||||
|
of who initiates the request to turn it on. Also, make
|
||||||
|
sure that if the other side went "WILL ECHO" in response
|
||||||
|
to our "DO ECHO", that we send a "DONT ECHO" to get the
|
||||||
|
option turned back off!
|
||||||
|
|
||||||
|
Fix the TERMIOS setting of the terminal speed to handle both
|
||||||
|
BSD's seperate fields, and the SYSV method of CBAUD bits.
|
||||||
|
|
||||||
|
Change how we deal with the other side refusing to enable
|
||||||
|
an option. The sequence used to be: send DO option; receive
|
||||||
|
WONT option; send DONT option. Now, the sequence is: send
|
||||||
|
DO option; receive WONT option. Both should be valid
|
||||||
|
according to the spec, but there has been at least one
|
||||||
|
client implementation of telnet identified that can get
|
||||||
|
really confused by this. (The exact sequence, from a trace
|
||||||
|
on the server side, is (numbers are number of responses that
|
||||||
|
we expect to get after that line...):
|
||||||
|
|
||||||
|
send WILL ECHO 1 (initial request)
|
||||||
|
send WONT ECHO 2 (server is changing state)
|
||||||
|
recv DO ECHO 1 (first reply, ok. expect DONT ECHO next)
|
||||||
|
send WILL ECHO 2 (server changes state again)
|
||||||
|
recv DONT ECHO 1 (second reply, ok. expect DO ECHO next)
|
||||||
|
recv DONT ECHO 0 (third reply, wrong answer. got DONT!!!)
|
||||||
|
*** send WONT ECHO (send WONT to acknowledge the DONT)
|
||||||
|
send WILL ECHO 1 (ask again to enable option)
|
||||||
|
recv DO ECHO 0
|
||||||
|
|
||||||
|
recv DONT ECHO 0
|
||||||
|
send WONT ECHO 1
|
||||||
|
recv DONT ECHO 0
|
||||||
|
recv DO ECHO 1
|
||||||
|
send WILL ECHO 0
|
||||||
|
(and the last 5 lines loop forever)
|
||||||
|
|
||||||
|
The line with the "***" is last of the WILL/DONT/WONT sequence.
|
||||||
|
The change to the server to not generate that makes this same
|
||||||
|
example become:
|
||||||
|
|
||||||
|
send will ECHO 1
|
||||||
|
send wont ECHO 2
|
||||||
|
recv do ECHO 1
|
||||||
|
send will ECHO 2
|
||||||
|
recv dont ECHO 1
|
||||||
|
recv dont ECHO 0
|
||||||
|
recv do ECHO 1
|
||||||
|
send will ECHO 0
|
||||||
|
|
||||||
|
There is other option negotiation going on, and not sending
|
||||||
|
the third part changes some of the timings, but this specific
|
||||||
|
example no longer gets stuck in a loop. The "telnet.state"
|
||||||
|
file has been modified to reflect this change to the algorithm.
|
||||||
|
|
||||||
|
A bunch of miscellaneous bug fixes and changes to make
|
||||||
|
lint happier.
|
||||||
|
|
||||||
|
This version of telnet also has some KERBEROS stuff in
|
||||||
|
it. This has not been tested, it uses an un-authorized
|
||||||
|
telnet option number, and uses an out-of-date version
|
||||||
|
of the (still being defined) AUTHENTICATION option.
|
||||||
|
There is no support for this code, do not enable it.
|
||||||
|
|
||||||
|
|
||||||
|
March 1, 1990:
|
||||||
|
CHANGES/BUGFIXES SINCE LAST RELEASE:
|
||||||
|
Some support for IP TOS has been added. Requires that the
|
||||||
|
kernel support the IP_TOS socket option (currently this
|
||||||
|
is only in UNICOS 6.0).
|
||||||
|
|
||||||
|
Both telnet and telnetd now use the cc_t typedef. typedefs are
|
||||||
|
included for systems that don't have it (in termios.h).
|
||||||
|
|
||||||
|
SLC_SUSP was not supported properly before. It is now.
|
||||||
|
|
||||||
|
IAC EOF was not translated properly in telnetd for SYSV_TERMIO
|
||||||
|
when not in linemode. It now saves a copy of the VEOF character,
|
||||||
|
so that when ICANON is turned off and we can't trust it anymore
|
||||||
|
(because it is now the VMIN character) we use the saved value.
|
||||||
|
|
||||||
|
There were two missing "break" commands in the linemode
|
||||||
|
processing code in telnetd.
|
||||||
|
|
||||||
|
Telnetd wasn't setting the kernel window size information
|
||||||
|
properly. It was using the rows for both rows and columns...
|
||||||
|
|
||||||
|
Questions/comments go to
|
||||||
|
David Borman
|
||||||
|
Cray Research, Inc.
|
||||||
|
655F Lone Oak Drive
|
||||||
|
Eagan, MN 55123
|
||||||
|
dab@cray.com.
|
||||||
|
|
||||||
|
README: You are reading it.
|
||||||
|
|
||||||
|
Config.generic:
|
||||||
|
This file contains all the OS specific definitions. It
|
||||||
|
has pre-definitions for many common system types, and is
|
||||||
|
in standard makefile fromat. See the comments at the top
|
||||||
|
of the file for more information.
|
||||||
|
|
||||||
|
Config.local:
|
||||||
|
This is not part of the distribution, but if this file exists,
|
||||||
|
it is used instead of "Config.generic". This allows site
|
||||||
|
specific configuration without having to modify the distributed
|
||||||
|
"Config.generic" file.
|
||||||
|
|
||||||
|
kern.diff:
|
||||||
|
This file contains the diffs for the changes needed for the
|
||||||
|
kernel to support LINEMODE is the server. These changes are
|
||||||
|
for a 4.3BSD system. You may need to make some changes for
|
||||||
|
your particular system.
|
||||||
|
|
||||||
|
There is a new bit in the terminal state word, TS_EXTPROC.
|
||||||
|
When this bit is set, several aspects of the terminal driver
|
||||||
|
are disabled. Input line editing, character echo, and
|
||||||
|
mapping of signals are all disabled. This allows the telnetd
|
||||||
|
to turn of these functions when in linemode, but still keep
|
||||||
|
track of what state the user wants the terminal to be in.
|
||||||
|
|
||||||
|
New ioctl()s:
|
||||||
|
|
||||||
|
TIOCEXT Turn on/off the TS_EXTPROC bit
|
||||||
|
TIOCGSTATE Get t_state of tty to look at TS_EXTPROC bit
|
||||||
|
TIOCSIG Generate a signal to processes in the
|
||||||
|
current process group of the pty.
|
||||||
|
|
||||||
|
There is a new mode for packet driver, the TIOCPKT_IOCTL bit.
|
||||||
|
When packet mode is turned on in the pty, and the TS_EXTPROC
|
||||||
|
bit is set, then whenever the state of the pty is changed, the
|
||||||
|
next read on the master side of the pty will have the TIOCPKT_IOCTL
|
||||||
|
bit set, and the data will contain the following:
|
||||||
|
struct xx {
|
||||||
|
struct sgttyb a;
|
||||||
|
struct tchars b;
|
||||||
|
struct ltchars c;
|
||||||
|
int t_state;
|
||||||
|
int t_flags;
|
||||||
|
}
|
||||||
|
This allows the process on the server side of the pty to know
|
||||||
|
when the state of the terminal has changed, and what the new
|
||||||
|
state is.
|
||||||
|
|
||||||
|
However, if you define USE_TERMIO or SYSV_TERMIO, the code will
|
||||||
|
expect that the structure returned in the TIOCPKT_IOCTL is
|
||||||
|
the termio/termios structure.
|
||||||
|
|
||||||
|
stty.diff:
|
||||||
|
This file contains the changes needed for the stty(1) program
|
||||||
|
to report on the current status of the TS_EXTPROC bit. It also
|
||||||
|
allows the user to turn on/off the TS_EXTPROC bit. This is useful
|
||||||
|
because it allows the user to say "stty -extproc", and the
|
||||||
|
LINEMODE option will be automatically disabled, and saying "stty
|
||||||
|
extproc" will re-enable the LINEMODE option.
|
||||||
|
|
||||||
|
telnet.state:
|
||||||
|
Both the client and server have code in them to deal
|
||||||
|
with option negotiation loops. The algorithm that is
|
||||||
|
used is described in this file.
|
||||||
|
|
||||||
|
tmac.doc:
|
||||||
|
Macros for use in formatting the man pages on non-4.3Reno
|
||||||
|
systems.
|
||||||
|
|
||||||
|
telnet:
|
||||||
|
This directory contains the client code. No kernel changes are
|
||||||
|
needed to use this code.
|
||||||
|
|
||||||
|
telnetd:
|
||||||
|
This directory contains the server code. If LINEMODE or KLUDGELINEMODE
|
||||||
|
are defined, then the kernel modifications listed above are needed.
|
||||||
|
|
||||||
|
libtelnet:
|
||||||
|
This directory contains code that is common to both the client
|
||||||
|
and the server.
|
||||||
|
|
||||||
|
arpa:
|
||||||
|
This directory has a new <arpa/telnet.h>
|
||||||
|
|
||||||
|
|
||||||
|
The following TELNET options are supported:
|
||||||
|
|
||||||
|
LINEMODE:
|
||||||
|
The LINEMODE option is supported as per RFC1116. The
|
||||||
|
FORWARDMASK option is not currently supported.
|
||||||
|
|
||||||
|
BINARY: The client has the ability to turn on/off the BINARY
|
||||||
|
option in each direction. Turning on BINARY from
|
||||||
|
server to client causes the LITOUT bit to get set in
|
||||||
|
the terminal driver on both ends, turning on BINARY
|
||||||
|
from the client to the server causes the PASS8 bit
|
||||||
|
to get set in the terminal driver on both ends.
|
||||||
|
|
||||||
|
TERMINAL-TYPE:
|
||||||
|
This is supported as per RFC1091. On the server side,
|
||||||
|
when a terminal type is received, termcap/terminfo
|
||||||
|
is consulted to determine if it is a known terminal
|
||||||
|
type. It keeps requesting terminal types until it
|
||||||
|
gets one that it recongnizes, or hits the end of the
|
||||||
|
list. The server side looks up the entry in the
|
||||||
|
termcap/terminfo data base, and generates a list of
|
||||||
|
names which it then passes one at a time to each
|
||||||
|
request for a terminal type, duplicating the last
|
||||||
|
entry in the list before cycling back to the beginning.
|
||||||
|
|
||||||
|
NAWS: The Negotiate about Window Size, as per RFC 1073.
|
||||||
|
|
||||||
|
TERMINAL-SPEED:
|
||||||
|
Implemented as per RFC 1079
|
||||||
|
|
||||||
|
TOGGLE-FLOW-CONTROL:
|
||||||
|
Implemented as per RFC 1080
|
||||||
|
|
||||||
|
TIMING-MARK:
|
||||||
|
As per RFC 860
|
||||||
|
|
||||||
|
SGA: As per RFC 858
|
||||||
|
|
||||||
|
ECHO: As per RFC 857
|
||||||
|
|
||||||
|
STATUS:
|
||||||
|
The server will send its current status upon
|
||||||
|
request. It does not ask for the clients status.
|
||||||
|
The client will request the servers current status
|
||||||
|
from the "send getstatus" command.
|
||||||
|
|
||||||
|
ENVIRON:
|
||||||
|
This option is currently being defined by the IETF
|
||||||
|
Telnet Working Group, and an RFC has not yet been
|
||||||
|
issued, but should be in the near future...
|
||||||
|
|
||||||
|
X-DISPLAY-LOCATION:
|
||||||
|
This functionality can be done through the ENVIRON
|
||||||
|
option, it is added here for completeness.
|
||||||
|
|
||||||
|
AUTHENTICATION:
|
||||||
|
This option is currently being defined by the IETF
|
||||||
|
Telnet Working Group, and an RFC has not yet been
|
||||||
|
issued. The basic framework is pretty much decided,
|
||||||
|
but the definitions for the specific authentication
|
||||||
|
schemes is still in a state of flux.
|
||||||
|
|
||||||
|
ENCRYPT:
|
||||||
|
This option is currently being defined by the IETF
|
||||||
|
Telnet Working Group, and an RFC has not yet been
|
||||||
|
issued. The draft RFC is still in a state of flux,
|
||||||
|
so this code may change in the future.
|
111
secure/usr.bin/telnet/authenc.c
Normal file
111
secure/usr.bin/telnet/authenc.c
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
/*-
|
||||||
|
* Copyright (c) 1991, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)authenc.c 8.1 (Berkeley) 6/6/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#if defined(AUTHENTICATION) || defined(ENCRYPTION)
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <arpa/telnet.h>
|
||||||
|
#include <libtelnet/encrypt.h>
|
||||||
|
#include <libtelnet/misc.h>
|
||||||
|
|
||||||
|
#include "general.h"
|
||||||
|
#include "ring.h"
|
||||||
|
#include "externs.h"
|
||||||
|
#include "defines.h"
|
||||||
|
#include "types.h"
|
||||||
|
|
||||||
|
int
|
||||||
|
net_write(str, len)
|
||||||
|
unsigned char *str;
|
||||||
|
int len;
|
||||||
|
{
|
||||||
|
if (NETROOM() > len) {
|
||||||
|
ring_supply_data(&netoring, str, len);
|
||||||
|
if (str[0] == IAC && str[1] == SE)
|
||||||
|
printsub('>', &str[2], len-2);
|
||||||
|
return(len);
|
||||||
|
}
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
net_encrypt()
|
||||||
|
{
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
if (encrypt_output)
|
||||||
|
ring_encrypt(&netoring, encrypt_output);
|
||||||
|
else
|
||||||
|
ring_clearto(&netoring);
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
telnet_spin()
|
||||||
|
{
|
||||||
|
return(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
telnet_getenv(val)
|
||||||
|
char *val;
|
||||||
|
{
|
||||||
|
return((char *)env_getvalue((unsigned char *)val));
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
telnet_gets(prompt, result, length, echo)
|
||||||
|
char *prompt;
|
||||||
|
char *result;
|
||||||
|
int length;
|
||||||
|
int echo;
|
||||||
|
{
|
||||||
|
extern char *getpass();
|
||||||
|
extern int globalmode;
|
||||||
|
int om = globalmode;
|
||||||
|
char *res;
|
||||||
|
|
||||||
|
TerminalNewMode(-1);
|
||||||
|
if (echo) {
|
||||||
|
printf("%s", prompt);
|
||||||
|
res = fgets(result, length, stdin);
|
||||||
|
} else if (res = getpass(prompt)) {
|
||||||
|
strncpy(result, res, length);
|
||||||
|
res = result;
|
||||||
|
}
|
||||||
|
TerminalNewMode(om);
|
||||||
|
return(res);
|
||||||
|
}
|
||||||
|
#endif /* defined(AUTHENTICATION) || defined(ENCRYPTION) */
|
2933
secure/usr.bin/telnet/commands.c
Normal file
2933
secure/usr.bin/telnet/commands.c
Normal file
File diff suppressed because it is too large
Load Diff
61
secure/usr.bin/telnet/defines.h
Normal file
61
secure/usr.bin/telnet/defines.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)defines.h 8.1 (Berkeley) 6/6/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define settimer(x) clocks.x = clocks.system++
|
||||||
|
|
||||||
|
#if !defined(TN3270)
|
||||||
|
|
||||||
|
#define SetIn3270()
|
||||||
|
|
||||||
|
#endif /* !defined(TN3270) */
|
||||||
|
|
||||||
|
#define NETADD(c) { *netoring.supply = c; ring_supplied(&netoring, 1); }
|
||||||
|
#define NET2ADD(c1,c2) { NETADD(c1); NETADD(c2); }
|
||||||
|
#define NETBYTES() (ring_full_count(&netoring))
|
||||||
|
#define NETROOM() (ring_empty_count(&netoring))
|
||||||
|
|
||||||
|
#define TTYADD(c) if (!(SYNCHing||flushout)) { \
|
||||||
|
*ttyoring.supply = c; \
|
||||||
|
ring_supplied(&ttyoring, 1); \
|
||||||
|
}
|
||||||
|
#define TTYBYTES() (ring_full_count(&ttyoring))
|
||||||
|
#define TTYROOM() (ring_empty_count(&ttyoring))
|
||||||
|
|
||||||
|
/* Various modes */
|
||||||
|
#define MODE_LOCAL_CHARS(m) ((m)&(MODE_EDIT|MODE_TRAPSIG))
|
||||||
|
#define MODE_LOCAL_ECHO(m) ((m)&MODE_ECHO)
|
||||||
|
#define MODE_COMMAND_LINE(m) ((m)==-1)
|
||||||
|
|
||||||
|
#define CONTROL(x) ((x)&0x1f) /* CTRL(x) is not portable */
|
481
secure/usr.bin/telnet/externs.h
Normal file
481
secure/usr.bin/telnet/externs.h
Normal file
@ -0,0 +1,481 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1990, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)externs.h 8.2 (Berkeley) 12/15/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef BSD
|
||||||
|
# define BSD 43
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ucb stdio.h defines BSD as something wierd
|
||||||
|
*/
|
||||||
|
#if defined(sun) && defined(__svr4__)
|
||||||
|
#define BSD 43
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef USE_TERMIO
|
||||||
|
# if BSD > 43 || defined(SYSV_TERMIO)
|
||||||
|
# define USE_TERMIO
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <setjmp.h>
|
||||||
|
#if defined(CRAY) && !defined(NO_BSD_SETJMP)
|
||||||
|
#include <bsdsetjmp.h>
|
||||||
|
#endif
|
||||||
|
#ifndef FILIO_H
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#else
|
||||||
|
#include <sys/filio.h>
|
||||||
|
#endif
|
||||||
|
#ifdef CRAY
|
||||||
|
# include <errno.h>
|
||||||
|
#endif /* CRAY */
|
||||||
|
#ifdef USE_TERMIO
|
||||||
|
# ifndef VINTR
|
||||||
|
# ifdef SYSV_TERMIO
|
||||||
|
# include <sys/termio.h>
|
||||||
|
# else
|
||||||
|
# include <sys/termios.h>
|
||||||
|
# define termio termios
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if defined(NO_CC_T) || !defined(USE_TERMIO)
|
||||||
|
# if !defined(USE_TERMIO)
|
||||||
|
typedef char cc_t;
|
||||||
|
# else
|
||||||
|
typedef unsigned char cc_t;
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef NO_STRING_H
|
||||||
|
#include <string.h>
|
||||||
|
#endif
|
||||||
|
#include <strings.h>
|
||||||
|
|
||||||
|
#ifndef _POSIX_VDISABLE
|
||||||
|
# ifdef sun
|
||||||
|
# include <sys/param.h> /* pick up VDISABLE definition, mayby */
|
||||||
|
# endif
|
||||||
|
# ifdef VDISABLE
|
||||||
|
# define _POSIX_VDISABLE VDISABLE
|
||||||
|
# else
|
||||||
|
# define _POSIX_VDISABLE ((cc_t)'\377')
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define SUBBUFSIZE 256
|
||||||
|
|
||||||
|
#ifndef CRAY
|
||||||
|
extern int errno; /* outside this world */
|
||||||
|
#endif /* !CRAY */
|
||||||
|
|
||||||
|
#if !defined(P)
|
||||||
|
# ifdef __STDC__
|
||||||
|
# define P(x) x
|
||||||
|
# else
|
||||||
|
# define P(x) ()
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern int
|
||||||
|
autologin, /* Autologin enabled */
|
||||||
|
skiprc, /* Don't process the ~/.telnetrc file */
|
||||||
|
eight, /* use eight bit mode (binary in and/or out */
|
||||||
|
flushout, /* flush output */
|
||||||
|
connected, /* Are we connected to the other side? */
|
||||||
|
globalmode, /* Mode tty should be in */
|
||||||
|
In3270, /* Are we in 3270 mode? */
|
||||||
|
telnetport, /* Are we connected to the telnet port? */
|
||||||
|
localflow, /* Flow control handled locally */
|
||||||
|
restartany, /* If flow control, restart output on any character */
|
||||||
|
localchars, /* we recognize interrupt/quit */
|
||||||
|
donelclchars, /* the user has set "localchars" */
|
||||||
|
showoptions,
|
||||||
|
net, /* Network file descriptor */
|
||||||
|
tin, /* Terminal input file descriptor */
|
||||||
|
tout, /* Terminal output file descriptor */
|
||||||
|
crlf, /* Should '\r' be mapped to <CR><LF> (or <CR><NUL>)? */
|
||||||
|
autoflush, /* flush output when interrupting? */
|
||||||
|
autosynch, /* send interrupt characters with SYNCH? */
|
||||||
|
SYNCHing, /* Is the stream in telnet SYNCH mode? */
|
||||||
|
donebinarytoggle, /* the user has put us in binary */
|
||||||
|
dontlecho, /* do we suppress local echoing right now? */
|
||||||
|
crmod,
|
||||||
|
netdata, /* Print out network data flow */
|
||||||
|
prettydump, /* Print "netdata" output in user readable format */
|
||||||
|
#if defined(unix)
|
||||||
|
#if defined(TN3270)
|
||||||
|
cursesdata, /* Print out curses data flow */
|
||||||
|
apitrace, /* Trace API transactions */
|
||||||
|
#endif /* defined(TN3270) */
|
||||||
|
termdata, /* Print out terminal data flow */
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
debug; /* Debug level */
|
||||||
|
|
||||||
|
extern cc_t escape; /* Escape to command mode */
|
||||||
|
extern cc_t rlogin; /* Rlogin mode escape character */
|
||||||
|
#ifdef KLUDGELINEMODE
|
||||||
|
extern cc_t echoc; /* Toggle local echoing */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern char
|
||||||
|
*prompt; /* Prompt for command. */
|
||||||
|
|
||||||
|
extern char
|
||||||
|
doopt[],
|
||||||
|
dont[],
|
||||||
|
will[],
|
||||||
|
wont[],
|
||||||
|
options[], /* All the little options */
|
||||||
|
*hostname; /* Who are we connected to? */
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
extern void (*encrypt_output) P((unsigned char *, int));
|
||||||
|
extern int (*decrypt_input) P((int));
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We keep track of each side of the option negotiation.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MY_STATE_WILL 0x01
|
||||||
|
#define MY_WANT_STATE_WILL 0x02
|
||||||
|
#define MY_STATE_DO 0x04
|
||||||
|
#define MY_WANT_STATE_DO 0x08
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Macros to check the current state of things
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define my_state_is_do(opt) (options[opt]&MY_STATE_DO)
|
||||||
|
#define my_state_is_will(opt) (options[opt]&MY_STATE_WILL)
|
||||||
|
#define my_want_state_is_do(opt) (options[opt]&MY_WANT_STATE_DO)
|
||||||
|
#define my_want_state_is_will(opt) (options[opt]&MY_WANT_STATE_WILL)
|
||||||
|
|
||||||
|
#define my_state_is_dont(opt) (!my_state_is_do(opt))
|
||||||
|
#define my_state_is_wont(opt) (!my_state_is_will(opt))
|
||||||
|
#define my_want_state_is_dont(opt) (!my_want_state_is_do(opt))
|
||||||
|
#define my_want_state_is_wont(opt) (!my_want_state_is_will(opt))
|
||||||
|
|
||||||
|
#define set_my_state_do(opt) {options[opt] |= MY_STATE_DO;}
|
||||||
|
#define set_my_state_will(opt) {options[opt] |= MY_STATE_WILL;}
|
||||||
|
#define set_my_want_state_do(opt) {options[opt] |= MY_WANT_STATE_DO;}
|
||||||
|
#define set_my_want_state_will(opt) {options[opt] |= MY_WANT_STATE_WILL;}
|
||||||
|
|
||||||
|
#define set_my_state_dont(opt) {options[opt] &= ~MY_STATE_DO;}
|
||||||
|
#define set_my_state_wont(opt) {options[opt] &= ~MY_STATE_WILL;}
|
||||||
|
#define set_my_want_state_dont(opt) {options[opt] &= ~MY_WANT_STATE_DO;}
|
||||||
|
#define set_my_want_state_wont(opt) {options[opt] &= ~MY_WANT_STATE_WILL;}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Make everything symetrical
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define HIS_STATE_WILL MY_STATE_DO
|
||||||
|
#define HIS_WANT_STATE_WILL MY_WANT_STATE_DO
|
||||||
|
#define HIS_STATE_DO MY_STATE_WILL
|
||||||
|
#define HIS_WANT_STATE_DO MY_WANT_STATE_WILL
|
||||||
|
|
||||||
|
#define his_state_is_do my_state_is_will
|
||||||
|
#define his_state_is_will my_state_is_do
|
||||||
|
#define his_want_state_is_do my_want_state_is_will
|
||||||
|
#define his_want_state_is_will my_want_state_is_do
|
||||||
|
|
||||||
|
#define his_state_is_dont my_state_is_wont
|
||||||
|
#define his_state_is_wont my_state_is_dont
|
||||||
|
#define his_want_state_is_dont my_want_state_is_wont
|
||||||
|
#define his_want_state_is_wont my_want_state_is_dont
|
||||||
|
|
||||||
|
#define set_his_state_do set_my_state_will
|
||||||
|
#define set_his_state_will set_my_state_do
|
||||||
|
#define set_his_want_state_do set_my_want_state_will
|
||||||
|
#define set_his_want_state_will set_my_want_state_do
|
||||||
|
|
||||||
|
#define set_his_state_dont set_my_state_wont
|
||||||
|
#define set_his_state_wont set_my_state_dont
|
||||||
|
#define set_his_want_state_dont set_my_want_state_wont
|
||||||
|
#define set_his_want_state_wont set_my_want_state_dont
|
||||||
|
|
||||||
|
|
||||||
|
extern FILE
|
||||||
|
*NetTrace; /* Where debugging output goes */
|
||||||
|
extern unsigned char
|
||||||
|
NetTraceFile[]; /* Name of file where debugging output goes */
|
||||||
|
extern void
|
||||||
|
SetNetTrace P((char *)); /* Function to change where debugging goes */
|
||||||
|
|
||||||
|
extern jmp_buf
|
||||||
|
peerdied,
|
||||||
|
toplevel; /* For error conditions. */
|
||||||
|
|
||||||
|
extern void
|
||||||
|
command P((int, char *, int)),
|
||||||
|
Dump P((int, unsigned char *, int)),
|
||||||
|
init_3270 P((void)),
|
||||||
|
printoption P((char *, int, int)),
|
||||||
|
printsub P((int, unsigned char *, int)),
|
||||||
|
sendnaws P((void)),
|
||||||
|
setconnmode P((int)),
|
||||||
|
setcommandmode P((void)),
|
||||||
|
setneturg P((void)),
|
||||||
|
sys_telnet_init P((void)),
|
||||||
|
telnet P((char *)),
|
||||||
|
tel_enter_binary P((int)),
|
||||||
|
TerminalFlushOutput P((void)),
|
||||||
|
TerminalNewMode P((int)),
|
||||||
|
TerminalRestoreState P((void)),
|
||||||
|
TerminalSaveState P((void)),
|
||||||
|
tninit P((void)),
|
||||||
|
upcase P((char *)),
|
||||||
|
willoption P((int)),
|
||||||
|
wontoption P((int));
|
||||||
|
|
||||||
|
extern void
|
||||||
|
send_do P((int, int)),
|
||||||
|
send_dont P((int, int)),
|
||||||
|
send_will P((int, int)),
|
||||||
|
send_wont P((int, int));
|
||||||
|
|
||||||
|
extern void
|
||||||
|
lm_will P((unsigned char *, int)),
|
||||||
|
lm_wont P((unsigned char *, int)),
|
||||||
|
lm_do P((unsigned char *, int)),
|
||||||
|
lm_dont P((unsigned char *, int)),
|
||||||
|
lm_mode P((unsigned char *, int, int));
|
||||||
|
|
||||||
|
extern void
|
||||||
|
slc_init P((void)),
|
||||||
|
slcstate P((void)),
|
||||||
|
slc_mode_export P((void)),
|
||||||
|
slc_mode_import P((int)),
|
||||||
|
slc_import P((int)),
|
||||||
|
slc_export P((void)),
|
||||||
|
slc P((unsigned char *, int)),
|
||||||
|
slc_check P((void)),
|
||||||
|
slc_start_reply P((void)),
|
||||||
|
slc_add_reply P((int, int, int)),
|
||||||
|
slc_end_reply P((void));
|
||||||
|
extern int
|
||||||
|
slc_update P((void));
|
||||||
|
|
||||||
|
extern void
|
||||||
|
env_opt P((unsigned char *, int)),
|
||||||
|
env_opt_start P((void)),
|
||||||
|
env_opt_start_info P((void)),
|
||||||
|
env_opt_add P((unsigned char *)),
|
||||||
|
env_opt_end P((int));
|
||||||
|
|
||||||
|
extern unsigned char
|
||||||
|
*env_default P((int, int)),
|
||||||
|
*env_getvalue P((unsigned char *));
|
||||||
|
|
||||||
|
extern int
|
||||||
|
get_status P((void)),
|
||||||
|
dosynch P((void));
|
||||||
|
|
||||||
|
extern cc_t
|
||||||
|
*tcval P((int));
|
||||||
|
|
||||||
|
#ifndef USE_TERMIO
|
||||||
|
|
||||||
|
extern struct tchars ntc;
|
||||||
|
extern struct ltchars nltc;
|
||||||
|
extern struct sgttyb nttyb;
|
||||||
|
|
||||||
|
# define termEofChar ntc.t_eofc
|
||||||
|
# define termEraseChar nttyb.sg_erase
|
||||||
|
# define termFlushChar nltc.t_flushc
|
||||||
|
# define termIntChar ntc.t_intrc
|
||||||
|
# define termKillChar nttyb.sg_kill
|
||||||
|
# define termLiteralNextChar nltc.t_lnextc
|
||||||
|
# define termQuitChar ntc.t_quitc
|
||||||
|
# define termSuspChar nltc.t_suspc
|
||||||
|
# define termRprntChar nltc.t_rprntc
|
||||||
|
# define termWerasChar nltc.t_werasc
|
||||||
|
# define termStartChar ntc.t_startc
|
||||||
|
# define termStopChar ntc.t_stopc
|
||||||
|
# define termForw1Char ntc.t_brkc
|
||||||
|
extern cc_t termForw2Char;
|
||||||
|
extern cc_t termAytChar;
|
||||||
|
|
||||||
|
# define termEofCharp (cc_t *)&ntc.t_eofc
|
||||||
|
# define termEraseCharp (cc_t *)&nttyb.sg_erase
|
||||||
|
# define termFlushCharp (cc_t *)&nltc.t_flushc
|
||||||
|
# define termIntCharp (cc_t *)&ntc.t_intrc
|
||||||
|
# define termKillCharp (cc_t *)&nttyb.sg_kill
|
||||||
|
# define termLiteralNextCharp (cc_t *)&nltc.t_lnextc
|
||||||
|
# define termQuitCharp (cc_t *)&ntc.t_quitc
|
||||||
|
# define termSuspCharp (cc_t *)&nltc.t_suspc
|
||||||
|
# define termRprntCharp (cc_t *)&nltc.t_rprntc
|
||||||
|
# define termWerasCharp (cc_t *)&nltc.t_werasc
|
||||||
|
# define termStartCharp (cc_t *)&ntc.t_startc
|
||||||
|
# define termStopCharp (cc_t *)&ntc.t_stopc
|
||||||
|
# define termForw1Charp (cc_t *)&ntc.t_brkc
|
||||||
|
# define termForw2Charp (cc_t *)&termForw2Char
|
||||||
|
# define termAytCharp (cc_t *)&termAytChar
|
||||||
|
|
||||||
|
# else
|
||||||
|
|
||||||
|
extern struct termio new_tc;
|
||||||
|
|
||||||
|
# define termEofChar new_tc.c_cc[VEOF]
|
||||||
|
# define termEraseChar new_tc.c_cc[VERASE]
|
||||||
|
# define termIntChar new_tc.c_cc[VINTR]
|
||||||
|
# define termKillChar new_tc.c_cc[VKILL]
|
||||||
|
# define termQuitChar new_tc.c_cc[VQUIT]
|
||||||
|
|
||||||
|
# ifndef VSUSP
|
||||||
|
extern cc_t termSuspChar;
|
||||||
|
# else
|
||||||
|
# define termSuspChar new_tc.c_cc[VSUSP]
|
||||||
|
# endif
|
||||||
|
# if defined(VFLUSHO) && !defined(VDISCARD)
|
||||||
|
# define VDISCARD VFLUSHO
|
||||||
|
# endif
|
||||||
|
# ifndef VDISCARD
|
||||||
|
extern cc_t termFlushChar;
|
||||||
|
# else
|
||||||
|
# define termFlushChar new_tc.c_cc[VDISCARD]
|
||||||
|
# endif
|
||||||
|
# ifndef VWERASE
|
||||||
|
extern cc_t termWerasChar;
|
||||||
|
# else
|
||||||
|
# define termWerasChar new_tc.c_cc[VWERASE]
|
||||||
|
# endif
|
||||||
|
# ifndef VREPRINT
|
||||||
|
extern cc_t termRprntChar;
|
||||||
|
# else
|
||||||
|
# define termRprntChar new_tc.c_cc[VREPRINT]
|
||||||
|
# endif
|
||||||
|
# ifndef VLNEXT
|
||||||
|
extern cc_t termLiteralNextChar;
|
||||||
|
# else
|
||||||
|
# define termLiteralNextChar new_tc.c_cc[VLNEXT]
|
||||||
|
# endif
|
||||||
|
# ifndef VSTART
|
||||||
|
extern cc_t termStartChar;
|
||||||
|
# else
|
||||||
|
# define termStartChar new_tc.c_cc[VSTART]
|
||||||
|
# endif
|
||||||
|
# ifndef VSTOP
|
||||||
|
extern cc_t termStopChar;
|
||||||
|
# else
|
||||||
|
# define termStopChar new_tc.c_cc[VSTOP]
|
||||||
|
# endif
|
||||||
|
# ifndef VEOL
|
||||||
|
extern cc_t termForw1Char;
|
||||||
|
# else
|
||||||
|
# define termForw1Char new_tc.c_cc[VEOL]
|
||||||
|
# endif
|
||||||
|
# ifndef VEOL2
|
||||||
|
extern cc_t termForw2Char;
|
||||||
|
# else
|
||||||
|
# define termForw2Char new_tc.c_cc[VEOL]
|
||||||
|
# endif
|
||||||
|
# ifndef VSTATUS
|
||||||
|
extern cc_t termAytChar;
|
||||||
|
#else
|
||||||
|
# define termAytChar new_tc.c_cc[VSTATUS]
|
||||||
|
#endif
|
||||||
|
|
||||||
|
# if !defined(CRAY) || defined(__STDC__)
|
||||||
|
# define termEofCharp &termEofChar
|
||||||
|
# define termEraseCharp &termEraseChar
|
||||||
|
# define termIntCharp &termIntChar
|
||||||
|
# define termKillCharp &termKillChar
|
||||||
|
# define termQuitCharp &termQuitChar
|
||||||
|
# define termSuspCharp &termSuspChar
|
||||||
|
# define termFlushCharp &termFlushChar
|
||||||
|
# define termWerasCharp &termWerasChar
|
||||||
|
# define termRprntCharp &termRprntChar
|
||||||
|
# define termLiteralNextCharp &termLiteralNextChar
|
||||||
|
# define termStartCharp &termStartChar
|
||||||
|
# define termStopCharp &termStopChar
|
||||||
|
# define termForw1Charp &termForw1Char
|
||||||
|
# define termForw2Charp &termForw2Char
|
||||||
|
# define termAytCharp &termAytChar
|
||||||
|
# else
|
||||||
|
/* Work around a compiler bug */
|
||||||
|
# define termEofCharp 0
|
||||||
|
# define termEraseCharp 0
|
||||||
|
# define termIntCharp 0
|
||||||
|
# define termKillCharp 0
|
||||||
|
# define termQuitCharp 0
|
||||||
|
# define termSuspCharp 0
|
||||||
|
# define termFlushCharp 0
|
||||||
|
# define termWerasCharp 0
|
||||||
|
# define termRprntCharp 0
|
||||||
|
# define termLiteralNextCharp 0
|
||||||
|
# define termStartCharp 0
|
||||||
|
# define termStopCharp 0
|
||||||
|
# define termForw1Charp 0
|
||||||
|
# define termForw2Charp 0
|
||||||
|
# define termAytCharp 0
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Ring buffer structures which are shared */
|
||||||
|
|
||||||
|
extern Ring
|
||||||
|
netoring,
|
||||||
|
netiring,
|
||||||
|
ttyoring,
|
||||||
|
ttyiring;
|
||||||
|
|
||||||
|
/* Tn3270 section */
|
||||||
|
#if defined(TN3270)
|
||||||
|
|
||||||
|
extern int
|
||||||
|
HaveInput, /* Whether an asynchronous I/O indication came in */
|
||||||
|
noasynchtty, /* Don't do signals on I/O (SIGURG, SIGIO) */
|
||||||
|
noasynchnet, /* Don't do signals on I/O (SIGURG, SIGIO) */
|
||||||
|
sigiocount, /* Count of SIGIO receptions */
|
||||||
|
shell_active; /* Subshell is active */
|
||||||
|
|
||||||
|
extern char
|
||||||
|
*Ibackp, /* Oldest byte of 3270 data */
|
||||||
|
Ibuf[], /* 3270 buffer */
|
||||||
|
*Ifrontp, /* Where next 3270 byte goes */
|
||||||
|
tline[],
|
||||||
|
*transcom; /* Transparent command */
|
||||||
|
|
||||||
|
extern int
|
||||||
|
settranscom P((int, char**));
|
||||||
|
|
||||||
|
extern void
|
||||||
|
inputAvailable P((int));
|
||||||
|
#endif /* defined(TN3270) */
|
49
secure/usr.bin/telnet/fdset.h
Normal file
49
secure/usr.bin/telnet/fdset.h
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)fdset.h 8.1 (Berkeley) 6/6/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following is defined just in case someone should want to run
|
||||||
|
* this telnet on a 4.2 system.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef FD_SETSIZE
|
||||||
|
|
||||||
|
#define FD_SET(n, p) ((p)->fds_bits[0] |= (1<<(n)))
|
||||||
|
#define FD_CLR(n, p) ((p)->fds_bits[0] &= ~(1<<(n)))
|
||||||
|
#define FD_ISSET(n, p) ((p)->fds_bits[0] & (1<<(n)))
|
||||||
|
#define FD_ZERO(p) ((p)->fds_bits[0] = 0)
|
||||||
|
|
||||||
|
#endif
|
45
secure/usr.bin/telnet/general.h
Normal file
45
secure/usr.bin/telnet/general.h
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)general.h 8.1 (Berkeley) 6/6/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Some general definitions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#define numberof(x) (sizeof x/sizeof x[0])
|
||||||
|
#define highestof(x) (numberof(x)-1)
|
||||||
|
|
||||||
|
#define ClearElement(x) memset((char *)&x, 0, sizeof x)
|
||||||
|
#define ClearArray(x) memset((char *)x, 0, sizeof x)
|
207
secure/usr.bin/telnet/krb4-proto.h
Normal file
207
secure/usr.bin/telnet/krb4-proto.h
Normal file
@ -0,0 +1,207 @@
|
|||||||
|
#ifdef __STDC__
|
||||||
|
# define P(s) s
|
||||||
|
#else
|
||||||
|
# define P(s) ()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* add_ticket.c */
|
||||||
|
int add_ticket P((KTEXT , int , char *, int , char *, char *, char *, int , KTEXT ));
|
||||||
|
|
||||||
|
/* cr_err_reply.c */
|
||||||
|
void cr_err_reply P((KTEXT , char *, char *, char *, u_long , u_long , char *));
|
||||||
|
|
||||||
|
/* create_auth_reply.c */
|
||||||
|
KTEXT create_auth_reply P((char *, char *, char *, long , int , unsigned long , int , KTEXT ));
|
||||||
|
|
||||||
|
/* create_ciph.c */
|
||||||
|
int create_ciph P((KTEXT , C_Block , char *, char *, char *, unsigned long , int , KTEXT , unsigned long , C_Block ));
|
||||||
|
|
||||||
|
/* create_death_packet.c */
|
||||||
|
KTEXT krb_create_death_packet P((char *));
|
||||||
|
|
||||||
|
/* create_ticket.c */
|
||||||
|
int krb_create_ticket P((KTEXT , unsigned int , char *, char *, char *, long , char *, int , long , char *, char *, C_Block ));
|
||||||
|
|
||||||
|
/* debug_decl.c */
|
||||||
|
|
||||||
|
/* decomp_ticket.c */
|
||||||
|
int decomp_ticket P((KTEXT , unsigned char *, char *, char *, char *, unsigned long *, C_Block , int *, unsigned long *, char *, char *, C_Block , Key_schedule ));
|
||||||
|
|
||||||
|
/* dest_tkt.c */
|
||||||
|
int dest_tkt P((void ));
|
||||||
|
|
||||||
|
/* extract_ticket.c */
|
||||||
|
int extract_ticket P((KTEXT , int , char *, int *, int *, char *, KTEXT ));
|
||||||
|
|
||||||
|
/* fgetst.c */
|
||||||
|
int fgetst P((FILE *, char *, int ));
|
||||||
|
|
||||||
|
/* get_ad_tkt.c */
|
||||||
|
int get_ad_tkt P((char *, char *, char *, int ));
|
||||||
|
|
||||||
|
/* get_admhst.c */
|
||||||
|
int krb_get_admhst P((char *, char *, int ));
|
||||||
|
|
||||||
|
/* get_cred.c */
|
||||||
|
int krb_get_cred P((char *, char *, char *, CREDENTIALS *));
|
||||||
|
|
||||||
|
/* get_in_tkt.c */
|
||||||
|
int krb_get_pw_in_tkt P((char *, char *, char *, char *, char *, int , char *));
|
||||||
|
int placebo_read_password P((des_cblock *, char *, int ));
|
||||||
|
int placebo_read_pw_string P((char *, int , char *, int ));
|
||||||
|
|
||||||
|
/* get_krbhst.c */
|
||||||
|
int krb_get_krbhst P((char *, char *, int ));
|
||||||
|
|
||||||
|
/* get_krbrlm.c */
|
||||||
|
int krb_get_lrealm P((char *, int ));
|
||||||
|
|
||||||
|
/* get_phost.c */
|
||||||
|
char *krb_get_phost P((char *));
|
||||||
|
|
||||||
|
/* get_pw_tkt.c */
|
||||||
|
int get_pw_tkt P((char *, char *, char *, char *));
|
||||||
|
|
||||||
|
/* get_request.c */
|
||||||
|
int get_request P((KTEXT , int , char **, char **));
|
||||||
|
|
||||||
|
/* get_svc_in_tkt.c */
|
||||||
|
int krb_get_svc_in_tkt P((char *, char *, char *, char *, char *, int , char *));
|
||||||
|
|
||||||
|
/* get_tf_fullname.c */
|
||||||
|
int krb_get_tf_fullname P((char *, char *, char *, char *));
|
||||||
|
|
||||||
|
/* get_tf_realm.c */
|
||||||
|
int krb_get_tf_realm P((char *, char *));
|
||||||
|
|
||||||
|
/* getopt.c */
|
||||||
|
int getopt P((int , char **, char *));
|
||||||
|
|
||||||
|
/* getrealm.c */
|
||||||
|
char *krb_realmofhost P((char *));
|
||||||
|
|
||||||
|
/* getst.c */
|
||||||
|
int getst P((int , char *, int ));
|
||||||
|
|
||||||
|
/* in_tkt.c */
|
||||||
|
int in_tkt P((char *, char *));
|
||||||
|
|
||||||
|
/* k_gethostname.c */
|
||||||
|
int k_gethostname P((char *, int ));
|
||||||
|
|
||||||
|
/* klog.c */
|
||||||
|
char *klog P((int , char *, int , int , int , int , int , int , int , int , int , int ));
|
||||||
|
int kset_logfile P((char *));
|
||||||
|
|
||||||
|
/* kname_parse.c */
|
||||||
|
int kname_parse P((char *, char *, char *, char *));
|
||||||
|
int k_isname P((char *));
|
||||||
|
int k_isinst P((char *));
|
||||||
|
int k_isrealm P((char *));
|
||||||
|
|
||||||
|
/* kntoln.c */
|
||||||
|
int krb_kntoln P((AUTH_DAT *, char *));
|
||||||
|
|
||||||
|
/* krb_err_txt.c */
|
||||||
|
|
||||||
|
/* krb_get_in_tkt.c */
|
||||||
|
int krb_get_in_tkt P((char *, char *, char *, char *, char *, int , int (*key_proc )(), int (*decrypt_proc )(), char *));
|
||||||
|
|
||||||
|
/* kuserok.c */
|
||||||
|
int kuserok P((AUTH_DAT *, char *));
|
||||||
|
|
||||||
|
/* log.c */
|
||||||
|
void log P((char *, int , int , int , int , int , int , int , int , int , int ));
|
||||||
|
int set_logfile P((char *));
|
||||||
|
int new_log P((long , char *));
|
||||||
|
|
||||||
|
/* mk_err.c */
|
||||||
|
long krb_mk_err P((u_char *, long , char *));
|
||||||
|
|
||||||
|
/* mk_priv.c */
|
||||||
|
long krb_mk_priv P((u_char *, u_char *, u_long , Key_schedule , C_Block , struct sockaddr_in *, struct sockaddr_in *));
|
||||||
|
|
||||||
|
/* mk_req.c */
|
||||||
|
int krb_mk_req P((KTEXT , char *, char *, char *, long ));
|
||||||
|
int krb_set_lifetime P((int ));
|
||||||
|
|
||||||
|
/* mk_safe.c */
|
||||||
|
long krb_mk_safe P((u_char *, u_char *, u_long , C_Block *, struct sockaddr_in *, struct sockaddr_in *));
|
||||||
|
|
||||||
|
/* month_sname.c */
|
||||||
|
char *month_sname P((int ));
|
||||||
|
|
||||||
|
/* netread.c */
|
||||||
|
int krb_net_read P((int , char *, int ));
|
||||||
|
|
||||||
|
/* netwrite.c */
|
||||||
|
int krb_net_write P((int , char *, int ));
|
||||||
|
|
||||||
|
/* one.c */
|
||||||
|
|
||||||
|
/* pkt_cipher.c */
|
||||||
|
KTEXT pkt_cipher P((KTEXT ));
|
||||||
|
|
||||||
|
/* pkt_clen.c */
|
||||||
|
int pkt_clen P((KTEXT ));
|
||||||
|
|
||||||
|
/* rd_err.c */
|
||||||
|
int krb_rd_err P((u_char *, u_long , long *, MSG_DAT *));
|
||||||
|
|
||||||
|
/* rd_priv.c */
|
||||||
|
long krb_rd_priv P((u_char *, u_long , Key_schedule , C_Block , struct sockaddr_in *, struct sockaddr_in *, MSG_DAT *));
|
||||||
|
|
||||||
|
/* rd_req.c */
|
||||||
|
int krb_set_key P((char *, int ));
|
||||||
|
int krb_rd_req P((KTEXT , char *, char *, long , AUTH_DAT *, char *));
|
||||||
|
|
||||||
|
/* rd_safe.c */
|
||||||
|
long krb_rd_safe P((u_char *, u_long , C_Block *, struct sockaddr_in *, struct sockaddr_in *, MSG_DAT *));
|
||||||
|
|
||||||
|
/* read_service_key.c */
|
||||||
|
int read_service_key P((char *, char *, char *, int , char *, char *));
|
||||||
|
|
||||||
|
/* recvauth.c */
|
||||||
|
int krb_recvauth P((long , int , KTEXT , char *, char *, struct sockaddr_in *, struct sockaddr_in *, AUTH_DAT *, char *, Key_schedule , char *));
|
||||||
|
|
||||||
|
/* save_credentials.c */
|
||||||
|
int save_credentials P((char *, char *, char *, C_Block , int , int , KTEXT , long ));
|
||||||
|
|
||||||
|
/* send_to_kdc.c */
|
||||||
|
int send_to_kdc P((KTEXT , KTEXT , char *));
|
||||||
|
|
||||||
|
/* sendauth.c */
|
||||||
|
int krb_sendauth P((long , int , KTEXT , char *, char *, char *, u_long , MSG_DAT *, CREDENTIALS *, Key_schedule , struct sockaddr_in *, struct sockaddr_in *, char *));
|
||||||
|
int krb_sendsvc P((int , char *));
|
||||||
|
|
||||||
|
/* setenv.c */
|
||||||
|
int setenv P((char *, char *, int ));
|
||||||
|
void unsetenv P((char *));
|
||||||
|
char *getenv P((char *));
|
||||||
|
char *_findenv P((char *, int *));
|
||||||
|
|
||||||
|
/* stime.c */
|
||||||
|
char *stime P((long *));
|
||||||
|
|
||||||
|
/* tf_shm.c */
|
||||||
|
int krb_shm_create P((char *));
|
||||||
|
int krb_is_diskless P((void ));
|
||||||
|
int krb_shm_dest P((char *));
|
||||||
|
|
||||||
|
/* tf_util.c */
|
||||||
|
int tf_init P((char *, int ));
|
||||||
|
int tf_get_pname P((char *));
|
||||||
|
int tf_get_pinst P((char *));
|
||||||
|
int tf_get_cred P((CREDENTIALS *));
|
||||||
|
int tf_close P((void ));
|
||||||
|
int tf_save_cred P((char *, char *, char *, C_Block , int , int , KTEXT , long ));
|
||||||
|
|
||||||
|
/* tkt_string.c */
|
||||||
|
char *tkt_string P((void ));
|
||||||
|
void krb_set_tkt_string P((char *));
|
||||||
|
|
||||||
|
/* util.c */
|
||||||
|
int ad_print P((AUTH_DAT *));
|
||||||
|
int placebo_cblock_print P((des_cblock ));
|
||||||
|
|
||||||
|
#undef P
|
322
secure/usr.bin/telnet/main.c
Normal file
322
secure/usr.bin/telnet/main.c
Normal file
@ -0,0 +1,322 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1990, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char copyright[] =
|
||||||
|
"@(#) Copyright (c) 1988, 1990, 1993\n\
|
||||||
|
The Regents of the University of California. All rights reserved.\n";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)main.c 8.2 (Berkeley) 12/15/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include "ring.h"
|
||||||
|
#include "externs.h"
|
||||||
|
#include "defines.h"
|
||||||
|
|
||||||
|
/* These values need to be the same as defined in libtelnet/kerberos5.c */
|
||||||
|
/* Either define them in both places, or put in some common header file. */
|
||||||
|
#define OPTS_FORWARD_CREDS 0x00000002
|
||||||
|
#define OPTS_FORWARDABLE_CREDS 0x00000001
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
#define FORWARD
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialize variables.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
tninit()
|
||||||
|
{
|
||||||
|
init_terminal();
|
||||||
|
|
||||||
|
init_network();
|
||||||
|
|
||||||
|
init_telnet();
|
||||||
|
|
||||||
|
init_sys();
|
||||||
|
|
||||||
|
#if defined(TN3270)
|
||||||
|
init_3270();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
usage()
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Usage: %s %s%s%s%s\n",
|
||||||
|
prompt,
|
||||||
|
#ifdef AUTHENTICATION
|
||||||
|
"[-8] [-E] [-K] [-L] [-S tos] [-X atype] [-a] [-c] [-d] [-e char]",
|
||||||
|
"\n\t[-k realm] [-l user] [-f/-F] [-n tracefile] ",
|
||||||
|
#else
|
||||||
|
"[-8] [-E] [-L] [-S tos] [-a] [-c] [-d] [-e char] [-l user]",
|
||||||
|
"\n\t[-n tracefile]",
|
||||||
|
#endif
|
||||||
|
#if defined(TN3270) && defined(unix)
|
||||||
|
# ifdef AUTHENTICATION
|
||||||
|
"[-noasynch] [-noasynctty]\n\t[-noasyncnet] [-r] [-t transcom] ",
|
||||||
|
# else
|
||||||
|
"[-noasynch] [-noasynctty] [-noasyncnet] [-r]\n\t[-t transcom]",
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
"[-r] ",
|
||||||
|
#endif
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
"[-x] [host-name [port]]"
|
||||||
|
#else /* ENCRYPTION */
|
||||||
|
"[host-name [port]]"
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* main. Parse arguments, invoke the protocol or command parser.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
main(argc, argv)
|
||||||
|
int argc;
|
||||||
|
char *argv[];
|
||||||
|
{
|
||||||
|
extern char *optarg;
|
||||||
|
extern int optind;
|
||||||
|
int ch;
|
||||||
|
char *user, *strrchr();
|
||||||
|
#ifdef FORWARD
|
||||||
|
extern int forward_flags;
|
||||||
|
#endif /* FORWARD */
|
||||||
|
|
||||||
|
tninit(); /* Clear out things */
|
||||||
|
#if defined(CRAY) && !defined(__STDC__)
|
||||||
|
_setlist_init(); /* Work around compiler bug */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
TerminalSaveState();
|
||||||
|
|
||||||
|
if (prompt = strrchr(argv[0], '/'))
|
||||||
|
++prompt;
|
||||||
|
else
|
||||||
|
prompt = argv[0];
|
||||||
|
|
||||||
|
user = NULL;
|
||||||
|
|
||||||
|
rlogin = (strncmp(prompt, "rlog", 4) == 0) ? '~' : _POSIX_VDISABLE;
|
||||||
|
autologin = -1;
|
||||||
|
|
||||||
|
while ((ch = getopt(argc, argv, "8EKLS:X:acde:fFk:l:n:rt:x")) != EOF) {
|
||||||
|
switch(ch) {
|
||||||
|
case '8':
|
||||||
|
eight = 3; /* binary output and input */
|
||||||
|
break;
|
||||||
|
case 'E':
|
||||||
|
rlogin = escape = _POSIX_VDISABLE;
|
||||||
|
break;
|
||||||
|
case 'K':
|
||||||
|
#ifdef AUTHENTICATION
|
||||||
|
autologin = 0;
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'L':
|
||||||
|
eight |= 2; /* binary output only */
|
||||||
|
break;
|
||||||
|
case 'S':
|
||||||
|
{
|
||||||
|
#ifdef HAS_GETTOS
|
||||||
|
extern int tos;
|
||||||
|
|
||||||
|
if ((tos = parsetos(optarg, "tcp")) < 0)
|
||||||
|
fprintf(stderr, "%s%s%s%s\n",
|
||||||
|
prompt, ": Bad TOS argument '",
|
||||||
|
optarg,
|
||||||
|
"; will try to use default TOS");
|
||||||
|
#else
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -S ignored, no parsetos() support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'X':
|
||||||
|
#ifdef AUTHENTICATION
|
||||||
|
auth_disable_name(optarg);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'a':
|
||||||
|
autologin = 1;
|
||||||
|
break;
|
||||||
|
case 'c':
|
||||||
|
skiprc = 1;
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
debug = 1;
|
||||||
|
break;
|
||||||
|
case 'e':
|
||||||
|
set_escape_char(optarg);
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
#if defined(AUTHENTICATION) && defined(KRB5) && defined(FORWARD)
|
||||||
|
if (forward_flags & OPTS_FORWARD_CREDS) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Only one of -f and -F allowed.\n",
|
||||||
|
prompt);
|
||||||
|
usage();
|
||||||
|
}
|
||||||
|
forward_flags |= OPTS_FORWARD_CREDS;
|
||||||
|
#else
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -f ignored, no Kerberos V5 support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'F':
|
||||||
|
#if defined(AUTHENTICATION) && defined(KRB5) && defined(FORWARD)
|
||||||
|
if (forward_flags & OPTS_FORWARD_CREDS) {
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Only one of -f and -F allowed.\n",
|
||||||
|
prompt);
|
||||||
|
usage();
|
||||||
|
}
|
||||||
|
forward_flags |= OPTS_FORWARD_CREDS;
|
||||||
|
forward_flags |= OPTS_FORWARDABLE_CREDS;
|
||||||
|
#else
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -F ignored, no Kerberos V5 support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'k':
|
||||||
|
#if defined(AUTHENTICATION) && defined(KRB4)
|
||||||
|
{
|
||||||
|
extern char *dest_realm, dst_realm_buf[], dst_realm_sz;
|
||||||
|
dest_realm = dst_realm_buf;
|
||||||
|
(void)strncpy(dest_realm, optarg, dst_realm_sz);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -k ignored, no Kerberos V4 support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'l':
|
||||||
|
autologin = 1;
|
||||||
|
user = optarg;
|
||||||
|
break;
|
||||||
|
case 'n':
|
||||||
|
#if defined(TN3270) && defined(unix)
|
||||||
|
/* distinguish between "-n oasynch" and "-noasynch" */
|
||||||
|
if (argv[optind - 1][0] == '-' && argv[optind - 1][1]
|
||||||
|
== 'n' && argv[optind - 1][2] == 'o') {
|
||||||
|
if (!strcmp(optarg, "oasynch")) {
|
||||||
|
noasynchtty = 1;
|
||||||
|
noasynchnet = 1;
|
||||||
|
} else if (!strcmp(optarg, "oasynchtty"))
|
||||||
|
noasynchtty = 1;
|
||||||
|
else if (!strcmp(optarg, "oasynchnet"))
|
||||||
|
noasynchnet = 1;
|
||||||
|
} else
|
||||||
|
#endif /* defined(TN3270) && defined(unix) */
|
||||||
|
SetNetTrace(optarg);
|
||||||
|
break;
|
||||||
|
case 'r':
|
||||||
|
rlogin = '~';
|
||||||
|
break;
|
||||||
|
case 't':
|
||||||
|
#if defined(TN3270) && defined(unix)
|
||||||
|
transcom = tline;
|
||||||
|
(void)strcpy(transcom, optarg);
|
||||||
|
#else
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -t ignored, no TN3270 support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case 'x':
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
encrypt_auto(1);
|
||||||
|
decrypt_auto(1);
|
||||||
|
#else /* ENCRYPTION */
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: Warning: -x ignored, no ENCRYPT support.\n",
|
||||||
|
prompt);
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
break;
|
||||||
|
case '?':
|
||||||
|
default:
|
||||||
|
usage();
|
||||||
|
/* NOTREACHED */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (autologin == -1)
|
||||||
|
autologin = (rlogin == _POSIX_VDISABLE) ? 0 : 1;
|
||||||
|
|
||||||
|
argc -= optind;
|
||||||
|
argv += optind;
|
||||||
|
|
||||||
|
if (argc) {
|
||||||
|
char *args[7], **argp = args;
|
||||||
|
|
||||||
|
if (argc > 2)
|
||||||
|
usage();
|
||||||
|
*argp++ = prompt;
|
||||||
|
if (user) {
|
||||||
|
*argp++ = "-l";
|
||||||
|
*argp++ = user;
|
||||||
|
}
|
||||||
|
*argp++ = argv[0]; /* host */
|
||||||
|
if (argc > 1)
|
||||||
|
*argp++ = argv[1]; /* port */
|
||||||
|
*argp = 0;
|
||||||
|
|
||||||
|
if (setjmp(toplevel) != 0)
|
||||||
|
Exit(0);
|
||||||
|
if (tn(argp - args, args) == 1)
|
||||||
|
return (0);
|
||||||
|
else
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
(void)setjmp(toplevel);
|
||||||
|
for (;;) {
|
||||||
|
#ifdef TN3270
|
||||||
|
if (shell_active)
|
||||||
|
shell_continue();
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
command(1, 0, 0);
|
||||||
|
}
|
||||||
|
}
|
177
secure/usr.bin/telnet/network.c
Normal file
177
secure/usr.bin/telnet/network.c
Normal file
@ -0,0 +1,177 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)network.c 8.2 (Berkeley) 12/15/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
#include <arpa/telnet.h>
|
||||||
|
|
||||||
|
#include "ring.h"
|
||||||
|
|
||||||
|
#include "defines.h"
|
||||||
|
#include "externs.h"
|
||||||
|
#include "fdset.h"
|
||||||
|
|
||||||
|
Ring netoring, netiring;
|
||||||
|
unsigned char netobuf[2*BUFSIZ], netibuf[BUFSIZ];
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialize internal network data structures.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
init_network()
|
||||||
|
{
|
||||||
|
if (ring_init(&netoring, netobuf, sizeof netobuf) != 1) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (ring_init(&netiring, netibuf, sizeof netibuf) != 1) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
NetTrace = stdout;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check to see if any out-of-band data exists on a socket (for
|
||||||
|
* Telnet "synch" processing).
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
stilloob()
|
||||||
|
{
|
||||||
|
static struct timeval timeout = { 0 };
|
||||||
|
fd_set excepts;
|
||||||
|
int value;
|
||||||
|
|
||||||
|
do {
|
||||||
|
FD_ZERO(&excepts);
|
||||||
|
FD_SET(net, &excepts);
|
||||||
|
value = select(net+1, (fd_set *)0, (fd_set *)0, &excepts, &timeout);
|
||||||
|
} while ((value == -1) && (errno == EINTR));
|
||||||
|
|
||||||
|
if (value < 0) {
|
||||||
|
perror("select");
|
||||||
|
(void) quit();
|
||||||
|
/* NOTREACHED */
|
||||||
|
}
|
||||||
|
if (FD_ISSET(net, &excepts)) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* setneturg()
|
||||||
|
*
|
||||||
|
* Sets "neturg" to the current location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
setneturg()
|
||||||
|
{
|
||||||
|
ring_mark(&netoring);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* netflush
|
||||||
|
* Send as much data as possible to the network,
|
||||||
|
* handling requests for urgent data.
|
||||||
|
*
|
||||||
|
* The return value indicates whether we did any
|
||||||
|
* useful work.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
netflush()
|
||||||
|
{
|
||||||
|
register int n, n1;
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
if (encrypt_output)
|
||||||
|
ring_encrypt(&netoring, encrypt_output);
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
if ((n1 = n = ring_full_consecutive(&netoring)) > 0) {
|
||||||
|
if (!ring_at_mark(&netoring)) {
|
||||||
|
n = send(net, (char *)netoring.consume, n, 0); /* normal write */
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* In 4.2 (and 4.3) systems, there is some question about
|
||||||
|
* what byte in a sendOOB operation is the "OOB" data.
|
||||||
|
* To make ourselves compatible, we only send ONE byte
|
||||||
|
* out of band, the one WE THINK should be OOB (though
|
||||||
|
* we really have more the TCP philosophy of urgent data
|
||||||
|
* rather than the Unix philosophy of OOB data).
|
||||||
|
*/
|
||||||
|
n = send(net, (char *)netoring.consume, 1, MSG_OOB);/* URGENT data */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (n < 0) {
|
||||||
|
if (errno != ENOBUFS && errno != EWOULDBLOCK) {
|
||||||
|
setcommandmode();
|
||||||
|
perror(hostname);
|
||||||
|
(void)NetClose(net);
|
||||||
|
ring_clear_mark(&netoring);
|
||||||
|
longjmp(peerdied, -1);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
n = 0;
|
||||||
|
}
|
||||||
|
if (netdata && n) {
|
||||||
|
Dump('>', netoring.consume, n);
|
||||||
|
}
|
||||||
|
if (n) {
|
||||||
|
ring_consumed(&netoring, n);
|
||||||
|
/*
|
||||||
|
* If we sent all, and more to send, then recurse to pick
|
||||||
|
* up the other half.
|
||||||
|
*/
|
||||||
|
if ((n1 == n) && ring_full_consecutive(&netoring)) {
|
||||||
|
(void) netflush();
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
362
secure/usr.bin/telnet/ring.c
Normal file
362
secure/usr.bin/telnet/ring.c
Normal file
@ -0,0 +1,362 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)ring.c 8.1 (Berkeley) 6/6/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This defines a structure for a ring buffer.
|
||||||
|
*
|
||||||
|
* The circular buffer has two parts:
|
||||||
|
*(((
|
||||||
|
* full: [consume, supply)
|
||||||
|
* empty: [supply, consume)
|
||||||
|
*]]]
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
#ifdef size_t
|
||||||
|
#undef size_t
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#ifndef FILIO_H
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#endif
|
||||||
|
#include <sys/socket.h>
|
||||||
|
|
||||||
|
#include "ring.h"
|
||||||
|
#include "general.h"
|
||||||
|
|
||||||
|
/* Internal macros */
|
||||||
|
|
||||||
|
#if !defined(MIN)
|
||||||
|
#define MIN(a,b) (((a)<(b))? (a):(b))
|
||||||
|
#endif /* !defined(MIN) */
|
||||||
|
|
||||||
|
#define ring_subtract(d,a,b) (((a)-(b) >= 0)? \
|
||||||
|
(a)-(b): (((a)-(b))+(d)->size))
|
||||||
|
|
||||||
|
#define ring_increment(d,a,c) (((a)+(c) < (d)->top)? \
|
||||||
|
(a)+(c) : (((a)+(c))-(d)->size))
|
||||||
|
|
||||||
|
#define ring_decrement(d,a,c) (((a)-(c) >= (d)->bottom)? \
|
||||||
|
(a)-(c) : (((a)-(c))-(d)->size))
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following is a clock, used to determine full, empty, etc.
|
||||||
|
*
|
||||||
|
* There is some trickiness here. Since the ring buffers are initialized
|
||||||
|
* to ZERO on allocation, we need to make sure, when interpreting the
|
||||||
|
* clock, that when the times are EQUAL, then the buffer is FULL.
|
||||||
|
*/
|
||||||
|
static u_long ring_clock = 0;
|
||||||
|
|
||||||
|
|
||||||
|
#define ring_empty(d) (((d)->consume == (d)->supply) && \
|
||||||
|
((d)->consumetime >= (d)->supplytime))
|
||||||
|
#define ring_full(d) (((d)->supply == (d)->consume) && \
|
||||||
|
((d)->supplytime > (d)->consumetime))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Buffer state transition routines */
|
||||||
|
|
||||||
|
ring_init(ring, buffer, count)
|
||||||
|
Ring *ring;
|
||||||
|
unsigned char *buffer;
|
||||||
|
int count;
|
||||||
|
{
|
||||||
|
memset((char *)ring, 0, sizeof *ring);
|
||||||
|
|
||||||
|
ring->size = count;
|
||||||
|
|
||||||
|
ring->supply = ring->consume = ring->bottom = buffer;
|
||||||
|
|
||||||
|
ring->top = ring->bottom+ring->size;
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
ring->clearto = 0;
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Mark routines */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Mark the most recently supplied byte.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
ring_mark(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
ring->mark = ring_decrement(ring, ring->supply, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Is the ring pointing to the mark?
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
ring_at_mark(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if (ring->mark == ring->consume) {
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Clear any mark set on the ring.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
ring_clear_mark(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
ring->mark = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Add characters from current segment to ring buffer.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ring_supplied(ring, count)
|
||||||
|
Ring *ring;
|
||||||
|
int count;
|
||||||
|
{
|
||||||
|
ring->supply = ring_increment(ring, ring->supply, count);
|
||||||
|
ring->supplytime = ++ring_clock;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We have just consumed "c" bytes.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ring_consumed(ring, count)
|
||||||
|
Ring *ring;
|
||||||
|
int count;
|
||||||
|
{
|
||||||
|
if (count == 0) /* don't update anything */
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (ring->mark &&
|
||||||
|
(ring_subtract(ring, ring->mark, ring->consume) < count)) {
|
||||||
|
ring->mark = 0;
|
||||||
|
}
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
if (ring->consume < ring->clearto &&
|
||||||
|
ring->clearto <= ring->consume + count)
|
||||||
|
ring->clearto = 0;
|
||||||
|
else if (ring->consume + count > ring->top &&
|
||||||
|
ring->bottom <= ring->clearto &&
|
||||||
|
ring->bottom + ((ring->consume + count) - ring->top))
|
||||||
|
ring->clearto = 0;
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
ring->consume = ring_increment(ring, ring->consume, count);
|
||||||
|
ring->consumetime = ++ring_clock;
|
||||||
|
/*
|
||||||
|
* Try to encourage "ring_empty_consecutive()" to be large.
|
||||||
|
*/
|
||||||
|
if (ring_empty(ring)) {
|
||||||
|
ring->consume = ring->supply = ring->bottom;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Buffer state query routines */
|
||||||
|
|
||||||
|
|
||||||
|
/* Number of bytes that may be supplied */
|
||||||
|
int
|
||||||
|
ring_empty_count(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if (ring_empty(ring)) { /* if empty */
|
||||||
|
return ring->size;
|
||||||
|
} else {
|
||||||
|
return ring_subtract(ring, ring->consume, ring->supply);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* number of CONSECUTIVE bytes that may be supplied */
|
||||||
|
int
|
||||||
|
ring_empty_consecutive(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if ((ring->consume < ring->supply) || ring_empty(ring)) {
|
||||||
|
/*
|
||||||
|
* if consume is "below" supply, or empty, then
|
||||||
|
* return distance to the top
|
||||||
|
*/
|
||||||
|
return ring_subtract(ring, ring->top, ring->supply);
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* else, return what we may.
|
||||||
|
*/
|
||||||
|
return ring_subtract(ring, ring->consume, ring->supply);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return the number of bytes that are available for consuming
|
||||||
|
* (but don't give more than enough to get to cross over set mark)
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
ring_full_count(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if ((ring->mark == 0) || (ring->mark == ring->consume)) {
|
||||||
|
if (ring_full(ring)) {
|
||||||
|
return ring->size; /* nothing consumed, but full */
|
||||||
|
} else {
|
||||||
|
return ring_subtract(ring, ring->supply, ring->consume);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return ring_subtract(ring, ring->mark, ring->consume);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return the number of CONSECUTIVE bytes available for consuming.
|
||||||
|
* However, don't return more than enough to cross over set mark.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
ring_full_consecutive(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if ((ring->mark == 0) || (ring->mark == ring->consume)) {
|
||||||
|
if ((ring->supply < ring->consume) || ring_full(ring)) {
|
||||||
|
return ring_subtract(ring, ring->top, ring->consume);
|
||||||
|
} else {
|
||||||
|
return ring_subtract(ring, ring->supply, ring->consume);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (ring->mark < ring->consume) {
|
||||||
|
return ring_subtract(ring, ring->top, ring->consume);
|
||||||
|
} else { /* Else, distance to mark */
|
||||||
|
return ring_subtract(ring, ring->mark, ring->consume);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Move data into the "supply" portion of of the ring buffer.
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ring_supply_data(ring, buffer, count)
|
||||||
|
Ring *ring;
|
||||||
|
unsigned char *buffer;
|
||||||
|
int count;
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
while (count) {
|
||||||
|
i = MIN(count, ring_empty_consecutive(ring));
|
||||||
|
memcpy(ring->supply, buffer, i);
|
||||||
|
ring_supplied(ring, i);
|
||||||
|
count -= i;
|
||||||
|
buffer += i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef notdef
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Move data from the "consume" portion of the ring buffer
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
ring_consume_data(ring, buffer, count)
|
||||||
|
Ring *ring;
|
||||||
|
unsigned char *buffer;
|
||||||
|
int count;
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
while (count) {
|
||||||
|
i = MIN(count, ring_full_consecutive(ring));
|
||||||
|
memcpy(buffer, ring->consume, i);
|
||||||
|
ring_consumed(ring, i);
|
||||||
|
count -= i;
|
||||||
|
buffer += i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
void
|
||||||
|
ring_encrypt(ring, encryptor)
|
||||||
|
Ring *ring;
|
||||||
|
void (*encryptor)();
|
||||||
|
{
|
||||||
|
unsigned char *s, *c;
|
||||||
|
|
||||||
|
if (ring_empty(ring) || ring->clearto == ring->supply)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!(c = ring->clearto))
|
||||||
|
c = ring->consume;
|
||||||
|
|
||||||
|
s = ring->supply;
|
||||||
|
|
||||||
|
if (s <= c) {
|
||||||
|
(*encryptor)(c, ring->top - c);
|
||||||
|
(*encryptor)(ring->bottom, s - ring->bottom);
|
||||||
|
} else
|
||||||
|
(*encryptor)(c, s - c);
|
||||||
|
|
||||||
|
ring->clearto = ring->supply;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ring_clearto(ring)
|
||||||
|
Ring *ring;
|
||||||
|
{
|
||||||
|
if (!ring_empty(ring))
|
||||||
|
ring->clearto = ring->supply;
|
||||||
|
else
|
||||||
|
ring->clearto = 0;
|
||||||
|
}
|
||||||
|
#endif /* ENCRYPTION */
|
105
secure/usr.bin/telnet/ring.h
Normal file
105
secure/usr.bin/telnet/ring.h
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)ring.h 8.1 (Berkeley) 6/6/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(P)
|
||||||
|
# undef P
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__STDC__) || defined(LINT_ARGS)
|
||||||
|
# define P(x) x
|
||||||
|
#else
|
||||||
|
# define P(x) ()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This defines a structure for a ring buffer.
|
||||||
|
*
|
||||||
|
* The circular buffer has two parts:
|
||||||
|
*(((
|
||||||
|
* full: [consume, supply)
|
||||||
|
* empty: [supply, consume)
|
||||||
|
*]]]
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
unsigned char *consume, /* where data comes out of */
|
||||||
|
*supply, /* where data comes in to */
|
||||||
|
*bottom, /* lowest address in buffer */
|
||||||
|
*top, /* highest address+1 in buffer */
|
||||||
|
*mark; /* marker (user defined) */
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
unsigned char *clearto; /* Data to this point is clear text */
|
||||||
|
unsigned char *encryyptedto; /* Data is encrypted to here */
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
int size; /* size in bytes of buffer */
|
||||||
|
u_long consumetime, /* help us keep straight full, empty, etc. */
|
||||||
|
supplytime;
|
||||||
|
} Ring;
|
||||||
|
|
||||||
|
/* Here are some functions and macros to deal with the ring buffer */
|
||||||
|
|
||||||
|
/* Initialization routine */
|
||||||
|
extern int
|
||||||
|
ring_init P((Ring *ring, unsigned char *buffer, int count));
|
||||||
|
|
||||||
|
/* Data movement routines */
|
||||||
|
extern void
|
||||||
|
ring_supply_data P((Ring *ring, unsigned char *buffer, int count));
|
||||||
|
#ifdef notdef
|
||||||
|
extern void
|
||||||
|
ring_consume_data P((Ring *ring, unsigned char *buffer, int count));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Buffer state transition routines */
|
||||||
|
extern void
|
||||||
|
ring_supplied P((Ring *ring, int count)),
|
||||||
|
ring_consumed P((Ring *ring, int count));
|
||||||
|
|
||||||
|
/* Buffer state query routines */
|
||||||
|
extern int
|
||||||
|
ring_empty_count P((Ring *ring)),
|
||||||
|
ring_empty_consecutive P((Ring *ring)),
|
||||||
|
ring_full_count P((Ring *ring)),
|
||||||
|
ring_full_consecutive P((Ring *ring));
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
extern void
|
||||||
|
ring_encrypt P((Ring *ring, void (*func)())),
|
||||||
|
ring_clearto P((Ring *ring));
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
|
||||||
|
extern void
|
||||||
|
ring_clear_mark(),
|
||||||
|
ring_mark();
|
1167
secure/usr.bin/telnet/sys_bsd.c
Normal file
1167
secure/usr.bin/telnet/sys_bsd.c
Normal file
File diff suppressed because it is too large
Load Diff
1360
secure/usr.bin/telnet/telnet.1
Normal file
1360
secure/usr.bin/telnet/telnet.1
Normal file
File diff suppressed because it is too large
Load Diff
2650
secure/usr.bin/telnet/telnet.c
Normal file
2650
secure/usr.bin/telnet/telnet.c
Normal file
File diff suppressed because it is too large
Load Diff
239
secure/usr.bin/telnet/terminal.c
Normal file
239
secure/usr.bin/telnet/terminal.c
Normal file
@ -0,0 +1,239 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1990, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)terminal.c 8.1 (Berkeley) 6/6/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#include <arpa/telnet.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include "ring.h"
|
||||||
|
|
||||||
|
#include "externs.h"
|
||||||
|
#include "types.h"
|
||||||
|
|
||||||
|
Ring ttyoring, ttyiring;
|
||||||
|
unsigned char ttyobuf[2*BUFSIZ], ttyibuf[BUFSIZ];
|
||||||
|
|
||||||
|
int termdata; /* Debugging flag */
|
||||||
|
|
||||||
|
#ifdef USE_TERMIO
|
||||||
|
# ifndef VDISCARD
|
||||||
|
cc_t termFlushChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VLNEXT
|
||||||
|
cc_t termLiteralNextChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VSUSP
|
||||||
|
cc_t termSuspChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VWERASE
|
||||||
|
cc_t termWerasChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VREPRINT
|
||||||
|
cc_t termRprntChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VSTART
|
||||||
|
cc_t termStartChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VSTOP
|
||||||
|
cc_t termStopChar;
|
||||||
|
# endif
|
||||||
|
# ifndef VEOL
|
||||||
|
cc_t termForw1Char;
|
||||||
|
# endif
|
||||||
|
# ifndef VEOL2
|
||||||
|
cc_t termForw2Char;
|
||||||
|
# endif
|
||||||
|
# ifndef VSTATUS
|
||||||
|
cc_t termAytChar;
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
cc_t termForw2Char;
|
||||||
|
cc_t termAytChar;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* initialize the terminal data structures.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
init_terminal()
|
||||||
|
{
|
||||||
|
if (ring_init(&ttyoring, ttyobuf, sizeof ttyobuf) != 1) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (ring_init(&ttyiring, ttyibuf, sizeof ttyibuf) != 1) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
autoflush = TerminalAutoFlush();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Send as much data as possible to the terminal.
|
||||||
|
*
|
||||||
|
* Return value:
|
||||||
|
* -1: No useful work done, data waiting to go out.
|
||||||
|
* 0: No data was waiting, so nothing was done.
|
||||||
|
* 1: All waiting data was written out.
|
||||||
|
* n: All data - n was written out.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
ttyflush(drop)
|
||||||
|
int drop;
|
||||||
|
{
|
||||||
|
register int n, n0, n1;
|
||||||
|
|
||||||
|
n0 = ring_full_count(&ttyoring);
|
||||||
|
if ((n1 = n = ring_full_consecutive(&ttyoring)) > 0) {
|
||||||
|
if (drop) {
|
||||||
|
TerminalFlushOutput();
|
||||||
|
/* we leave 'n' alone! */
|
||||||
|
} else {
|
||||||
|
n = TerminalWrite(ttyoring.consume, n);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (n > 0) {
|
||||||
|
if (termdata && n) {
|
||||||
|
Dump('>', ttyoring.consume, n);
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* If we wrote everything, and the full count is
|
||||||
|
* larger than what we wrote, then write the
|
||||||
|
* rest of the buffer.
|
||||||
|
*/
|
||||||
|
if (n1 == n && n0 > n) {
|
||||||
|
n1 = n0 - n;
|
||||||
|
if (!drop)
|
||||||
|
n1 = TerminalWrite(ttyoring.bottom, n1);
|
||||||
|
n += n1;
|
||||||
|
}
|
||||||
|
ring_consumed(&ttyoring, n);
|
||||||
|
}
|
||||||
|
if (n < 0)
|
||||||
|
return -1;
|
||||||
|
if (n == n0) {
|
||||||
|
if (n0)
|
||||||
|
return -1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return n0 - n + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These routines decides on what the mode should be (based on the values
|
||||||
|
* of various global variables).
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
getconnmode()
|
||||||
|
{
|
||||||
|
extern int linemode;
|
||||||
|
int mode = 0;
|
||||||
|
#ifdef KLUDGELINEMODE
|
||||||
|
extern int kludgelinemode;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (In3270)
|
||||||
|
return(MODE_FLOW);
|
||||||
|
|
||||||
|
if (my_want_state_is_dont(TELOPT_ECHO))
|
||||||
|
mode |= MODE_ECHO;
|
||||||
|
|
||||||
|
if (localflow)
|
||||||
|
mode |= MODE_FLOW;
|
||||||
|
|
||||||
|
if (my_want_state_is_will(TELOPT_BINARY))
|
||||||
|
mode |= MODE_INBIN;
|
||||||
|
|
||||||
|
if (his_want_state_is_will(TELOPT_BINARY))
|
||||||
|
mode |= MODE_OUTBIN;
|
||||||
|
|
||||||
|
#ifdef KLUDGELINEMODE
|
||||||
|
if (kludgelinemode) {
|
||||||
|
if (my_want_state_is_dont(TELOPT_SGA)) {
|
||||||
|
mode |= (MODE_TRAPSIG|MODE_EDIT);
|
||||||
|
if (dontlecho && (clocks.echotoggle > clocks.modenegotiated)) {
|
||||||
|
mode &= ~MODE_ECHO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(mode);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (my_want_state_is_will(TELOPT_LINEMODE))
|
||||||
|
mode |= linemode;
|
||||||
|
return(mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
setconnmode(force)
|
||||||
|
int force;
|
||||||
|
{
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
static int enc_passwd = 0;
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
register int newmode;
|
||||||
|
|
||||||
|
newmode = getconnmode()|(force?MODE_FORCE:0);
|
||||||
|
|
||||||
|
TerminalNewMode(newmode);
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
if ((newmode & (MODE_ECHO|MODE_EDIT)) == MODE_EDIT) {
|
||||||
|
if (my_want_state_is_will(TELOPT_ENCRYPT)
|
||||||
|
&& (enc_passwd == 0) && !encrypt_output) {
|
||||||
|
encrypt_request_start(0, 0);
|
||||||
|
enc_passwd = 1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (enc_passwd) {
|
||||||
|
encrypt_request_end();
|
||||||
|
enc_passwd = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
setcommandmode()
|
||||||
|
{
|
||||||
|
TerminalNewMode(-1);
|
||||||
|
}
|
411
secure/usr.bin/telnet/tn3270.c
Normal file
411
secure/usr.bin/telnet/tn3270.c
Normal file
@ -0,0 +1,411 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)tn3270.c 8.1 (Berkeley) 6/6/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <arpa/telnet.h>
|
||||||
|
|
||||||
|
#include "general.h"
|
||||||
|
|
||||||
|
#include "defines.h"
|
||||||
|
#include "ring.h"
|
||||||
|
#include "externs.h"
|
||||||
|
#include "fdset.h"
|
||||||
|
|
||||||
|
#if defined(TN3270)
|
||||||
|
|
||||||
|
#include "../ctlr/screen.h"
|
||||||
|
#include "../general/globals.h"
|
||||||
|
|
||||||
|
#include "../sys_curses/telextrn.h"
|
||||||
|
#include "../ctlr/externs.h"
|
||||||
|
|
||||||
|
#if defined(unix)
|
||||||
|
int
|
||||||
|
HaveInput, /* There is input available to scan */
|
||||||
|
cursesdata, /* Do we dump curses data? */
|
||||||
|
sigiocount; /* Number of times we got a SIGIO */
|
||||||
|
|
||||||
|
char tline[200];
|
||||||
|
char *transcom = 0; /* transparent mode command (default: none) */
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
|
||||||
|
char Ibuf[8*BUFSIZ], *Ifrontp, *Ibackp;
|
||||||
|
|
||||||
|
static char sb_terminal[] = { IAC, SB,
|
||||||
|
TELOPT_TTYPE, TELQUAL_IS,
|
||||||
|
'I', 'B', 'M', '-', '3', '2', '7', '8', '-', '2',
|
||||||
|
IAC, SE };
|
||||||
|
#define SBTERMMODEL 13
|
||||||
|
|
||||||
|
static int
|
||||||
|
Sent3270TerminalType; /* Have we said we are a 3270? */
|
||||||
|
|
||||||
|
#endif /* defined(TN3270) */
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
init_3270()
|
||||||
|
{
|
||||||
|
#if defined(TN3270)
|
||||||
|
#if defined(unix)
|
||||||
|
HaveInput = 0;
|
||||||
|
sigiocount = 0;
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
Sent3270TerminalType = 0;
|
||||||
|
Ifrontp = Ibackp = Ibuf;
|
||||||
|
init_ctlr(); /* Initialize some things */
|
||||||
|
init_keyboard();
|
||||||
|
init_screen();
|
||||||
|
init_system();
|
||||||
|
#endif /* defined(TN3270) */
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(TN3270)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataToNetwork - queue up some data to go to network. If "done" is set,
|
||||||
|
* then when last byte is queued, we add on an IAC EOR sequence (so,
|
||||||
|
* don't call us with "done" until you want that done...)
|
||||||
|
*
|
||||||
|
* We actually do send all the data to the network buffer, since our
|
||||||
|
* only client needs for us to do that.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
DataToNetwork(buffer, count, done)
|
||||||
|
register char *buffer; /* where the data is */
|
||||||
|
register int count; /* how much to send */
|
||||||
|
int done; /* is this the last of a logical block */
|
||||||
|
{
|
||||||
|
register int loop, c;
|
||||||
|
int origCount;
|
||||||
|
|
||||||
|
origCount = count;
|
||||||
|
|
||||||
|
while (count) {
|
||||||
|
/* If not enough room for EORs, IACs, etc., wait */
|
||||||
|
if (NETROOM() < 6) {
|
||||||
|
fd_set o;
|
||||||
|
|
||||||
|
FD_ZERO(&o);
|
||||||
|
netflush();
|
||||||
|
while (NETROOM() < 6) {
|
||||||
|
FD_SET(net, &o);
|
||||||
|
(void) select(net+1, (fd_set *) 0, &o, (fd_set *) 0,
|
||||||
|
(struct timeval *) 0);
|
||||||
|
netflush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
c = ring_empty_count(&netoring);
|
||||||
|
if (c > count) {
|
||||||
|
c = count;
|
||||||
|
}
|
||||||
|
loop = c;
|
||||||
|
while (loop) {
|
||||||
|
if (((unsigned char)*buffer) == IAC) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
buffer++;
|
||||||
|
loop--;
|
||||||
|
}
|
||||||
|
if ((c = c-loop)) {
|
||||||
|
ring_supply_data(&netoring, buffer-c, c);
|
||||||
|
count -= c;
|
||||||
|
}
|
||||||
|
if (loop) {
|
||||||
|
NET2ADD(IAC, IAC);
|
||||||
|
count--;
|
||||||
|
buffer++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (done) {
|
||||||
|
NET2ADD(IAC, EOR);
|
||||||
|
netflush(); /* try to move along as quickly as ... */
|
||||||
|
}
|
||||||
|
return(origCount - count);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(unix)
|
||||||
|
void
|
||||||
|
inputAvailable(signo)
|
||||||
|
int signo;
|
||||||
|
{
|
||||||
|
HaveInput = 1;
|
||||||
|
sigiocount++;
|
||||||
|
}
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
|
||||||
|
void
|
||||||
|
outputPurge()
|
||||||
|
{
|
||||||
|
(void) ttyflush(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following routines are places where the various tn3270
|
||||||
|
* routines make calls into telnet.c.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataToTerminal - queue up some data to go to terminal.
|
||||||
|
*
|
||||||
|
* Note: there are people who call us and depend on our processing
|
||||||
|
* *all* the data at one time (thus the select).
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
DataToTerminal(buffer, count)
|
||||||
|
register char *buffer; /* where the data is */
|
||||||
|
register int count; /* how much to send */
|
||||||
|
{
|
||||||
|
register int c;
|
||||||
|
int origCount;
|
||||||
|
|
||||||
|
origCount = count;
|
||||||
|
|
||||||
|
while (count) {
|
||||||
|
if (TTYROOM() == 0) {
|
||||||
|
#if defined(unix)
|
||||||
|
fd_set o;
|
||||||
|
|
||||||
|
FD_ZERO(&o);
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
(void) ttyflush(0);
|
||||||
|
while (TTYROOM() == 0) {
|
||||||
|
#if defined(unix)
|
||||||
|
FD_SET(tout, &o);
|
||||||
|
(void) select(tout+1, (fd_set *) 0, &o, (fd_set *) 0,
|
||||||
|
(struct timeval *) 0);
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
(void) ttyflush(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
c = TTYROOM();
|
||||||
|
if (c > count) {
|
||||||
|
c = count;
|
||||||
|
}
|
||||||
|
ring_supply_data(&ttyoring, buffer, c);
|
||||||
|
count -= c;
|
||||||
|
buffer += c;
|
||||||
|
}
|
||||||
|
return(origCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Push3270 - Try to send data along the 3270 output (to screen) direction.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
Push3270()
|
||||||
|
{
|
||||||
|
int save = ring_full_count(&netiring);
|
||||||
|
|
||||||
|
if (save) {
|
||||||
|
if (Ifrontp+save > Ibuf+sizeof Ibuf) {
|
||||||
|
if (Ibackp != Ibuf) {
|
||||||
|
memcpy(Ibuf, Ibackp, Ifrontp-Ibackp);
|
||||||
|
Ifrontp -= (Ibackp-Ibuf);
|
||||||
|
Ibackp = Ibuf;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Ifrontp+save < Ibuf+sizeof Ibuf) {
|
||||||
|
(void)telrcv();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return save != ring_full_count(&netiring);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Finish3270 - get the last dregs of 3270 data out to the terminal
|
||||||
|
* before quitting.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
Finish3270()
|
||||||
|
{
|
||||||
|
while (Push3270() || !DoTerminalOutput()) {
|
||||||
|
#if defined(unix)
|
||||||
|
HaveInput = 0;
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* StringToTerminal - output a null terminated string to the terminal */
|
||||||
|
|
||||||
|
void
|
||||||
|
StringToTerminal(s)
|
||||||
|
char *s;
|
||||||
|
{
|
||||||
|
int count;
|
||||||
|
|
||||||
|
count = strlen(s);
|
||||||
|
if (count) {
|
||||||
|
(void) DataToTerminal(s, count); /* we know it always goes... */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if ((!defined(NOT43)) || defined(PUTCHAR))
|
||||||
|
/* _putchar - output a single character to the terminal. This name is so that
|
||||||
|
* curses(3x) can call us to send out data.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
_putchar(c)
|
||||||
|
char c;
|
||||||
|
{
|
||||||
|
#if defined(sun) /* SunOS 4.0 bug */
|
||||||
|
c &= 0x7f;
|
||||||
|
#endif /* defined(sun) */
|
||||||
|
if (cursesdata) {
|
||||||
|
Dump('>', &c, 1);
|
||||||
|
}
|
||||||
|
if (!TTYROOM()) {
|
||||||
|
(void) DataToTerminal(&c, 1);
|
||||||
|
} else {
|
||||||
|
TTYADD(c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif /* ((!defined(NOT43)) || defined(PUTCHAR)) */
|
||||||
|
|
||||||
|
void
|
||||||
|
SetIn3270()
|
||||||
|
{
|
||||||
|
if (Sent3270TerminalType && my_want_state_is_will(TELOPT_BINARY)
|
||||||
|
&& my_want_state_is_do(TELOPT_BINARY) && !donebinarytoggle) {
|
||||||
|
if (!In3270) {
|
||||||
|
In3270 = 1;
|
||||||
|
Init3270(); /* Initialize 3270 functions */
|
||||||
|
/* initialize terminal key mapping */
|
||||||
|
InitTerminal(); /* Start terminal going */
|
||||||
|
setconnmode(0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (In3270) {
|
||||||
|
StopScreen(1);
|
||||||
|
In3270 = 0;
|
||||||
|
Stop3270(); /* Tell 3270 we aren't here anymore */
|
||||||
|
setconnmode(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* tn3270_ttype()
|
||||||
|
*
|
||||||
|
* Send a response to a terminal type negotiation.
|
||||||
|
*
|
||||||
|
* Return '0' if no more responses to send; '1' if a response sent.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
tn3270_ttype()
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Try to send a 3270 type terminal name. Decide which one based
|
||||||
|
* on the format of our screen, and (in the future) color
|
||||||
|
* capaiblities.
|
||||||
|
*/
|
||||||
|
InitTerminal(); /* Sets MaxNumberColumns, MaxNumberLines */
|
||||||
|
if ((MaxNumberLines >= 24) && (MaxNumberColumns >= 80)) {
|
||||||
|
Sent3270TerminalType = 1;
|
||||||
|
if ((MaxNumberLines >= 27) && (MaxNumberColumns >= 132)) {
|
||||||
|
MaxNumberLines = 27;
|
||||||
|
MaxNumberColumns = 132;
|
||||||
|
sb_terminal[SBTERMMODEL] = '5';
|
||||||
|
} else if (MaxNumberLines >= 43) {
|
||||||
|
MaxNumberLines = 43;
|
||||||
|
MaxNumberColumns = 80;
|
||||||
|
sb_terminal[SBTERMMODEL] = '4';
|
||||||
|
} else if (MaxNumberLines >= 32) {
|
||||||
|
MaxNumberLines = 32;
|
||||||
|
MaxNumberColumns = 80;
|
||||||
|
sb_terminal[SBTERMMODEL] = '3';
|
||||||
|
} else {
|
||||||
|
MaxNumberLines = 24;
|
||||||
|
MaxNumberColumns = 80;
|
||||||
|
sb_terminal[SBTERMMODEL] = '2';
|
||||||
|
}
|
||||||
|
NumberLines = 24; /* before we start out... */
|
||||||
|
NumberColumns = 80;
|
||||||
|
ScreenSize = NumberLines*NumberColumns;
|
||||||
|
if ((MaxNumberLines*MaxNumberColumns) > MAXSCREENSIZE) {
|
||||||
|
ExitString("Programming error: MAXSCREENSIZE too small.\n",
|
||||||
|
1);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
printsub('>', sb_terminal+2, sizeof sb_terminal-2);
|
||||||
|
ring_supply_data(&netoring, sb_terminal, sizeof sb_terminal);
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(unix)
|
||||||
|
int
|
||||||
|
settranscom(argc, argv)
|
||||||
|
int argc;
|
||||||
|
char *argv[];
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (argc == 1 && transcom) {
|
||||||
|
transcom = 0;
|
||||||
|
}
|
||||||
|
if (argc == 1) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
transcom = tline;
|
||||||
|
(void) strcpy(transcom, argv[1]);
|
||||||
|
for (i = 2; i < argc; ++i) {
|
||||||
|
(void) strcat(transcom, " ");
|
||||||
|
(void) strcat(transcom, argv[i]);
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
|
||||||
|
#endif /* defined(TN3270) */
|
52
secure/usr.bin/telnet/types.h
Normal file
52
secure/usr.bin/telnet/types.h
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)types.h 8.1 (Berkeley) 6/6/93
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char *modedescriptions;
|
||||||
|
char modetype;
|
||||||
|
} Modelist;
|
||||||
|
|
||||||
|
extern Modelist modelist[];
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int
|
||||||
|
system, /* what the current time is */
|
||||||
|
echotoggle, /* last time user entered echo character */
|
||||||
|
modenegotiated, /* last time operating mode negotiated */
|
||||||
|
didnetreceive, /* last time we read data from network */
|
||||||
|
gotDM; /* when did we last see a data mark */
|
||||||
|
} Clocks;
|
||||||
|
|
||||||
|
extern Clocks clocks;
|
939
secure/usr.bin/telnet/utilities.c
Normal file
939
secure/usr.bin/telnet/utilities.c
Normal file
@ -0,0 +1,939 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1988, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. All advertising materials mentioning features or use of this software
|
||||||
|
* must display the following acknowledgement:
|
||||||
|
* This product includes software developed by the University of
|
||||||
|
* California, Berkeley and its contributors.
|
||||||
|
* 4. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef lint
|
||||||
|
static char sccsid[] = "@(#)utilities.c 8.2 (Berkeley) 12/15/93";
|
||||||
|
#endif /* not lint */
|
||||||
|
|
||||||
|
#define TELOPTS
|
||||||
|
#define TELCMDS
|
||||||
|
#define SLC_NAMES
|
||||||
|
#include <arpa/telnet.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
|
#include "general.h"
|
||||||
|
|
||||||
|
#include "fdset.h"
|
||||||
|
|
||||||
|
#include "ring.h"
|
||||||
|
|
||||||
|
#include "defines.h"
|
||||||
|
|
||||||
|
#include "externs.h"
|
||||||
|
|
||||||
|
FILE *NetTrace = 0; /* Not in bss, since needs to stay */
|
||||||
|
int prettydump;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* upcase()
|
||||||
|
*
|
||||||
|
* Upcase (in place) the argument.
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
upcase(argument)
|
||||||
|
register char *argument;
|
||||||
|
{
|
||||||
|
register int c;
|
||||||
|
|
||||||
|
while ((c = *argument) != 0) {
|
||||||
|
if (islower(c)) {
|
||||||
|
*argument = toupper(c);
|
||||||
|
}
|
||||||
|
argument++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SetSockOpt()
|
||||||
|
*
|
||||||
|
* Compensate for differences in 4.2 and 4.3 systems.
|
||||||
|
*/
|
||||||
|
|
||||||
|
int
|
||||||
|
SetSockOpt(fd, level, option, yesno)
|
||||||
|
int fd, level, option, yesno;
|
||||||
|
{
|
||||||
|
#ifndef NOT43
|
||||||
|
return setsockopt(fd, level, option,
|
||||||
|
(char *)&yesno, sizeof yesno);
|
||||||
|
#else /* NOT43 */
|
||||||
|
if (yesno == 0) { /* Can't do that in 4.2! */
|
||||||
|
fprintf(stderr, "Error: attempt to turn off an option 0x%x.\n",
|
||||||
|
option);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return setsockopt(fd, level, option, 0, 0);
|
||||||
|
#endif /* NOT43 */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following are routines used to print out debugging information.
|
||||||
|
*/
|
||||||
|
|
||||||
|
unsigned char NetTraceFile[256] = "(standard output)";
|
||||||
|
|
||||||
|
void
|
||||||
|
SetNetTrace(file)
|
||||||
|
register char *file;
|
||||||
|
{
|
||||||
|
if (NetTrace && NetTrace != stdout)
|
||||||
|
fclose(NetTrace);
|
||||||
|
if (file && (strcmp(file, "-") != 0)) {
|
||||||
|
NetTrace = fopen(file, "w");
|
||||||
|
if (NetTrace) {
|
||||||
|
strcpy((char *)NetTraceFile, file);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fprintf(stderr, "Cannot open %s.\n", file);
|
||||||
|
}
|
||||||
|
NetTrace = stdout;
|
||||||
|
strcpy((char *)NetTraceFile, "(standard output)");
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
Dump(direction, buffer, length)
|
||||||
|
char direction;
|
||||||
|
unsigned char *buffer;
|
||||||
|
int length;
|
||||||
|
{
|
||||||
|
# define BYTES_PER_LINE 32
|
||||||
|
# define min(x,y) ((x<y)? x:y)
|
||||||
|
unsigned char *pThis;
|
||||||
|
int offset;
|
||||||
|
extern pettydump;
|
||||||
|
|
||||||
|
offset = 0;
|
||||||
|
|
||||||
|
while (length) {
|
||||||
|
/* print one line */
|
||||||
|
fprintf(NetTrace, "%c 0x%x\t", direction, offset);
|
||||||
|
pThis = buffer;
|
||||||
|
if (prettydump) {
|
||||||
|
buffer = buffer + min(length, BYTES_PER_LINE/2);
|
||||||
|
while (pThis < buffer) {
|
||||||
|
fprintf(NetTrace, "%c%.2x",
|
||||||
|
(((*pThis)&0xff) == 0xff) ? '*' : ' ',
|
||||||
|
(*pThis)&0xff);
|
||||||
|
pThis++;
|
||||||
|
}
|
||||||
|
length -= BYTES_PER_LINE/2;
|
||||||
|
offset += BYTES_PER_LINE/2;
|
||||||
|
} else {
|
||||||
|
buffer = buffer + min(length, BYTES_PER_LINE);
|
||||||
|
while (pThis < buffer) {
|
||||||
|
fprintf(NetTrace, "%.2x", (*pThis)&0xff);
|
||||||
|
pThis++;
|
||||||
|
}
|
||||||
|
length -= BYTES_PER_LINE;
|
||||||
|
offset += BYTES_PER_LINE;
|
||||||
|
}
|
||||||
|
if (NetTrace == stdout) {
|
||||||
|
fprintf(NetTrace, "\r\n");
|
||||||
|
} else {
|
||||||
|
fprintf(NetTrace, "\n");
|
||||||
|
}
|
||||||
|
if (length < 0) {
|
||||||
|
fflush(NetTrace);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/* find next unique line */
|
||||||
|
}
|
||||||
|
fflush(NetTrace);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
printoption(direction, cmd, option)
|
||||||
|
char *direction;
|
||||||
|
int cmd, option;
|
||||||
|
{
|
||||||
|
if (!showoptions)
|
||||||
|
return;
|
||||||
|
if (cmd == IAC) {
|
||||||
|
if (TELCMD_OK(option))
|
||||||
|
fprintf(NetTrace, "%s IAC %s", direction, TELCMD(option));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%s IAC %d", direction, option);
|
||||||
|
} else {
|
||||||
|
register char *fmt;
|
||||||
|
fmt = (cmd == WILL) ? "WILL" : (cmd == WONT) ? "WONT" :
|
||||||
|
(cmd == DO) ? "DO" : (cmd == DONT) ? "DONT" : 0;
|
||||||
|
if (fmt) {
|
||||||
|
fprintf(NetTrace, "%s %s ", direction, fmt);
|
||||||
|
if (TELOPT_OK(option))
|
||||||
|
fprintf(NetTrace, "%s", TELOPT(option));
|
||||||
|
else if (option == TELOPT_EXOPL)
|
||||||
|
fprintf(NetTrace, "EXOPL");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d", option);
|
||||||
|
} else
|
||||||
|
fprintf(NetTrace, "%s %d %d", direction, cmd, option);
|
||||||
|
}
|
||||||
|
if (NetTrace == stdout) {
|
||||||
|
fprintf(NetTrace, "\r\n");
|
||||||
|
fflush(NetTrace);
|
||||||
|
} else {
|
||||||
|
fprintf(NetTrace, "\n");
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
optionstatus()
|
||||||
|
{
|
||||||
|
register int i;
|
||||||
|
extern char will_wont_resp[], do_dont_resp[];
|
||||||
|
|
||||||
|
for (i = 0; i < 256; i++) {
|
||||||
|
if (do_dont_resp[i]) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("resp DO_DONT %s: %d\n", TELOPT(i), do_dont_resp[i]);
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("resp DO_DONT %s: %d\n", TELCMD(i), do_dont_resp[i]);
|
||||||
|
else
|
||||||
|
printf("resp DO_DONT %d: %d\n", i,
|
||||||
|
do_dont_resp[i]);
|
||||||
|
if (my_want_state_is_do(i)) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("want DO %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("want DO %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf("want DO %d\n", i);
|
||||||
|
} else {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("want DONT %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("want DONT %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf("want DONT %d\n", i);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (my_state_is_do(i)) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf(" DO %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf(" DO %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf(" DO %d\n", i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (will_wont_resp[i]) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("resp WILL_WONT %s: %d\n", TELOPT(i), will_wont_resp[i]);
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("resp WILL_WONT %s: %d\n", TELCMD(i), will_wont_resp[i]);
|
||||||
|
else
|
||||||
|
printf("resp WILL_WONT %d: %d\n",
|
||||||
|
i, will_wont_resp[i]);
|
||||||
|
if (my_want_state_is_will(i)) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("want WILL %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("want WILL %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf("want WILL %d\n", i);
|
||||||
|
} else {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf("want WONT %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf("want WONT %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf("want WONT %d\n", i);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (my_state_is_will(i)) {
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
printf(" WILL %s\n", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
printf(" WILL %s\n", TELCMD(i));
|
||||||
|
else
|
||||||
|
printf(" WILL %d\n", i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
printsub(direction, pointer, length)
|
||||||
|
char direction; /* '<' or '>' */
|
||||||
|
unsigned char *pointer; /* where suboption data sits */
|
||||||
|
int length; /* length of suboption data */
|
||||||
|
{
|
||||||
|
register int i;
|
||||||
|
char buf[512];
|
||||||
|
extern int want_status_response;
|
||||||
|
|
||||||
|
if (showoptions || direction == 0 ||
|
||||||
|
(want_status_response && (pointer[0] == TELOPT_STATUS))) {
|
||||||
|
if (direction) {
|
||||||
|
fprintf(NetTrace, "%s IAC SB ",
|
||||||
|
(direction == '<')? "RCVD":"SENT");
|
||||||
|
if (length >= 3) {
|
||||||
|
register int j;
|
||||||
|
|
||||||
|
i = pointer[length-2];
|
||||||
|
j = pointer[length-1];
|
||||||
|
|
||||||
|
if (i != IAC || j != SE) {
|
||||||
|
fprintf(NetTrace, "(terminated by ");
|
||||||
|
if (TELOPT_OK(i))
|
||||||
|
fprintf(NetTrace, "%s ", TELOPT(i));
|
||||||
|
else if (TELCMD_OK(i))
|
||||||
|
fprintf(NetTrace, "%s ", TELCMD(i));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d ", i);
|
||||||
|
if (TELOPT_OK(j))
|
||||||
|
fprintf(NetTrace, "%s", TELOPT(j));
|
||||||
|
else if (TELCMD_OK(j))
|
||||||
|
fprintf(NetTrace, "%s", TELCMD(j));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d", j);
|
||||||
|
fprintf(NetTrace, ", not IAC SE!) ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
length -= 2;
|
||||||
|
}
|
||||||
|
if (length < 1) {
|
||||||
|
fprintf(NetTrace, "(Empty suboption??\?)");
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fflush(NetTrace);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (pointer[0]) {
|
||||||
|
case TELOPT_TTYPE:
|
||||||
|
fprintf(NetTrace, "TERMINAL-TYPE ");
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case TELQUAL_IS:
|
||||||
|
fprintf(NetTrace, "IS \"%.*s\"", length-2, (char *)pointer+2);
|
||||||
|
break;
|
||||||
|
case TELQUAL_SEND:
|
||||||
|
fprintf(NetTrace, "SEND");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace,
|
||||||
|
"- unknown qualifier %d (0x%x).",
|
||||||
|
pointer[1], pointer[1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TELOPT_TSPEED:
|
||||||
|
fprintf(NetTrace, "TERMINAL-SPEED");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case TELQUAL_IS:
|
||||||
|
fprintf(NetTrace, " IS ");
|
||||||
|
fprintf(NetTrace, "%.*s", length-2, (char *)pointer+2);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if (pointer[1] == 1)
|
||||||
|
fprintf(NetTrace, " SEND");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " %d (unknown)", pointer[1]);
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELOPT_LFLOW:
|
||||||
|
fprintf(NetTrace, "TOGGLE-FLOW-CONTROL");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case LFLOW_OFF:
|
||||||
|
fprintf(NetTrace, " OFF"); break;
|
||||||
|
case LFLOW_ON:
|
||||||
|
fprintf(NetTrace, " ON"); break;
|
||||||
|
case LFLOW_RESTART_ANY:
|
||||||
|
fprintf(NetTrace, " RESTART-ANY"); break;
|
||||||
|
case LFLOW_RESTART_XON:
|
||||||
|
fprintf(NetTrace, " RESTART-XON"); break;
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, " %d (unknown)", pointer[1]);
|
||||||
|
}
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELOPT_NAWS:
|
||||||
|
fprintf(NetTrace, "NAWS");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (length == 2) {
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[1]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fprintf(NetTrace, " %d %d (%d)",
|
||||||
|
pointer[1], pointer[2],
|
||||||
|
(int)((((unsigned int)pointer[1])<<8)|((unsigned int)pointer[2])));
|
||||||
|
if (length == 4) {
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[3]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fprintf(NetTrace, " %d %d (%d)",
|
||||||
|
pointer[3], pointer[4],
|
||||||
|
(int)((((unsigned int)pointer[3])<<8)|((unsigned int)pointer[4])));
|
||||||
|
for (i = 5; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
|
||||||
|
#if defined(AUTHENTICATION)
|
||||||
|
case TELOPT_AUTHENTICATION:
|
||||||
|
fprintf(NetTrace, "AUTHENTICATION");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case TELQUAL_REPLY:
|
||||||
|
case TELQUAL_IS:
|
||||||
|
fprintf(NetTrace, " %s ", (pointer[1] == TELQUAL_IS) ?
|
||||||
|
"IS" : "REPLY");
|
||||||
|
if (AUTHTYPE_NAME_OK(pointer[2]))
|
||||||
|
fprintf(NetTrace, "%s ", AUTHTYPE_NAME(pointer[2]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d ", pointer[2]);
|
||||||
|
if (length < 3) {
|
||||||
|
fprintf(NetTrace, "(partial suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fprintf(NetTrace, "%s|%s",
|
||||||
|
((pointer[3] & AUTH_WHO_MASK) == AUTH_WHO_CLIENT) ?
|
||||||
|
"CLIENT" : "SERVER",
|
||||||
|
((pointer[3] & AUTH_HOW_MASK) == AUTH_HOW_MUTUAL) ?
|
||||||
|
"MUTUAL" : "ONE-WAY");
|
||||||
|
|
||||||
|
auth_printsub(&pointer[1], length - 1, buf, sizeof(buf));
|
||||||
|
fprintf(NetTrace, "%s", buf);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELQUAL_SEND:
|
||||||
|
i = 2;
|
||||||
|
fprintf(NetTrace, " SEND ");
|
||||||
|
while (i < length) {
|
||||||
|
if (AUTHTYPE_NAME_OK(pointer[i]))
|
||||||
|
fprintf(NetTrace, "%s ", AUTHTYPE_NAME(pointer[i]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d ", pointer[i]);
|
||||||
|
if (++i >= length) {
|
||||||
|
fprintf(NetTrace, "(partial suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fprintf(NetTrace, "%s|%s ",
|
||||||
|
((pointer[i] & AUTH_WHO_MASK) == AUTH_WHO_CLIENT) ?
|
||||||
|
"CLIENT" : "SERVER",
|
||||||
|
((pointer[i] & AUTH_HOW_MASK) == AUTH_HOW_MUTUAL) ?
|
||||||
|
"MUTUAL" : "ONE-WAY");
|
||||||
|
++i;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELQUAL_NAME:
|
||||||
|
i = 2;
|
||||||
|
fprintf(NetTrace, " NAME \"");
|
||||||
|
while (i < length)
|
||||||
|
putc(pointer[i++], NetTrace);
|
||||||
|
putc('"', NetTrace);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef ENCRYPTION
|
||||||
|
case TELOPT_ENCRYPT:
|
||||||
|
fprintf(NetTrace, "ENCRYPT");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case ENCRYPT_START:
|
||||||
|
fprintf(NetTrace, " START");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_END:
|
||||||
|
fprintf(NetTrace, " END");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_REQSTART:
|
||||||
|
fprintf(NetTrace, " REQUEST-START");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_REQEND:
|
||||||
|
fprintf(NetTrace, " REQUEST-END");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_IS:
|
||||||
|
case ENCRYPT_REPLY:
|
||||||
|
fprintf(NetTrace, " %s ", (pointer[1] == ENCRYPT_IS) ?
|
||||||
|
"IS" : "REPLY");
|
||||||
|
if (length < 3) {
|
||||||
|
fprintf(NetTrace, " (partial suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (ENCTYPE_NAME_OK(pointer[2]))
|
||||||
|
fprintf(NetTrace, "%s ", ENCTYPE_NAME(pointer[2]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " %d (unknown)", pointer[2]);
|
||||||
|
|
||||||
|
encrypt_printsub(&pointer[1], length - 1, buf, sizeof(buf));
|
||||||
|
fprintf(NetTrace, "%s", buf);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_SUPPORT:
|
||||||
|
i = 2;
|
||||||
|
fprintf(NetTrace, " SUPPORT ");
|
||||||
|
while (i < length) {
|
||||||
|
if (ENCTYPE_NAME_OK(pointer[i]))
|
||||||
|
fprintf(NetTrace, "%s ", ENCTYPE_NAME(pointer[i]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d ", pointer[i]);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENCRYPT_ENC_KEYID:
|
||||||
|
fprintf(NetTrace, " ENC_KEYID ");
|
||||||
|
goto encommon;
|
||||||
|
|
||||||
|
case ENCRYPT_DEC_KEYID:
|
||||||
|
fprintf(NetTrace, " DEC_KEYID ");
|
||||||
|
goto encommon;
|
||||||
|
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, " %d (unknown)", pointer[1]);
|
||||||
|
encommon:
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " %d", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
#endif /* ENCRYPTION */
|
||||||
|
|
||||||
|
case TELOPT_LINEMODE:
|
||||||
|
fprintf(NetTrace, "LINEMODE ");
|
||||||
|
if (length < 2) {
|
||||||
|
fprintf(NetTrace, " (empty suboption??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case WILL:
|
||||||
|
fprintf(NetTrace, "WILL ");
|
||||||
|
goto common;
|
||||||
|
case WONT:
|
||||||
|
fprintf(NetTrace, "WONT ");
|
||||||
|
goto common;
|
||||||
|
case DO:
|
||||||
|
fprintf(NetTrace, "DO ");
|
||||||
|
goto common;
|
||||||
|
case DONT:
|
||||||
|
fprintf(NetTrace, "DONT ");
|
||||||
|
common:
|
||||||
|
if (length < 3) {
|
||||||
|
fprintf(NetTrace, "(no option??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
switch (pointer[2]) {
|
||||||
|
case LM_FORWARDMASK:
|
||||||
|
fprintf(NetTrace, "Forward Mask");
|
||||||
|
for (i = 3; i < length; i++)
|
||||||
|
fprintf(NetTrace, " %x", pointer[i]);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, "%d (unknown)", pointer[2]);
|
||||||
|
for (i = 3; i < length; i++)
|
||||||
|
fprintf(NetTrace, " %d", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case LM_SLC:
|
||||||
|
fprintf(NetTrace, "SLC");
|
||||||
|
for (i = 2; i < length - 2; i += 3) {
|
||||||
|
if (SLC_NAME_OK(pointer[i+SLC_FUNC]))
|
||||||
|
fprintf(NetTrace, " %s", SLC_NAME(pointer[i+SLC_FUNC]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " %d", pointer[i+SLC_FUNC]);
|
||||||
|
switch (pointer[i+SLC_FLAGS]&SLC_LEVELBITS) {
|
||||||
|
case SLC_NOSUPPORT:
|
||||||
|
fprintf(NetTrace, " NOSUPPORT"); break;
|
||||||
|
case SLC_CANTCHANGE:
|
||||||
|
fprintf(NetTrace, " CANTCHANGE"); break;
|
||||||
|
case SLC_VARIABLE:
|
||||||
|
fprintf(NetTrace, " VARIABLE"); break;
|
||||||
|
case SLC_DEFAULT:
|
||||||
|
fprintf(NetTrace, " DEFAULT"); break;
|
||||||
|
}
|
||||||
|
fprintf(NetTrace, "%s%s%s",
|
||||||
|
pointer[i+SLC_FLAGS]&SLC_ACK ? "|ACK" : "",
|
||||||
|
pointer[i+SLC_FLAGS]&SLC_FLUSHIN ? "|FLUSHIN" : "",
|
||||||
|
pointer[i+SLC_FLAGS]&SLC_FLUSHOUT ? "|FLUSHOUT" : "");
|
||||||
|
if (pointer[i+SLC_FLAGS]& ~(SLC_ACK|SLC_FLUSHIN|
|
||||||
|
SLC_FLUSHOUT| SLC_LEVELBITS))
|
||||||
|
fprintf(NetTrace, "(0x%x)", pointer[i+SLC_FLAGS]);
|
||||||
|
fprintf(NetTrace, " %d;", pointer[i+SLC_VALUE]);
|
||||||
|
if ((pointer[i+SLC_VALUE] == IAC) &&
|
||||||
|
(pointer[i+SLC_VALUE+1] == IAC))
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
for (; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case LM_MODE:
|
||||||
|
fprintf(NetTrace, "MODE ");
|
||||||
|
if (length < 3) {
|
||||||
|
fprintf(NetTrace, "(no mode??\?)");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
char tbuf[64];
|
||||||
|
sprintf(tbuf, "%s%s%s%s%s",
|
||||||
|
pointer[2]&MODE_EDIT ? "|EDIT" : "",
|
||||||
|
pointer[2]&MODE_TRAPSIG ? "|TRAPSIG" : "",
|
||||||
|
pointer[2]&MODE_SOFT_TAB ? "|SOFT_TAB" : "",
|
||||||
|
pointer[2]&MODE_LIT_ECHO ? "|LIT_ECHO" : "",
|
||||||
|
pointer[2]&MODE_ACK ? "|ACK" : "");
|
||||||
|
fprintf(NetTrace, "%s", tbuf[1] ? &tbuf[1] : "0");
|
||||||
|
}
|
||||||
|
if (pointer[2]&~(MODE_MASK))
|
||||||
|
fprintf(NetTrace, " (0x%x)", pointer[2]);
|
||||||
|
for (i = 3; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?0x%x?", pointer[i]);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, "%d (unknown)", pointer[1]);
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " %d", pointer[i]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELOPT_STATUS: {
|
||||||
|
register char *cp;
|
||||||
|
register int j, k;
|
||||||
|
|
||||||
|
fprintf(NetTrace, "STATUS");
|
||||||
|
|
||||||
|
switch (pointer[1]) {
|
||||||
|
default:
|
||||||
|
if (pointer[1] == TELQUAL_SEND)
|
||||||
|
fprintf(NetTrace, " SEND");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " %d (unknown)", pointer[1]);
|
||||||
|
for (i = 2; i < length; i++)
|
||||||
|
fprintf(NetTrace, " ?%d?", pointer[i]);
|
||||||
|
break;
|
||||||
|
case TELQUAL_IS:
|
||||||
|
if (--want_status_response < 0)
|
||||||
|
want_status_response = 0;
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fprintf(NetTrace, " IS\r\n");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " IS\n");
|
||||||
|
|
||||||
|
for (i = 2; i < length; i++) {
|
||||||
|
switch(pointer[i]) {
|
||||||
|
case DO: cp = "DO"; goto common2;
|
||||||
|
case DONT: cp = "DONT"; goto common2;
|
||||||
|
case WILL: cp = "WILL"; goto common2;
|
||||||
|
case WONT: cp = "WONT"; goto common2;
|
||||||
|
common2:
|
||||||
|
i++;
|
||||||
|
if (TELOPT_OK((int)pointer[i]))
|
||||||
|
fprintf(NetTrace, " %s %s", cp, TELOPT(pointer[i]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, " %s %d", cp, pointer[i]);
|
||||||
|
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fprintf(NetTrace, "\r\n");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "\n");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SB:
|
||||||
|
fprintf(NetTrace, " SB ");
|
||||||
|
i++;
|
||||||
|
j = k = i;
|
||||||
|
while (j < length) {
|
||||||
|
if (pointer[j] == SE) {
|
||||||
|
if (j+1 == length)
|
||||||
|
break;
|
||||||
|
if (pointer[j+1] == SE)
|
||||||
|
j++;
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pointer[k++] = pointer[j++];
|
||||||
|
}
|
||||||
|
printsub(0, &pointer[i], k - i);
|
||||||
|
if (i < length) {
|
||||||
|
fprintf(NetTrace, " SE");
|
||||||
|
i = j;
|
||||||
|
} else
|
||||||
|
i = j - 1;
|
||||||
|
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fprintf(NetTrace, "\r\n");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "\n");
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, " %d", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case TELOPT_XDISPLOC:
|
||||||
|
fprintf(NetTrace, "X-DISPLAY-LOCATION ");
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case TELQUAL_IS:
|
||||||
|
fprintf(NetTrace, "IS \"%.*s\"", length-2, (char *)pointer+2);
|
||||||
|
break;
|
||||||
|
case TELQUAL_SEND:
|
||||||
|
fprintf(NetTrace, "SEND");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
fprintf(NetTrace, "- unknown qualifier %d (0x%x).",
|
||||||
|
pointer[1], pointer[1]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case TELOPT_NEW_ENVIRON:
|
||||||
|
fprintf(NetTrace, "NEW-ENVIRON ");
|
||||||
|
#ifdef OLD_ENVIRON
|
||||||
|
goto env_common1;
|
||||||
|
case TELOPT_OLD_ENVIRON:
|
||||||
|
fprintf(NetTrace, "OLD-ENVIRON");
|
||||||
|
env_common1:
|
||||||
|
#endif
|
||||||
|
switch (pointer[1]) {
|
||||||
|
case TELQUAL_IS:
|
||||||
|
fprintf(NetTrace, "IS ");
|
||||||
|
goto env_common;
|
||||||
|
case TELQUAL_SEND:
|
||||||
|
fprintf(NetTrace, "SEND ");
|
||||||
|
goto env_common;
|
||||||
|
case TELQUAL_INFO:
|
||||||
|
fprintf(NetTrace, "INFO ");
|
||||||
|
env_common:
|
||||||
|
{
|
||||||
|
register int noquote = 2;
|
||||||
|
#if defined(ENV_HACK) && defined(OLD_ENVIRON)
|
||||||
|
extern int old_env_var, old_env_value;
|
||||||
|
#endif
|
||||||
|
for (i = 2; i < length; i++ ) {
|
||||||
|
switch (pointer[i]) {
|
||||||
|
case NEW_ENV_VALUE:
|
||||||
|
#ifdef OLD_ENVIRON
|
||||||
|
/* case NEW_ENV_OVAR: */
|
||||||
|
if (pointer[0] == TELOPT_OLD_ENVIRON) {
|
||||||
|
# ifdef ENV_HACK
|
||||||
|
if (old_env_var == OLD_ENV_VALUE)
|
||||||
|
fprintf(NetTrace, "\" (VALUE) " + noquote);
|
||||||
|
else
|
||||||
|
# endif
|
||||||
|
fprintf(NetTrace, "\" VAR " + noquote);
|
||||||
|
} else
|
||||||
|
#endif /* OLD_ENVIRON */
|
||||||
|
fprintf(NetTrace, "\" VALUE " + noquote);
|
||||||
|
noquote = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NEW_ENV_VAR:
|
||||||
|
#ifdef OLD_ENVIRON
|
||||||
|
/* case OLD_ENV_VALUE: */
|
||||||
|
if (pointer[0] == TELOPT_OLD_ENVIRON) {
|
||||||
|
# ifdef ENV_HACK
|
||||||
|
if (old_env_value == OLD_ENV_VAR)
|
||||||
|
fprintf(NetTrace, "\" (VAR) " + noquote);
|
||||||
|
else
|
||||||
|
# endif
|
||||||
|
fprintf(NetTrace, "\" VALUE " + noquote);
|
||||||
|
} else
|
||||||
|
#endif /* OLD_ENVIRON */
|
||||||
|
fprintf(NetTrace, "\" VAR " + noquote);
|
||||||
|
noquote = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENV_ESC:
|
||||||
|
fprintf(NetTrace, "\" ESC " + noquote);
|
||||||
|
noquote = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ENV_USERVAR:
|
||||||
|
fprintf(NetTrace, "\" USERVAR " + noquote);
|
||||||
|
noquote = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
def_case:
|
||||||
|
if (isprint(pointer[i]) && pointer[i] != '"') {
|
||||||
|
if (noquote) {
|
||||||
|
putc('"', NetTrace);
|
||||||
|
noquote = 0;
|
||||||
|
}
|
||||||
|
putc(pointer[i], NetTrace);
|
||||||
|
} else {
|
||||||
|
fprintf(NetTrace, "\" %03o " + noquote,
|
||||||
|
pointer[i]);
|
||||||
|
noquote = 2;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!noquote)
|
||||||
|
putc('"', NetTrace);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (TELOPT_OK(pointer[0]))
|
||||||
|
fprintf(NetTrace, "%s (unknown)", TELOPT(pointer[0]));
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "%d (unknown)", pointer[0]);
|
||||||
|
for (i = 1; i < length; i++)
|
||||||
|
fprintf(NetTrace, " %d", pointer[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (direction) {
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fprintf(NetTrace, "\r\n");
|
||||||
|
else
|
||||||
|
fprintf(NetTrace, "\n");
|
||||||
|
}
|
||||||
|
if (NetTrace == stdout)
|
||||||
|
fflush(NetTrace);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* EmptyTerminal - called to make sure that the terminal buffer is empty.
|
||||||
|
* Note that we consider the buffer to run all the
|
||||||
|
* way to the kernel (thus the select).
|
||||||
|
*/
|
||||||
|
|
||||||
|
void
|
||||||
|
EmptyTerminal()
|
||||||
|
{
|
||||||
|
#if defined(unix)
|
||||||
|
fd_set o;
|
||||||
|
|
||||||
|
FD_ZERO(&o);
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
|
||||||
|
if (TTYBYTES() == 0) {
|
||||||
|
#if defined(unix)
|
||||||
|
FD_SET(tout, &o);
|
||||||
|
(void) select(tout+1, (fd_set *) 0, &o, (fd_set *) 0,
|
||||||
|
(struct timeval *) 0); /* wait for TTLOWAT */
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
} else {
|
||||||
|
while (TTYBYTES()) {
|
||||||
|
(void) ttyflush(0);
|
||||||
|
#if defined(unix)
|
||||||
|
FD_SET(tout, &o);
|
||||||
|
(void) select(tout+1, (fd_set *) 0, &o, (fd_set *) 0,
|
||||||
|
(struct timeval *) 0); /* wait for TTLOWAT */
|
||||||
|
#endif /* defined(unix) */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
SetForExit()
|
||||||
|
{
|
||||||
|
setconnmode(0);
|
||||||
|
#if defined(TN3270)
|
||||||
|
if (In3270) {
|
||||||
|
Finish3270();
|
||||||
|
}
|
||||||
|
#else /* defined(TN3270) */
|
||||||
|
do {
|
||||||
|
(void)telrcv(); /* Process any incoming data */
|
||||||
|
EmptyTerminal();
|
||||||
|
} while (ring_full_count(&netiring)); /* While there is any */
|
||||||
|
#endif /* defined(TN3270) */
|
||||||
|
setcommandmode();
|
||||||
|
fflush(stdout);
|
||||||
|
fflush(stderr);
|
||||||
|
#if defined(TN3270)
|
||||||
|
if (In3270) {
|
||||||
|
StopScreen(1);
|
||||||
|
}
|
||||||
|
#endif /* defined(TN3270) */
|
||||||
|
setconnmode(0);
|
||||||
|
EmptyTerminal(); /* Flush the path to the tty */
|
||||||
|
setcommandmode();
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
Exit(returnCode)
|
||||||
|
int returnCode;
|
||||||
|
{
|
||||||
|
SetForExit();
|
||||||
|
exit(returnCode);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ExitString(string, returnCode)
|
||||||
|
char *string;
|
||||||
|
int returnCode;
|
||||||
|
{
|
||||||
|
SetForExit();
|
||||||
|
fwrite(string, 1, strlen(string), stderr);
|
||||||
|
exit(returnCode);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user