Patrick Welche <prlw1@cam.ac.uk>
[netbsd-mini2440.git] / crypto / dist / heimdal / appl / telnet / telnetd / telnetd.8
bloba7dd67024c46b129ccbddea157aa32332c97ad87
1 .\" Copyright (c) 1983, 1993
2 .\"     The Regents of the University of California.  All rights reserved.
3 .\"
4 .\" Redistribution and use in source and binary forms, with or without
5 .\" modification, are permitted provided that the following conditions
6 .\" are met:
7 .\" 1. Redistributions of source code must retain the above copyright
8 .\"    notice, this list of conditions and the following disclaimer.
9 .\" 2. Redistributions in binary form must reproduce the above copyright
10 .\"    notice, this list of conditions and the following disclaimer in the
11 .\"    documentation and/or other materials provided with the distribution.
12 .\" 3. All advertising materials mentioning features or use of this software
13 .\"    must display the following acknowledgement:
14 .\"     This product includes software developed by the University of
15 .\"     California, Berkeley and its contributors.
16 .\" 4. Neither the name of the University nor the names of its contributors
17 .\"    may be used to endorse or promote products derived from this software
18 .\"    without specific prior written permission.
19 .\"
20 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23 .\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 .\" SUCH DAMAGE.
31 .\"
32 .\"     @(#)telnetd.8   8.4 (Berkeley) 6/1/94
33 .\"
34 .Dd September 19, 2006
35 .Dt TELNETD 8
36 .Os BSD 4.2
37 .Sh NAME
38 .Nm telnetd
39 .Nd DARPA
40 .Tn TELNET
41 protocol server
42 .Sh SYNOPSIS
43 .Nm telnetd
44 .Op Fl BeUhkln
45 .Op Fl D Ar debugmode
46 .Op Fl S Ar tos
47 .Op Fl X Ar authtype
48 .Op Fl a Ar authmode
49 .Op Fl r Ns Ar lowpty-highpty
50 .Op Fl u Ar len
51 .Op Fl debug
52 .Op Fl L Ar /bin/login
53 .Op Fl y
54 .Op Ar port
55 .Sh DESCRIPTION
56 The
57 .Nm telnetd
58 command is a server which supports the
59 .Tn DARPA
60 standard
61 .Tn TELNET
62 virtual terminal protocol.
63 .Nm Telnetd
64 is normally invoked by the internet server (see
65 .Xr inetd 8 )
66 for requests to connect to the
67 .Tn TELNET
68 port as indicated by the
69 .Pa /etc/services
70 file (see
71 .Xr services 5 ) .
72 The
73 .Fl debug
74 option may be used to start up
75 .Nm telnetd
76 manually, instead of through
77 .Xr inetd 8 .
78 If started up this way,
79 .Ar port
80 may be specified to run
81 .Nm telnetd
82 on an alternate
83 .Tn TCP
84 port number.
85 .Pp
86 The
87 .Nm telnetd
88 command accepts the following options:
89 .Bl -tag -width "-a authmode"
90 .It Fl a Ar authmode
91 This option may be used for specifying what mode should
92 be used for authentication.
93 Note that this option is only useful if
94 .Nm telnetd
95 has been compiled with support for the
96 .Dv AUTHENTICATION
97 option.
98 There are several valid values for
99 .Ar authmode :
100 .Bl -tag -width debug
101 .It debug
102 Turns on authentication debugging code.
103 .It user
104 Only allow connections when the remote user
105 can provide valid authentication information
106 to identify the remote user,
107 and is allowed access to the specified account
108 without providing a password.
109 .It valid
110 Only allow connections when the remote user
111 can provide valid authentication information
112 to identify the remote user.
114 .Xr login 1
115 command will provide any additional user verification
116 needed if the remote user is not allowed automatic
117 access to the specified account.
118 .It other
119 Only allow connections that supply some authentication information.
120 This option is currently not supported
121 by any of the existing authentication mechanisms,
122 and is thus the same as specifying
123 .Fl a
124 .Cm valid .
125 .It otp
126 Only allow authenticated connections (as with
127 .Fl a
128 .Cm user )
129 and also logins with one-time passwords (OTPs).  This option will call
130 login with an option so that only OTPs are accepted.  The user can of
131 course still type secret information at the prompt.
132 .It none
133 This is the default state.
134 Authentication information is not required.
135 If no or insufficient authentication information
136 is provided, then the
137 .Xr login 1
138 program will provide the necessary user
139 verification.
140 .It off
141 This disables the authentication code.
142 All user verification will happen through the
143 .Xr login 1
144 program.
146 .It Fl B
147 Ignored.
148 .It Fl D Ar debugmode
149 This option may be used for debugging purposes.
150 This allows
151 .Nm telnetd
152 to print out debugging information
153 to the connection, allowing the user to see what
154 .Nm telnetd
155 is doing.
156 There are several possible values for
157 .Ar debugmode :
158 .Bl -tag -width exercise
159 .It Cm options
160 Prints information about the negotiation of
161 .Tn TELNET
162 options.
163 .It Cm report
164 Prints the
165 .Cm options
166 information, plus some additional information
167 about what processing is going on.
168 .It Cm netdata
169 Displays the data stream received by
170 .Nm telnetd .
171 .It Cm ptydata
172 Displays data written to the pty.
173 .It Cm exercise
174 Has not been implemented yet.
176 .It Fl e
177 require encryption to be turned on (in both direction) by the client
178 and disconnects if the client tries to turn the encryption off (in
179 either direction).
180 .It Fl h
181 Disables the printing of host-specific information before
182 login has been completed.
183 .It Fl k
184 .It Fl l
185 Ignored.
186 .It Fl n
187 Disable
188 .Dv TCP
189 keep-alives.  Normally
190 .Nm telnetd
191 enables the
192 .Tn TCP
193 keep-alive mechanism to probe connections that
194 have been idle for some period of time to determine
195 if the client is still there, so that idle connections
196 from machines that have crashed or can no longer
197 be reached may be cleaned up.
198 .It Fl r Ar lowpty-highpty
199 This option is only enabled when
200 .Nm telnetd
201 is compiled for
202 .Dv UNICOS .
203 It specifies an inclusive range of pseudo-terminal devices to
204 use.  If the system has sysconf variable
205 .Dv _SC_CRAY_NPTY
206 configured, the default pty search range is 0 to
207 .Dv _SC_CRAY_NPTY ;
208 otherwise, the default range is 0 to 128.  Either
209 .Ar lowpty
211 .Ar highpty
212 may be omitted to allow changing
213 either end of the search range.  If
214 .Ar lowpty
215 is omitted, the - character is still required so that
216 .Nm telnetd
217 can differentiate
218 .Ar highpty
219 from
220 .Ar lowpty .
221 .It Fl S Ar tos
222 .It Fl u Ar len
223 This option is used to specify the size of the field
224 in the
225 .Dv utmp
226 structure that holds the remote host name.
227 If the resolved host name is longer than
228 .Ar len ,
229 the dotted decimal value will be used instead.
230 This allows hosts with very long host names that
231 overflow this field to still be uniquely identified.
232 Specifying
233 .Fl u0
234 indicates that only dotted decimal addresses
235 should be put into the
236 .Pa utmp
237 file.
238 .It Fl U
239 This option causes
240 .Nm telnetd
241 to refuse connections from addresses that
242 cannot be mapped back into a symbolic name
243 via the
244 .Xr gethostbyaddr 3
245 routine.
246 .It Fl X Ar authtype
247 This option is only valid if
248 .Nm telnetd
249 has been built with support for the authentication option.
250 It disables the use of
251 .Ar authtype
252 authentication, and
253 can be used to temporarily disable
254 a specific authentication type without having to recompile
255 .Nm telnetd .
256 .It Fl L Ar pathname
257 Specify pathname to an alternative login program.
258 .It Fl y
259 Makes
261 not warn when a user is trying to login with a cleartext password.
264 .Nm Telnetd
265 operates by allocating a pseudo-terminal device (see
266 .Xr pty 4 )
267 for a client, then creating a login process which has
268 the slave side of the pseudo-terminal as
269 .Dv stdin ,
270 .Dv stdout
272 .Dv stderr .
273 .Nm Telnetd
274 manipulates the master side of the pseudo-terminal,
275 implementing the
276 .Tn TELNET
277 protocol and passing characters
278 between the remote client and the login process.
280 When a
281 .Tn TELNET
282 session is started up,
283 .Nm telnetd
284 sends
285 .Tn TELNET
286 options to the client side indicating
287 a willingness to do the
288 following
289 .Tn TELNET
290 options, which are described in more detail below:
291 .Bd -literal -offset indent
292 DO AUTHENTICATION
293 WILL ENCRYPT
294 DO TERMINAL TYPE
295 DO TSPEED
296 DO XDISPLOC
297 DO NEW-ENVIRON
298 DO ENVIRON
299 WILL SUPPRESS GO AHEAD
300 DO ECHO
301 DO LINEMODE
302 DO NAWS
303 WILL STATUS
304 DO LFLOW
305 DO TIMING-MARK
308 The pseudo-terminal allocated to the client is configured
309 to operate in
310 .Dq cooked
311 mode, and with
312 .Dv XTABS and
313 .Dv CRMOD
314 enabled (see
315 .Xr tty 4 ) .
317 .Nm Telnetd
318 has support for enabling locally the following
319 .Tn TELNET
320 options:
321 .Bl -tag -width "DO AUTHENTICATION"
322 .It "WILL ECHO"
323 When the
324 .Dv LINEMODE
325 option is enabled, a
326 .Dv WILL ECHO
328 .Dv WONT ECHO
329 will be sent to the client to indicate the
330 current state of terminal echoing.
331 When terminal echo is not desired, a
332 .Dv WILL ECHO
333 is sent to indicate that
334 .Tn telnetd
335 will take care of echoing any data that needs to be
336 echoed to the terminal, and then nothing is echoed.
337 When terminal echo is desired, a
338 .Dv WONT ECHO
339 is sent to indicate that
340 .Tn telnetd
341 will not be doing any terminal echoing, so the
342 client should do any terminal echoing that is needed.
343 .It "WILL BINARY"
344 Indicates that the client is willing to send a
345 8 bits of data, rather than the normal 7 bits
346 of the Network Virtual Terminal.
347 .It "WILL SGA"
348 Indicates that it will not be sending
349 .Dv IAC GA ,
350 go ahead, commands.
351 .It "WILL STATUS"
352 Indicates a willingness to send the client, upon
353 request, of the current status of all
354 .Tn TELNET
355 options.
356 .It "WILL TIMING-MARK"
357 Whenever a
358 .Dv DO TIMING-MARK
359 command is received, it is always responded
360 to with a
361 .Dv WILL TIMING-MARK
362 .It "WILL LOGOUT"
363 When a
364 .Dv DO LOGOUT
365 is received, a
366 .Dv WILL LOGOUT
367 is sent in response, and the
368 .Tn TELNET
369 session is shut down.
370 .It "WILL ENCRYPT"
371 Only sent if
372 .Nm telnetd
373 is compiled with support for data encryption, and
374 indicates a willingness to decrypt
375 the data stream.
378 .Nm Telnetd
379 has support for enabling remotely the following
380 .Tn TELNET
381 options:
382 .Bl -tag -width "DO AUTHENTICATION"
383 .It "DO BINARY"
384 Sent to indicate that
385 .Tn telnetd
386 is willing to receive an 8 bit data stream.
387 .It "DO LFLOW"
388 Requests that the client handle flow control
389 characters remotely.
390 .It "DO ECHO"
391 This is not really supported, but is sent to identify a 4.2BSD
392 .Xr telnet 1
393 client, which will improperly respond with
394 .Dv WILL ECHO .
395 If a
396 .Dv WILL ECHO
397 is received, a
398 .Dv DONT ECHO
399 will be sent in response.
400 .It "DO TERMINAL-TYPE"
401 Indicates a desire to be able to request the
402 name of the type of terminal that is attached
403 to the client side of the connection.
404 .It "DO SGA"
405 Indicates that it does not need to receive
406 .Dv IAC GA ,
407 the go ahead command.
408 .It "DO NAWS"
409 Requests that the client inform the server when
410 the window (display) size changes.
411 .It "DO TERMINAL-SPEED"
412 Indicates a desire to be able to request information
413 about the speed of the serial line to which
414 the client is attached.
415 .It "DO XDISPLOC"
416 Indicates a desire to be able to request the name
417 of the X windows display that is associated with
418 the telnet client.
419 .It "DO NEW-ENVIRON"
420 Indicates a desire to be able to request environment
421 variable information, as described in RFC 1572.
422 .It "DO ENVIRON"
423 Indicates a desire to be able to request environment
424 variable information, as described in RFC 1408.
425 .It "DO LINEMODE"
426 Only sent if
427 .Nm telnetd
428 is compiled with support for linemode, and
429 requests that the client do line by line processing.
430 .It "DO TIMING-MARK"
431 Only sent if
432 .Nm telnetd
433 is compiled with support for both linemode and
434 kludge linemode, and the client responded with
435 .Dv WONT LINEMODE .
436 If the client responds with
437 .Dv WILL TM ,
438 the it is assumed that the client supports
439 kludge linemode.
440 Note that the
441 .Op Fl k
442 option can be used to disable this.
443 .It "DO AUTHENTICATION"
444 Only sent if
445 .Nm telnetd
446 is compiled with support for authentication, and
447 indicates a willingness to receive authentication
448 information for automatic login.
449 .It "DO ENCRYPT"
450 Only sent if
451 .Nm telnetd
452 is compiled with support for data encryption, and
453 indicates a willingness to decrypt
454 the data stream.
456 .Sh FILES
457 .Bl -tag -width /etc/services -compact
458 .It Pa /etc/services
459 .It Pa /etc/inittab
460 (UNICOS systems only)
461 .It Pa /etc/iptos
462 (if supported)
464 .Sh "SEE ALSO"
465 .Xr telnet 1 ,
466 .Xr login 1
467 .Sh STANDARDS
468 .Bl -tag -compact -width RFC-1572
469 .It Cm RFC-854
470 .Tn TELNET
471 PROTOCOL SPECIFICATION
472 .It Cm RFC-855
473 TELNET OPTION SPECIFICATIONS
474 .It Cm RFC-856
475 TELNET BINARY TRANSMISSION
476 .It Cm RFC-857
477 TELNET ECHO OPTION
478 .It Cm RFC-858
479 TELNET SUPPRESS GO AHEAD OPTION
480 .It Cm RFC-859
481 TELNET STATUS OPTION
482 .It Cm RFC-860
483 TELNET TIMING MARK OPTION
484 .It Cm RFC-861
485 TELNET EXTENDED OPTIONS - LIST OPTION
486 .It Cm RFC-885
487 TELNET END OF RECORD OPTION
488 .It Cm RFC-1073
489 Telnet Window Size Option
490 .It Cm RFC-1079
491 Telnet Terminal Speed Option
492 .It Cm RFC-1091
493 Telnet Terminal-Type Option
494 .It Cm RFC-1096
495 Telnet X Display Location Option
496 .It Cm RFC-1123
497 Requirements for Internet Hosts -- Application and Support
498 .It Cm RFC-1184
499 Telnet Linemode Option
500 .It Cm RFC-1372
501 Telnet Remote Flow Control Option
502 .It Cm RFC-1416
503 Telnet Authentication Option
504 .It Cm RFC-1411
505 Telnet Authentication: Kerberos Version 4
506 .It Cm RFC-1412
507 Telnet Authentication: SPX
508 .It Cm RFC-1571
509 Telnet Environment Option Interoperability Issues
510 .It Cm RFC-1572
511 Telnet Environment Option
513 .Sh BUGS
514 Some
515 .Tn TELNET
516 commands are only partially implemented.
518 Because of bugs in the original 4.2 BSD
519 .Xr telnet 1 ,
520 .Nm telnetd
521 performs some dubious protocol exchanges to try to discover if the remote
522 client is, in fact, a 4.2 BSD
523 .Xr telnet 1 .
525 Binary mode
526 has no common interpretation except between similar operating systems
527 (Unix in this case).
529 The terminal type name received from the remote client is converted to
530 lower case.
532 .Nm Telnetd
533 never sends
534 .Tn TELNET
535 .Dv IAC GA
536 (go ahead) commands.