17db96d56Sopenharmony_ci:mod:`telnetlib` --- Telnet client
27db96d56Sopenharmony_ci==================================
37db96d56Sopenharmony_ci
47db96d56Sopenharmony_ci.. module:: telnetlib
57db96d56Sopenharmony_ci   :synopsis: Telnet client class.
67db96d56Sopenharmony_ci   :deprecated:
77db96d56Sopenharmony_ci
87db96d56Sopenharmony_ci.. sectionauthor:: Skip Montanaro <skip@pobox.com>
97db96d56Sopenharmony_ci
107db96d56Sopenharmony_ci**Source code:** :source:`Lib/telnetlib.py`
117db96d56Sopenharmony_ci
127db96d56Sopenharmony_ci.. index:: single: protocol; Telnet
137db96d56Sopenharmony_ci
147db96d56Sopenharmony_ci.. deprecated-removed:: 3.11 3.13
157db96d56Sopenharmony_ci   The :mod:`telnetlib` module is deprecated
167db96d56Sopenharmony_ci   (see :pep:`PEP 594 <594#telnetlib>` for details and alternatives).
177db96d56Sopenharmony_ci
187db96d56Sopenharmony_ci--------------
197db96d56Sopenharmony_ci
207db96d56Sopenharmony_ciThe :mod:`telnetlib` module provides a :class:`Telnet` class that implements the
217db96d56Sopenharmony_ciTelnet protocol.  See :rfc:`854` for details about the protocol. In addition, it
227db96d56Sopenharmony_ciprovides symbolic constants for the protocol characters (see below), and for the
237db96d56Sopenharmony_citelnet options. The symbolic names of the telnet options follow the definitions
247db96d56Sopenharmony_ciin ``arpa/telnet.h``, with the leading ``TELOPT_`` removed. For symbolic names
257db96d56Sopenharmony_ciof options which are traditionally not included in ``arpa/telnet.h``, see the
267db96d56Sopenharmony_cimodule source itself.
277db96d56Sopenharmony_ci
287db96d56Sopenharmony_ciThe symbolic constants for the telnet commands are: IAC, DONT, DO, WONT, WILL,
297db96d56Sopenharmony_ciSE (Subnegotiation End), NOP (No Operation), DM (Data Mark), BRK (Break), IP
307db96d56Sopenharmony_ci(Interrupt process), AO (Abort output), AYT (Are You There), EC (Erase
317db96d56Sopenharmony_ciCharacter), EL (Erase Line), GA (Go Ahead), SB (Subnegotiation Begin).
327db96d56Sopenharmony_ci
337db96d56Sopenharmony_ci.. include:: ../includes/wasm-notavail.rst
347db96d56Sopenharmony_ci
357db96d56Sopenharmony_ci.. class:: Telnet(host=None, port=0[, timeout])
367db96d56Sopenharmony_ci
377db96d56Sopenharmony_ci   :class:`Telnet` represents a connection to a Telnet server. The instance is
387db96d56Sopenharmony_ci   initially not connected by default; the :meth:`~Telnet.open` method must be used to
397db96d56Sopenharmony_ci   establish a connection.  Alternatively, the host name and optional port
407db96d56Sopenharmony_ci   number can be passed to the constructor too, in which case the connection to
417db96d56Sopenharmony_ci   the server will be established before the constructor returns.  The optional
427db96d56Sopenharmony_ci   *timeout* parameter specifies a timeout in seconds for blocking operations
437db96d56Sopenharmony_ci   like the connection attempt (if not specified, the global default timeout
447db96d56Sopenharmony_ci   setting will be used).
457db96d56Sopenharmony_ci
467db96d56Sopenharmony_ci   Do not reopen an already connected instance.
477db96d56Sopenharmony_ci
487db96d56Sopenharmony_ci   This class has many :meth:`read_\*` methods.  Note that some of them  raise
497db96d56Sopenharmony_ci   :exc:`EOFError` when the end of the connection is read, because they can return
507db96d56Sopenharmony_ci   an empty string for other reasons.  See the individual descriptions below.
517db96d56Sopenharmony_ci
527db96d56Sopenharmony_ci   A :class:`Telnet` object is a context manager and can be used in a
537db96d56Sopenharmony_ci   :keyword:`with` statement.  When the :keyword:`!with` block ends, the
547db96d56Sopenharmony_ci   :meth:`close` method is called::
557db96d56Sopenharmony_ci
567db96d56Sopenharmony_ci       >>> from telnetlib import Telnet
577db96d56Sopenharmony_ci       >>> with Telnet('localhost', 23) as tn:
587db96d56Sopenharmony_ci       ...     tn.interact()
597db96d56Sopenharmony_ci       ...
607db96d56Sopenharmony_ci
617db96d56Sopenharmony_ci   .. versionchanged:: 3.6 Context manager support added
627db96d56Sopenharmony_ci
637db96d56Sopenharmony_ci
647db96d56Sopenharmony_ci.. seealso::
657db96d56Sopenharmony_ci
667db96d56Sopenharmony_ci   :rfc:`854` - Telnet Protocol Specification
677db96d56Sopenharmony_ci      Definition of the Telnet protocol.
687db96d56Sopenharmony_ci
697db96d56Sopenharmony_ci
707db96d56Sopenharmony_ci.. _telnet-objects:
717db96d56Sopenharmony_ci
727db96d56Sopenharmony_ciTelnet Objects
737db96d56Sopenharmony_ci--------------
747db96d56Sopenharmony_ci
757db96d56Sopenharmony_ci:class:`Telnet` instances have the following methods:
767db96d56Sopenharmony_ci
777db96d56Sopenharmony_ci
787db96d56Sopenharmony_ci.. method:: Telnet.read_until(expected, timeout=None)
797db96d56Sopenharmony_ci
807db96d56Sopenharmony_ci   Read until a given byte string, *expected*, is encountered or until *timeout*
817db96d56Sopenharmony_ci   seconds have passed.
827db96d56Sopenharmony_ci
837db96d56Sopenharmony_ci   When no match is found, return whatever is available instead, possibly empty
847db96d56Sopenharmony_ci   bytes.  Raise :exc:`EOFError` if the connection is closed and no cooked data
857db96d56Sopenharmony_ci   is available.
867db96d56Sopenharmony_ci
877db96d56Sopenharmony_ci
887db96d56Sopenharmony_ci.. method:: Telnet.read_all()
897db96d56Sopenharmony_ci
907db96d56Sopenharmony_ci   Read all data until EOF as bytes; block until connection closed.
917db96d56Sopenharmony_ci
927db96d56Sopenharmony_ci
937db96d56Sopenharmony_ci.. method:: Telnet.read_some()
947db96d56Sopenharmony_ci
957db96d56Sopenharmony_ci   Read at least one byte of cooked data unless EOF is hit. Return ``b''`` if
967db96d56Sopenharmony_ci   EOF is hit.  Block if no data is immediately available.
977db96d56Sopenharmony_ci
987db96d56Sopenharmony_ci
997db96d56Sopenharmony_ci.. method:: Telnet.read_very_eager()
1007db96d56Sopenharmony_ci
1017db96d56Sopenharmony_ci   Read everything that can be without blocking in I/O (eager).
1027db96d56Sopenharmony_ci
1037db96d56Sopenharmony_ci   Raise :exc:`EOFError` if connection closed and no cooked data available.
1047db96d56Sopenharmony_ci   Return ``b''`` if no cooked data available otherwise. Do not block unless in
1057db96d56Sopenharmony_ci   the midst of an IAC sequence.
1067db96d56Sopenharmony_ci
1077db96d56Sopenharmony_ci
1087db96d56Sopenharmony_ci.. method:: Telnet.read_eager()
1097db96d56Sopenharmony_ci
1107db96d56Sopenharmony_ci   Read readily available data.
1117db96d56Sopenharmony_ci
1127db96d56Sopenharmony_ci   Raise :exc:`EOFError` if connection closed and no cooked data available.
1137db96d56Sopenharmony_ci   Return ``b''`` if no cooked data available otherwise. Do not block unless in
1147db96d56Sopenharmony_ci   the midst of an IAC sequence.
1157db96d56Sopenharmony_ci
1167db96d56Sopenharmony_ci
1177db96d56Sopenharmony_ci.. method:: Telnet.read_lazy()
1187db96d56Sopenharmony_ci
1197db96d56Sopenharmony_ci   Process and return data already in the queues (lazy).
1207db96d56Sopenharmony_ci
1217db96d56Sopenharmony_ci   Raise :exc:`EOFError` if connection closed and no data available. Return
1227db96d56Sopenharmony_ci   ``b''`` if no cooked data available otherwise.  Do not block unless in the
1237db96d56Sopenharmony_ci   midst of an IAC sequence.
1247db96d56Sopenharmony_ci
1257db96d56Sopenharmony_ci
1267db96d56Sopenharmony_ci.. method:: Telnet.read_very_lazy()
1277db96d56Sopenharmony_ci
1287db96d56Sopenharmony_ci   Return any data available in the cooked queue (very lazy).
1297db96d56Sopenharmony_ci
1307db96d56Sopenharmony_ci   Raise :exc:`EOFError` if connection closed and no data available. Return
1317db96d56Sopenharmony_ci   ``b''`` if no cooked data available otherwise.  This method never blocks.
1327db96d56Sopenharmony_ci
1337db96d56Sopenharmony_ci
1347db96d56Sopenharmony_ci.. method:: Telnet.read_sb_data()
1357db96d56Sopenharmony_ci
1367db96d56Sopenharmony_ci   Return the data collected between a SB/SE pair (suboption begin/end). The
1377db96d56Sopenharmony_ci   callback should access these data when it was invoked with a ``SE`` command.
1387db96d56Sopenharmony_ci   This method never blocks.
1397db96d56Sopenharmony_ci
1407db96d56Sopenharmony_ci
1417db96d56Sopenharmony_ci.. method:: Telnet.open(host, port=0[, timeout])
1427db96d56Sopenharmony_ci
1437db96d56Sopenharmony_ci   Connect to a host. The optional second argument is the port number, which
1447db96d56Sopenharmony_ci   defaults to the standard Telnet port (23). The optional *timeout* parameter
1457db96d56Sopenharmony_ci   specifies a timeout in seconds for blocking operations like the connection
1467db96d56Sopenharmony_ci   attempt (if not specified, the global default timeout setting will be used).
1477db96d56Sopenharmony_ci
1487db96d56Sopenharmony_ci   Do not try to reopen an already connected instance.
1497db96d56Sopenharmony_ci
1507db96d56Sopenharmony_ci   .. audit-event:: telnetlib.Telnet.open self,host,port telnetlib.Telnet.open
1517db96d56Sopenharmony_ci
1527db96d56Sopenharmony_ci
1537db96d56Sopenharmony_ci.. method:: Telnet.msg(msg, *args)
1547db96d56Sopenharmony_ci
1557db96d56Sopenharmony_ci   Print a debug message when the debug level is ``>`` 0. If extra arguments are
1567db96d56Sopenharmony_ci   present, they are substituted in the message using the standard string
1577db96d56Sopenharmony_ci   formatting operator.
1587db96d56Sopenharmony_ci
1597db96d56Sopenharmony_ci
1607db96d56Sopenharmony_ci.. method:: Telnet.set_debuglevel(debuglevel)
1617db96d56Sopenharmony_ci
1627db96d56Sopenharmony_ci   Set the debug level.  The higher the value of *debuglevel*, the more debug
1637db96d56Sopenharmony_ci   output you get (on ``sys.stdout``).
1647db96d56Sopenharmony_ci
1657db96d56Sopenharmony_ci
1667db96d56Sopenharmony_ci.. method:: Telnet.close()
1677db96d56Sopenharmony_ci
1687db96d56Sopenharmony_ci   Close the connection.
1697db96d56Sopenharmony_ci
1707db96d56Sopenharmony_ci
1717db96d56Sopenharmony_ci.. method:: Telnet.get_socket()
1727db96d56Sopenharmony_ci
1737db96d56Sopenharmony_ci   Return the socket object used internally.
1747db96d56Sopenharmony_ci
1757db96d56Sopenharmony_ci
1767db96d56Sopenharmony_ci.. method:: Telnet.fileno()
1777db96d56Sopenharmony_ci
1787db96d56Sopenharmony_ci   Return the file descriptor of the socket object used internally.
1797db96d56Sopenharmony_ci
1807db96d56Sopenharmony_ci
1817db96d56Sopenharmony_ci.. method:: Telnet.write(buffer)
1827db96d56Sopenharmony_ci
1837db96d56Sopenharmony_ci   Write a byte string to the socket, doubling any IAC characters. This can
1847db96d56Sopenharmony_ci   block if the connection is blocked.  May raise :exc:`OSError` if the
1857db96d56Sopenharmony_ci   connection is closed.
1867db96d56Sopenharmony_ci
1877db96d56Sopenharmony_ci   .. audit-event:: telnetlib.Telnet.write self,buffer telnetlib.Telnet.write
1887db96d56Sopenharmony_ci
1897db96d56Sopenharmony_ci   .. versionchanged:: 3.3
1907db96d56Sopenharmony_ci      This method used to raise :exc:`socket.error`, which is now an alias
1917db96d56Sopenharmony_ci      of :exc:`OSError`.
1927db96d56Sopenharmony_ci
1937db96d56Sopenharmony_ci
1947db96d56Sopenharmony_ci.. method:: Telnet.interact()
1957db96d56Sopenharmony_ci
1967db96d56Sopenharmony_ci   Interaction function, emulates a very dumb Telnet client.
1977db96d56Sopenharmony_ci
1987db96d56Sopenharmony_ci
1997db96d56Sopenharmony_ci.. method:: Telnet.mt_interact()
2007db96d56Sopenharmony_ci
2017db96d56Sopenharmony_ci   Multithreaded version of :meth:`interact`.
2027db96d56Sopenharmony_ci
2037db96d56Sopenharmony_ci
2047db96d56Sopenharmony_ci.. method:: Telnet.expect(list, timeout=None)
2057db96d56Sopenharmony_ci
2067db96d56Sopenharmony_ci   Read until one from a list of a regular expressions matches.
2077db96d56Sopenharmony_ci
2087db96d56Sopenharmony_ci   The first argument is a list of regular expressions, either compiled
2097db96d56Sopenharmony_ci   (:ref:`regex objects <re-objects>`) or uncompiled (byte strings). The
2107db96d56Sopenharmony_ci   optional second argument is a timeout, in seconds; the default is to block
2117db96d56Sopenharmony_ci   indefinitely.
2127db96d56Sopenharmony_ci
2137db96d56Sopenharmony_ci   Return a tuple of three items: the index in the list of the first regular
2147db96d56Sopenharmony_ci   expression that matches; the match object returned; and the bytes read up
2157db96d56Sopenharmony_ci   till and including the match.
2167db96d56Sopenharmony_ci
2177db96d56Sopenharmony_ci   If end of file is found and no bytes were read, raise :exc:`EOFError`.
2187db96d56Sopenharmony_ci   Otherwise, when nothing matches, return ``(-1, None, data)`` where *data* is
2197db96d56Sopenharmony_ci   the bytes received so far (may be empty bytes if a timeout happened).
2207db96d56Sopenharmony_ci
2217db96d56Sopenharmony_ci   If a regular expression ends with a greedy match (such as ``.*``) or if more
2227db96d56Sopenharmony_ci   than one expression can match the same input, the results are
2237db96d56Sopenharmony_ci   non-deterministic, and may depend on the I/O timing.
2247db96d56Sopenharmony_ci
2257db96d56Sopenharmony_ci
2267db96d56Sopenharmony_ci.. method:: Telnet.set_option_negotiation_callback(callback)
2277db96d56Sopenharmony_ci
2287db96d56Sopenharmony_ci   Each time a telnet option is read on the input flow, this *callback* (if set) is
2297db96d56Sopenharmony_ci   called with the following parameters: callback(telnet socket, command
2307db96d56Sopenharmony_ci   (DO/DONT/WILL/WONT), option).  No other action is done afterwards by telnetlib.
2317db96d56Sopenharmony_ci
2327db96d56Sopenharmony_ci
2337db96d56Sopenharmony_ci.. _telnet-example:
2347db96d56Sopenharmony_ci
2357db96d56Sopenharmony_ciTelnet Example
2367db96d56Sopenharmony_ci--------------
2377db96d56Sopenharmony_ci
2387db96d56Sopenharmony_ci.. sectionauthor:: Peter Funk <pf@artcom-gmbh.de>
2397db96d56Sopenharmony_ci
2407db96d56Sopenharmony_ci
2417db96d56Sopenharmony_ciA simple example illustrating typical use::
2427db96d56Sopenharmony_ci
2437db96d56Sopenharmony_ci   import getpass
2447db96d56Sopenharmony_ci   import telnetlib
2457db96d56Sopenharmony_ci
2467db96d56Sopenharmony_ci   HOST = "localhost"
2477db96d56Sopenharmony_ci   user = input("Enter your remote account: ")
2487db96d56Sopenharmony_ci   password = getpass.getpass()
2497db96d56Sopenharmony_ci
2507db96d56Sopenharmony_ci   tn = telnetlib.Telnet(HOST)
2517db96d56Sopenharmony_ci
2527db96d56Sopenharmony_ci   tn.read_until(b"login: ")
2537db96d56Sopenharmony_ci   tn.write(user.encode('ascii') + b"\n")
2547db96d56Sopenharmony_ci   if password:
2557db96d56Sopenharmony_ci       tn.read_until(b"Password: ")
2567db96d56Sopenharmony_ci       tn.write(password.encode('ascii') + b"\n")
2577db96d56Sopenharmony_ci
2587db96d56Sopenharmony_ci   tn.write(b"ls\n")
2597db96d56Sopenharmony_ci   tn.write(b"exit\n")
2607db96d56Sopenharmony_ci
2617db96d56Sopenharmony_ci   print(tn.read_all().decode('ascii'))
2627db96d56Sopenharmony_ci
263