source: vendor/python/2.5/Doc/lib/libtelnetlib.tex

Last change on this file was 3225, checked in by bird, 18 years ago

Python 2.5

File size: 7.0 KB
Line 
1\section{\module{telnetlib} ---
2 Telnet client}
3
4\declaremodule{standard}{telnetlib}
5\modulesynopsis{Telnet client class.}
6\sectionauthor{Skip Montanaro}{skip@mojam.com}
7
8\index{protocol!Telnet}
9
10The \module{telnetlib} module provides a \class{Telnet} class that
11implements the Telnet protocol. See \rfc{854} for details about the
12protocol. In addition, it provides symbolic constants for the protocol
13characters (see below), and for the telnet options. The
14symbolic names of the telnet options follow the definitions in
15\code{arpa/telnet.h}, with the leading \code{TELOPT_} removed. For
16symbolic names of options which are traditionally not included in
17\code{arpa/telnet.h}, see the module source itself.
18
19The symbolic constants for the telnet commands are: IAC, DONT, DO,
20WONT, WILL, SE (Subnegotiation End), NOP (No Operation), DM (Data
21Mark), BRK (Break), IP (Interrupt process), AO (Abort output), AYT
22(Are You There), EC (Erase Character), EL (Erase Line), GA (Go Ahead),
23SB (Subnegotiation Begin).
24
25
26\begin{classdesc}{Telnet}{\optional{host\optional{, port}}}
27\class{Telnet} represents a connection to a Telnet server. The
28instance is initially not connected by default; the \method{open()}
29method must be used to establish a connection. Alternatively, the
30host name and optional port number can be passed to the constructor,
31to, in which case the connection to the server will be established
32before the constructor returns.
33
34Do not reopen an already connected instance.
35
36This class has many \method{read_*()} methods. Note that some of them
37raise \exception{EOFError} when the end of the connection is read,
38because they can return an empty string for other reasons. See the
39individual descriptions below.
40\end{classdesc}
41
42
43\begin{seealso}
44 \seerfc{854}{Telnet Protocol Specification}{
45 Definition of the Telnet protocol.}
46\end{seealso}
47
48
49
50\subsection{Telnet Objects \label{telnet-objects}}
51
52\class{Telnet} instances have the following methods:
53
54
55\begin{methoddesc}{read_until}{expected\optional{, timeout}}
56Read until a given string, \var{expected}, is encountered or until
57\var{timeout} seconds have passed.
58
59When no match is found, return whatever is available instead,
60possibly the empty string. Raise \exception{EOFError} if the connection
61is closed and no cooked data is available.
62\end{methoddesc}
63
64\begin{methoddesc}{read_all}{}
65Read all data until \EOF; block until connection closed.
66\end{methoddesc}
67
68\begin{methoddesc}{read_some}{}
69Read at least one byte of cooked data unless \EOF{} is hit.
70Return \code{''} if \EOF{} is hit. Block if no data is immediately
71available.
72\end{methoddesc}
73
74\begin{methoddesc}{read_very_eager}{}
75Read everything that can be without blocking in I/O (eager).
76
77Raise \exception{EOFError} if connection closed and no cooked data
78available. Return \code{''} if no cooked data available otherwise.
79Do not block unless in the midst of an IAC sequence.
80\end{methoddesc}
81
82\begin{methoddesc}{read_eager}{}
83Read readily available data.
84
85Raise \exception{EOFError} if connection closed and no cooked data
86available. Return \code{''} if no cooked data available otherwise.
87Do not block unless in the midst of an IAC sequence.
88\end{methoddesc}
89
90\begin{methoddesc}{read_lazy}{}
91Process and return data already in the queues (lazy).
92
93Raise \exception{EOFError} if connection closed and no data available.
94Return \code{''} if no cooked data available otherwise. Do not block
95unless in the midst of an IAC sequence.
96\end{methoddesc}
97
98\begin{methoddesc}{read_very_lazy}{}
99Return any data available in the cooked queue (very lazy).
100
101Raise \exception{EOFError} if connection closed and no data available.
102Return \code{''} if no cooked data available otherwise. This method
103never blocks.
104\end{methoddesc}
105
106\begin{methoddesc}{read_sb_data}{}
107Return the data collected between a SB/SE pair (suboption begin/end).
108The callback should access these data when it was invoked with a
109\code{SE} command. This method never blocks.
110
111\versionadded{2.3}
112\end{methoddesc}
113
114\begin{methoddesc}{open}{host\optional{, port}}
115Connect to a host.
116The optional second argument is the port number, which
117defaults to the standard Telnet port (23).
118
119Do not try to reopen an already connected instance.
120\end{methoddesc}
121
122\begin{methoddesc}{msg}{msg\optional{, *args}}
123Print a debug message when the debug level is \code{>} 0.
124If extra arguments are present, they are substituted in the
125message using the standard string formatting operator.
126\end{methoddesc}
127
128\begin{methoddesc}{set_debuglevel}{debuglevel}
129Set the debug level. The higher the value of \var{debuglevel}, the
130more debug output you get (on \code{sys.stdout}).
131\end{methoddesc}
132
133\begin{methoddesc}{close}{}
134Close the connection.
135\end{methoddesc}
136
137\begin{methoddesc}{get_socket}{}
138Return the socket object used internally.
139\end{methoddesc}
140
141\begin{methoddesc}{fileno}{}
142Return the file descriptor of the socket object used internally.
143\end{methoddesc}
144
145\begin{methoddesc}{write}{buffer}
146Write a string to the socket, doubling any IAC characters.
147This can block if the connection is blocked. May raise
148\exception{socket.error} if the connection is closed.
149\end{methoddesc}
150
151\begin{methoddesc}{interact}{}
152Interaction function, emulates a very dumb Telnet client.
153\end{methoddesc}
154
155\begin{methoddesc}{mt_interact}{}
156Multithreaded version of \method{interact()}.
157\end{methoddesc}
158
159\begin{methoddesc}{expect}{list\optional{, timeout}}
160Read until one from a list of a regular expressions matches.
161
162The first argument is a list of regular expressions, either
163compiled (\class{re.RegexObject} instances) or uncompiled (strings).
164The optional second argument is a timeout, in seconds; the default
165is to block indefinitely.
166
167Return a tuple of three items: the index in the list of the
168first regular expression that matches; the match object
169returned; and the text read up till and including the match.
170
171If end of file is found and no text was read, raise
172\exception{EOFError}. Otherwise, when nothing matches, return
173\code{(-1, None, \var{text})} where \var{text} is the text received so
174far (may be the empty string if a timeout happened).
175
176If a regular expression ends with a greedy match (such as \regexp{.*})
177or if more than one expression can match the same input, the
178results are indeterministic, and may depend on the I/O timing.
179\end{methoddesc}
180
181\begin{methoddesc}{set_option_negotiation_callback}{callback}
182Each time a telnet option is read on the input flow, this
183\var{callback} (if set) is called with the following parameters :
184callback(telnet socket, command (DO/DONT/WILL/WONT), option). No other
185action is done afterwards by telnetlib.
186\end{methoddesc}
187
188
189\subsection{Telnet Example \label{telnet-example}}
190\sectionauthor{Peter Funk}{pf@artcom-gmbh.de}
191
192A simple example illustrating typical use:
193
194\begin{verbatim}
195import getpass
196import sys
197import telnetlib
198
199HOST = "localhost"
200user = raw_input("Enter your remote account: ")
201password = getpass.getpass()
202
203tn = telnetlib.Telnet(HOST)
204
205tn.read_until("login: ")
206tn.write(user + "\n")
207if password:
208 tn.read_until("Password: ")
209 tn.write(password + "\n")
210
211tn.write("ls\n")
212tn.write("exit\n")
213
214print tn.read_all()
215\end{verbatim}
Note: See TracBrowser for help on using the repository browser.