Cliente-a-Cliente DirectoEl Cliente-a-Cliente Directo, del inglés Direct Client-to-Client (DCC), es un protocolo de Internet Relay Chat (IRC) que permite interconectar dos peers o puntos usando un servidor IRC como saludo (handshaking) para permitir intercambiar archivos o llevar a cabo tareas no relacionadas con el chat. Una vez conectados, una típica sesión de DCC corre independiente del servidor IRC. Originalmente diseñado para ser usado con ircII, es ahora soportado por varios clientes IRC. La conexión DCC puede ser iniciada de dos formas diferentes:
Aplicaciones comunes DCCChat DCCEl servicio de chat permite a los usuarios charlar el uno con el otro en una conexión DCC. El tráfico va directamente entre usuarios y no sobre la red IRC. Cuando lo comparamos con el envío normal de mensajes, este reduce la carga en la red IRC. Permitiendo el envío de una gran cantidad de texto de una vez, evitando retrasos, saturación, haciendo la comunicación más segura no exponiendo el mensaje a los servidores de IRC (el mensaje sigue siendo texto plano). El chat DCC es normalmente iniciado usando un saludo CTCP. El usuario que desea establecer la conexión envía el siguiente CTCP al destino:
Donde:
Una vez que la conexión es establecida, el protocolo usado para el chat DCC es muy simple: los usuarios intercambian mensajes terminados en CRLF. Mensajes que comienzan con un ASCII 001 (Control+A, representado por "^A") y la palabra "ACTION" y están opcionalmente terminados por otro ASCII 001, que será interpretado como un emotivo:
DCC WhiteboardEsta una extensión de DCC Chat, que permite comandos para dibujar y ser enviados como líneas de texto. DCC Whiteboard es inicializado con un saludo (handshake) similar al del DCC Chat, con el pseudo nombre de archivo “Chat” reemplazado por “wboard”:
Una vez que la conexión es establecida, los dos clientes intercambian mensajes terminados con CRLF. Los mensajes que comienzan (y opcionalmente terminan) ASCII 001 son interpretados como comando especiales, el comando DCC SendEl servicio de envío (send) permite a los usuarios enviarse archivo entre ellos. La especificación original para el saludo (handshake) no permitía al receptor conocer el tamaño total del archivo, pausar y reanudar (resume) la transferencia. Esto hizo que los clientes introdujeran sus propias extensiones para el saludo (handshake), muchas de las cuales lograron un amplio soporte. El saludo original consistía que el emisor enviaba el siguiente CTCP al destinatario:
Como en el DCC Chat:
En este punto, la especificación original tenía al receptor conectado a la dirección dada y el puerto esperando los datos, o ignorar el pedido, pero para clientes que soportan la extensión
Si el cliente soporta
Y el receptor puede conectarse a la dirección y al puerto dato y escuchar los datos para añadirlo en el archivo. Los datos se envían en bloques, a los que el cliente debe corresponder enviando los tamaños de los bloques de datos entrantes como enteros de 32 bits (Endianness, network byte order). Esto ralentiza las conexiones, y es redundante porque tal comportamiento ya está implementado por Transmission Control Protocol (TCP). La extensión send-ahead solventa este problema no esperando las respuestas, pero ya que el receptor aún debe enviarlas por cada bloque que recibe, en el caso de que el emisor las espere, no está completamente solucionado. Otra extensión, TDCC, o turbo DCC, elimina las respuestas, pero requiere un saludo (handshake) ligeramente modificado y no está ampliamente soportado. Versiones más antiguas de TDCC reemplazan la palabra SEND en el saludo con TSEND; versiones posteriores usan la palabra SEND pero añaden "T" después del saludo, haciendo esta versión de TSEND compatible con otros clientes (tanto como estos puedan analizar el saludo modificado). DCC XMITEl servicio XMIT es una versión modificada de DCC SEND que permite reanudar archivos y cortes. XMIT no está ampliamente soportado. El saludo XMIT difiere algo del saludo SEND. El emisor envía un CTCP ofreciendo un archivo al receptor: DCC XMIT <protocol> <ip> <port>[ <name>[ <size> [<MIME-type>]]]
ERRMSG DCC CHAT <protocol> unavailable El ERRMSG DCC CHAT <protocol> declined Otros errores son reportados de la misma manera. Si el receptor está dispuesto y capaz de recibir el archivo, conectará a la dirección y puerto dados. Lo que pase después dependerá del protocolo usado. En el caso del protocolo "clear", el servidor XMIT, para recibir una conexión, enviará un valor de tiempo time t de 32 bits en (network byte order), representando el tiempo de modificación del archivo. En principio, basándose en el tiempo de modificación del archivo local, el cliente entonces enviará otro dato de tipo long en (network byte order), un offset que el servidor debería buscar cuando envía el archivo. Este debería ser cero si se quiere todo el archivo, o el tamaño del archivo local si el cliente desea reanudar una descarga previa. Aunque es más rápido que SEND, XMIT lleva una de las mismas limitaciones en la que es imposible indicar el tamaño del archivo, a no ser que su tamaño sea especificado en el CTCP de la negociación o conocido antes del saludo. Además, no puedes reanudar un archivo pasada la marca de los dos gigabytes debido al offset de 32 bites. DCC PasivoEn una conexión DCC normal, el iniciador actúa como servidor, y el destino es el cliente. A causa del extendido cortafuegos y la reducción de transparencia de punto-a-punto debido al Network Address Translation (NAT), el iniciador podría no ser capaz de actuar como un servidor. Se han inventado varias formas de solicitar al destino que actúe como el servidor: DCC ServerEsta extensión al DCC SEND y CHAT normales fue introducido por el cliente de IRC denominado mIRC. El servidor DCC tiene soporte moderado, pero no es un estándar en todos los clientes. Permite la iniciación de una conexión DCC por dirección IP, sin la necesidad de un servidor IRC. Eso se lleva a cabo recibiendo al cliente que actúa como un servidor (de ahí el nombre) a la espera (normalmente a través del puerto 59) de un saludo por parte del emisor. Para un CHAT, el iniciador envía:
El destino entonces responde con:
El resto procede de acuerdo con el protocolo estándar del DCC CHAT. Para un SEND, el iniciador envía:
El destino responde con:
Donde El servidor DCC también soporta servidores de archivos estilo-mIRC y DCC GET. RDCCEl servidor DCC no proporciona forma alguna de especificar el puerto a utilizar, así que esto ha de negociarse manualmente, lo cual no siempre es posible, ya que una de las partes puede no ser humana. RDCC es un mecanismo de saludo (handshake) para servidor DCC, en el que además del puerto proporciona la dirección IP del servidor, que de otra manera el cliente podría no ser capaz de encontrar debido al enmascaramiento del host. No está ampliamente soportado. El iniciador solicita el puerto en el que el destino escucha, enviando la petición CTCP:
Donde
Donde DCC ReverseAl contrario que con DCC Server, donde el saludo se maneja directamente sobre la conexión IP, DCC REVERSE tiene un saludo CTCP normal, similar al utilizado por DCC SEND. Esto no está ampliamente soportado. El emisor ofrece un archivo al receptor enviando el mensaje CTCP:
Donde
Aquí
DCC RSendEsta es la alternativa del cliente KVIrc a DCC REVERSE. El emisor ofrece un archivo enviando el CTCP.
El receptor puede aceptar respondiendo con un CTCP.
Y el emisor conecta al receptor y transmite como en un DCC SEND normal. Reverse/Firewall DCCEste mecanismo de DCC pasivo está soportado al menos por mIRC, Visual IRC, XChat, HexChat y KVIrc. El emisor ofrece un archivo enviando el mensaje CTCP:
Donde El receptor puede aceptar el archivo abriendo un socket de escucha y respondiendo con el mensaje CTCP:
Esto es idéntico al mensaje original del DCC inverso, excepto que la El emisor entonces conecta al socket del receptor, envía el contenido del archivo, y espera a que el receptor cierre el socket cuando el archivo esté finalizado. Cuando se usa la extensión RESUME al protocolo SEND, la secuencia de comandos llega a ser (con >> DCC SEND <filename> <ip> 0 <filesize> <token> << DCC RESUME <filename> 0 <position> <token> >> DCC ACCEPT <filename> 0 <position> <token> << DCC SEND <filename> <peer-ip> <port> <filesize> <token> Después de lo cual, el protocolo continúa normalmente (por ejemplo el emisor conecta al socket del receptor). Servidores de archivo (FSERV)Un DCC fserve, o servidor de archivo, permite a un usuario navegar, leer y descargar archivos localizados en un servidor DCC. Normalmente, esto se implementa en una sesión DCC CHAT (la cual se presenta al usuario con un comando prompt) o comandos CTCP especiales para solicitar un archivo. Los archivos se envían sobre DCC SEND o DCC XMIT. Hay muchas implementaciones de servidores de archivo DCC. Entre ellos está el comando FSERV en el popular cliente mIRC. Secure DCC (SDCC)SDCC (Secure Direct Client-to-Client), también conocido como DCC SCHAT, es una variación del protocolo DCC que permite a dos individuos mantener una charla privada en IRC con cifrado sin que se produzca un lag. Este no es muy usado. Véase tambiénReferenciasEnlaces externos
|
Portal di Ensiklopedia Dunia