"telnetlib" --- cliente Telnet
******************************

**Código fuente:** Lib/telnetlib.py

Obsoleto desde la versión 3.11, se eliminará en la versión 3.13: El
módulo "telnetlib" es obsoleto (véase **PEP 594** para detalles y
alternativas).

======================================================================

El módulo "telnetlib" proporciona una clase "Telnet" que implementa el
protocolo Telnet.  Consulte **RFC 854** para obtener más información
sobre el protocolo. Además, proporciona constantes simbólicas para los
caracteres de protocolo (ver más abajo) y para las opciones telnet.
Los nombres simbólicos de las opciones de telnet siguen las
definiciones de "arpa/telnet.h", con el "TELOPT_" principal eliminado.
Para conocer los nombres simbólicos de las opciones que
tradicionalmente no se incluyen en "arpa/telnet.h", consulte la propia
fuente del módulo.

Las constantes simbólicas para los comandos telnet son: IAC, DONT, DO,
WONT, WILL, SE (Subnegotiation End), NOP (No Operation), DM (Data
Mark), BRK (Break), IP (Interrupt process), AO (Abort output), AYT
(Are You There), EC (Eliminar Character), EL (Erase Line), GA (Go
Ahead), SB (Subnegotiation Begin).

Availability: not Emscripten, not WASI.

Este módulo no funciona o no está disponible en plataformas
WebAssembly "wasm32-emscripten" y "wasm32-wasi". Véase disponibilidad
en wasm para más información.

class telnetlib.Telnet(host=None, port=0[, timeout])

   "Telnet" representa una conexión a un servidor Telnet. La instancia
   inicialmente no está conectada de forma predeterminada; el método
   "open()" debe utilizarse para establecer una conexión.  Como
   alternativa, el nombre de host y el número de puerto opcional
   también se pueden pasar al constructor, en cuyo caso se establecerá
   la conexión con el servidor antes de que se retorne el constructor.
   El parámetro opcional *timeout* especifica un tiempo de espera en
   segundos para bloquear operaciones como el intento de conexión (si
   no se especifica, se usará la configuración de tiempo de espera
   predeterminada global).

   No vuelve a abrir una instancia ya conectada.

   Esta clase tiene muchos métodos "read_*()".  Tenga en cuenta que
   algunos de ellos generan "EOFError" cuando se lee el final de la
   conexión, porque pueden retornar una cadena vacía por otros
   motivos.  Vea las descripciones individuales a continuación.

   Un objeto "Telnet" es un gestor de contexto y se puede utilizar en
   una instrucción "with".  Cuando finaliza el bloque "with", se llama
   al método "close()":

      >>> from telnetlib import Telnet
      >>> with Telnet('localhost', 23) as tn:
      ...     tn.interact()
      ...

   Distinto en la versión 3.6: Soporte de gestor de contexto añadido

Ver también:

  **RFC 854** - Especificación del protocolo Telnet
     Definición del protocolo telnet.


Objetos telnet
==============

Las instancias "Telnet" contienen los siguientes métodos:

Telnet.read_until(expected, timeout=None)

   Lee hasta que se encuentre una cadena de bytes determinada,
   *expected*, o hasta que hayan pasado los segundos *timeout*.

   Cuando no se encuentra ninguna coincidencia, retorna lo que esté
   disponible en su lugar, posiblemente bytes vacíos.  Lanza
   "EOFError" si la conexión está cerrada y no hay datos cocinados
   disponibles.

Telnet.read_all()

   Lee todos los datos hasta EOF como bytes; bloquea hasta que se
   cierre la conexión.

Telnet.read_some()

   Lee al menos un byte de datos cocinados a menos que se golpee EOF.
   Retorna "b''" si se llega a EOF.  Bloquea si no hay datos
   disponibles inmediatamente.

Telnet.read_very_eager()

   Lee todo lo que puede ser sin bloquear en E/S (ansioso).

   Lanza "EOFError" si la conexión está cerrada y no hay datos cocidos
   disponibles. Retorna "b''" si no hay datos cocinados disponibles de
   otra manera. No bloquea a menos que esté en medio de una secuencia
   IAC.

Telnet.read_eager()

   Lee los datos disponibles.

   Lanza "EOFError" si la conexión está cerrada y no hay datos cocidos
   disponibles. Retorna "b''" si no hay datos cocinados disponibles de
   otra manera. No bloquea a menos que esté en medio de una secuencia
   IAC.

Telnet.read_lazy()

   Procesa y retorna datos ya en las colas (perezoso).

   Lanza "EOFError" si la conexión está cerrada y no hay datos
   disponibles. Retorna "b''" si no hay datos cocinados disponibles de
   otra manera.  No bloquea a menos que esté en medio de una secuencia
   IAC.

Telnet.read_very_lazy()

   Retorna los datos disponibles en la cola cocida (muy perezoso).

   Lanza "EOFError" si la conexión está cerrada y no hay datos
   disponibles. Retorna "b''" si no hay datos cocinados disponibles de
   otra manera.  Este método nunca se bloquea.

Telnet.read_sb_data()

   Retorna los datos recopilados entre un par SB/SE (suboption
   begin/end). La retrollamada debe tener acceso a estos datos cuando
   se invocó con un comando "SE". Este método nunca se bloquea.

Telnet.open(host, port=0[, timeout])

   Conecta a un host. El segundo argumento opcional es el número de
   puerto, que tiene como valor predeterminado el puerto Telnet
   estándar (23). El parámetro opcional *timeout* especifica un tiempo
   de espera en segundos para bloquear operaciones como el intento de
   conexión (si no se especifica, se usará la configuración de tiempo
   de espera predeterminada global).

   No intente volver a abrir una instancia ya conectada.

   Genera un  evento de auditoría "telnetlib. Telnet.open" con
   argumentos "self", "host", "port".

Telnet.msg(msg, *args)

   Imprime un mensaje de depuración cuando el nivel de depuración sea
   ">" 0. Si hay argumentos adicionales, se sustituyen en el mensaje
   mediante el operador de formato de cadena de caracteres estándar.

Telnet.set_debuglevel(debuglevel)

   Establece el nivel de depuración.  Cuanto mayor sea el valor de
   *debuglevel*, más salida de depuración obtendrá (en "sys.stdout").

Telnet.close()

   Cierra la conexión.

Telnet.get_socket()

   Retorna el objeto de socket utilizado internamente.

Telnet.fileno()

   Retorna el descriptor de archivo del objeto de socket utilizado
   internamente.

Telnet.write(buffer)

   Escribe una cadena de bytes en el socket, duplicando los caracteres
   IAC. Esto puede bloquearse si la conexión está bloqueada.  Puede
   generar "OSError" si la conexión está cerrada.

   Lanza un evento de auditoría "telnetlib.Telnet.write" con
   argumentos "self", "buffer".

   Distinto en la versión 3.3: Este método se utiliza para lanzar
   "socket.error", que ahora es un alias de "OSError".

Telnet.interact()

   Función de interacción, emula a un cliente Telnet muy tonto.

Telnet.mt_interact()

   Versión multiproceso de "interact()".

Telnet.expect(list, timeout=None)

   Lee hasta que uno de una lista de expresiones regulares coincida.

   El primer argumento es una lista de expresiones regulares,
   compiladas (objetos regex) o no compiladas (cadenas de bytes). El
   segundo argumento opcional es un tiempo de espera, en segundos; el
   valor predeterminado es bloquear indefinidamente.

   Retorna una tupla de tres elementos: el índice de la lista de la
   primera expresión regular que coincide; el objeto de coincidencia
   retornado; y los bytes leen hasta e incluyendo la coincidencia.

   Si se encuentra el final del archivo y no se leyó ningún bytes,
   lanza "EOFError". De lo contrario, cuando nada coincide, retorna
   "(-1, None, data)" donde *data* es los bytes recibidos hasta ahora
   (pueden ser bytes vacíos si se ha producido un tiempo de espera).

   Si una expresión regular termina con una coincidencia expansiva
   (como ".*") o si más de una expresión puede coincidir con la misma
   entrada, los resultados no son deterministas y pueden depender de
   la sincronización de E/S.

Telnet.set_option_negotiation_callback(callback)

   Cada vez que se lee una opción telnet en el flujo de entrada, se
   llama a esta *callback* (si se establece) con los siguientes
   parámetros: callback(telnet socket, command (DO/DONT/WILL/WONT),
   opción).  No hay ninguna otra acción se realiza después por
   telnetlib.


Ejemplo de telnet
=================

Un ejemplo sencillo que ilustra el uso típico:

   import getpass
   import telnetlib

   HOST = "localhost"
   user = input("Enter your remote account: ")
   password = getpass.getpass()

   tn = telnetlib.Telnet(HOST)

   tn.read_until(b"login: ")
   tn.write(user.encode('ascii') + b"\n")
   if password:
       tn.read_until(b"Password: ")
       tn.write(password.encode('ascii') + b"\n")

   tn.write(b"ls\n")
   tn.write(b"exit\n")

   print(tn.read_all().decode('ascii'))
