INTERNET-DRAFT Simon Butcher Expires April 2004 Alien Internet Services October 2003 Uniform Resource Locator Schemes for Internet Relay Chat Servers Status of this Memo This document is an Internet-Draft and is subject to all provisions of Section 10 of RFC2026. Distribution of this document is unlimited. Comments should be sent to the author. Internet-Drafts are working documents of the Internet Engineering Task Force (IETF), its areas, and its working groups. Note that other groups may also distribute working documents as Internet- Drafts. Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress." The list of current Internet-Drafts can be accessed at http://www.ietf.org/1id-abstracts.html The list of Internet-Draft Shadow Directories can be accessed at http://www.ietf.org/shadow.html Copyright Notice Copyright (C) The Internet Society (2003). All Rights Reserved. Abstract This document specifies two URL (Uniform Resource Locator) schemes, using the URI (Uniform Resource Indicator) names "irc" and "ircs", for the location of IRC (Internet Relay Chat) servers. These URLs allow for easy location of an IRC server, optionally also specifying an IRC channel to join or person to contact upon connection. S. Butcher Expires April 2004 [Page 1] INTERNET-DRAFT URL Schemes for IRC October 2003 1. Introduction Since its introduction, Internet Relay Chat (IRC) has become widely known and used within the Internet Community as a real-time chat medium. IRC networks are steadily growing larger, not only with regards to the number of regular uses, but also the number of channels and servers required to support the demand. Due to the nature of IRC as a simple real-time chat service, it has been known to be used for a wide variety of uses such as software support, job interviews, and of course just for a casual chat. While IRC is progressing, the need for an appropriate Uniform Resource Locator (URL) scheme has become apparent. Applications for such a scheme would range quite widely, including IRC network server lists on a website, software support contact details, or even a meeting location with an e-mail including a specific IRC channel. The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in [RFC2119]. In this document, the term "client" is defined as the IRC client software, and the term "user" is the end-user of that software. 2. URL Definition An IRC URL begins with either the Uniform Resource Identifiers (URIs) "irc" or "ircs", denoting normal and secured connections respectively. Normal sessions are via the existing transport, as defined in [RFC2812], and secured sessions are the same, only via a secure transport layer such as [TLS] (or [SSL], the predecessor to TLS). The URL scheme for IRC follows the Generic URL Syntax, defined in [RFC2396]. The action the URL is to instigate is to open a connection to the specified IRC server using whatever protocol necessary. At the time of writing, only one protocol is defined to do this, as defined in RFC 2812. S. Butcher Expires April 2004 [Page 2] INTERNET-DRAFT URL Schemes for IRC October 2003 2.1. ABNF Syntax The following is the definition for an IRC URL in [ABNF] grammar: ircURL = type "://" location "/" [ channel ] [ options ] type = "irc" / "ircs" location = [ authinfo "@" ] hostport ; See Section 3.2.2 of [RFC2396] for the ; definition of 'hostport'. authinfo = [ nickname *2( "," nickname ) ] [ ":" password ] nickname = *( escaped / unreserved ) ; Further restrictions may apply upon connection, ; depending on the server. Some common nickname ; characters must be encoded as per ; recommendations in Section 2.4.3 of [RFC2396]. password = *( escaped / unreserved ) channel = [ "#" / "&" ] optparam [ "," optparam ] ; The definition of 'channel' is the same as ; 'optvalue' for the 'channel' option (see Section ; 2.6.1), except that the two most common channel ; prefixes, "#" and "&", may be used ; without escapes. channame = optparam chankey = optparam options = "?" option *( "&" option ) option = optname [ "=" optvalue ] optname = *( ALPHA ) ; Option names are case-insensitive. optvalue = optparam *( "," optparam ) optparam = *( escaped / unreserved ) The definition of "escaped" and "unreserved" is in sections 2.4.1 and 2.3 of [RFC2396] respectively. Clients MUST be aware of protocol limitations. For example, "IRC-2", as specified in [RFC2812], disallows characters such as spaces (U+0020). S. Butcher Expires April 2004 [Page 3] INTERNET-DRAFT URL Schemes for IRC October 2003 2.2. Authentication Multiple nicknames MAY be specified, and pending any error or lack of availability, the IRC client software MAY request the next nickname in the list. Clients MUST NOT accept any more than three (3) nicknames, and any more nicknames specified MUST be ignored to curtail potential abuse. Clients may only attempt to use alternative nicknames given during the one connection. Clients MUST NOT reconnect to the server to try alternative nicknames. Should the client run out of alternative nicknames to try, but the server is willing to accept another attempt, the client MAY either disconnect from the server and show the user an error message, or prompt the user for another nickname to try. The use of passwords is not recommended, as they present a significant security problem. They are allowed purely for convenience. Users of the authentication field must be aware of the security issues discussed in Section 6 of this document. 2.3. Server Names If the host name used is not a raw address (such as an IPv4, IPv6, or other raw address), the name cannot be resolved (through DNS or other means), and does not contain a period character (code point U+002E), the client MAY use the hostname as a network name to find an appropriate IRC server. This action SHOULD NOT occur for "ircs" scheme, as the destination may be dubious. See Section 3 for an example of this in use. S. Butcher Expires April 2004 [Page 4] INTERNET-DRAFT URL Schemes for IRC October 2003 2.4. Server Ports Special consideration must be given to URLs without ports specified. Almost all IRC servers are contactable on a variety of standard ports as allocated by the IANA. Should an IRC URL be specified without a port, a client SHOULD try a number of standard ports: - For the "irc" URI, it is RECOMMENDED that the server is attempts connection to the ports 6667, 194, 6665, 6666, 6668 and 6669, in that order. Port 194 is likely to be a more "authentic" server, however most IRC servers are available on ports 6667, at least. - For the "ircs" URI, it is RECOMMENDED that the default port used is 994. User-space ports (those above port 1023) may have questionable authenticity, and SHOULD NOT be used unless explicitly specified. Port numbers shown here are in decimal, and have been assigned by the IANA. 2.5. Channels For compatibility with older implementations, and to allow simplification of the specification, channels MAY be specified without the use of the "channel" option detailed in Section 2.6.1. Only one channel can be specified, optionally with a key, and this facility has the same functionality as the "channel" option. See Section 3 of this document for examples of the equivalence between this and the "channel" option in Section 2.6.1. 2.6. Additional Options Additional options may be added to control what action the client software MAY take following connection to the IRC server. Unsupported options MUST be ignored by the client. All options, other than the 'channel' option, should be considered optional. Clients MUST implement the 'channel' option, but MAY omit other options. These options listed here may be expanded on at a later date by updated RFC's. S. Butcher Expires April 2004 [Page 5] INTERNET-DRAFT URL Schemes for IRC October 2003 2.6.1. The "channel" Option This instructs the client to join the specified channel, allowing the user to participate in discussions within the channel. The value given with the channel option is a channel name, and optionally a "key" (see Section 4.2.10 of [RFC2811]). Its value can be defined in [ABNF] as follows: optvalue = name [ "," key ] For information on acceptable characters in either the 'name' or 'key' fields, see the definition of 'optparam' in Section 2.1 of this document. If the client discovers the channel name given is considered to be invalid because it is missing a valid prefix character, the client SHOULD prepend a default prefix character to the name. Clients MUST attempt to determine valid channel name prefix characters from the server it is connected to, such as via an "RPL_ISUPPORT" reply. If the client is unable to determine valid prefix characters for the server it is connected to, the client MUST attempt to join the channel without modifying its name. If joining the channel failed, the prefix characters defined by [RFC2811] should be presumed to be valid, and the default for this server should be prepended to the name. Since default prefix characters for channels may differ between IRC servers, the client MUST try to determine the default channel prefix for the server it is connected to. If the client is still unable to determine a prefix character, a prefix character of '#' (U+0023) MAY be presumed. The number of channels which can be joined at once is normally restricted by the server, but no hard-limit is given by this specification as this is a matter of individual server policy. As such, multiple "channel" options may be given. An automated message MUST NOT be sent to the channel upon joining it. It is NOT RECOMMENDED to use the channel key feature. Please see Section 6 of this document. If a key is required to join a channel, and one is not given, the IRC client MAY wish to prompt the user for the key. S. Butcher Expires April 2004 [Page 6] INTERNET-DRAFT URL Schemes for IRC October 2003 2.6.2. The "query" Option For each "query" option, the client is requested to open some interface where by users may type a message to the given query target. For example, the client may open up a window where messages may be typed to, and received from the target. Some clients may not have the ability to open up a specific window or dialogue box. These clients MAY prompt the user for a message to be sent to the target, or otherwise this option MAY be ignored and hence unsupported. The option value is the same as the message target value specified in Section 3.3.1 of [RFC2812], except that the client MUST only accept one target. Multiple targets per "query" option MUST NOT be accepted, and the entire query MUST be considered invalid and ignored. A message MUST NOT be automatically sent to the target, simply an interface created to allow the user to send a message to the target. The IRC client software MAY wish to check the availability of the target prior to opening the interface if inclined to do so, however any method of testing the availability MUST NOT generate any automatic message being sent to the target. Multiple targets MAY be referenced with multiple query options, however in order to reduce the potential for abuse, it is RECOMMENDED that additional query options are ignored. There are valid reasons for having multiple targets, and abuse is minimal as no messages are sent to the targets. S. Butcher Expires April 2004 [Page 7] INTERNET-DRAFT URL Schemes for IRC October 2003 3. Examples While examples of every situation cannot be shown here because of space considerations, the following examples provide a rough overview of how the IRC URL can be used. In its simplest form, the above complete URL can be used to direct a client to a specific IRC server, which in this case is "irc.undernet.org". The client should presume to use default port settings. The above URL specifies that the IRC client should try to connect to "irc.efnet.org" on the port 6667, rather than use whatever is considered the default. It also tells the IRC client it should try to use a nickname of "pickle", if it is available. This shows a properly [UTF-8] encoded URL, specifying the nickname Idil (with the first character being a Turkish Latin capital letter "I" with a dot above it, [Unicode] code point U+0130). Failing that, the second nickname, "idil", may be used if the first one is rejected, perhaps by an older IRC server. The above URL will instruct the IRC client to connect to a server with the address 192.0.2.1, which is an IRC server that is presumably password protected. The client should request to use the nickname "pickle", with the password "secret" to authenticate the session to the remote server. This URL also enforces the standard IRC port, 194, and will stop IRC clients from hunting for ports. All three of these URLs connects to the IRCnet network, and will join the client to the channel "#worldchat" upon connection. This will connect to the server "irc.alien.net.au" and will provoke the client to open up a window (or similar) associated with sending S. Butcher Expires April 2004 [Page 8] INTERNET-DRAFT URL Schemes for IRC October 2003 messages to the nickname 'pickle'. It will also join the channel "+private" using the channel key "foo". This will connect to AUSTnet and join two channels, "#melbourne" and "#sydney", with the keys "foo" and "bah", respectively. This will open a dialogue box prepared to send a message to "pickle%butcher.id.au". Please refer to Section 3.3.1 of [RFC2812] for more details. This URL will connect to the network named as "undernet", so long as the client is configured appropriately to know of server(s) associated with this name. S. Butcher Expires April 2004 [Page 9] INTERNET-DRAFT URL Schemes for IRC October 2003 4. Internationalisation Considerations With the inevitable adoption of [Unicode] on IRC, and indeed the Internet as a whole, URLs MUST be encoded using the [UTF-8] character set, with potentially unsafe octets encoded using %HH notation (where HH is a hexadecimal value), as per Section 2.2.5 of [RFC-2718]. For example, the word for "alias" in Japanese, using Unicode code- points, is U+5225 U+540D. Correctly encoded, this would appear in the URL as: "%E5%88%A5%E5%90%8D". An example of this use in action can be found in Section 3. 5. Interoperability Considerations Many existing implementations fail to acknowledge the correct use of the generic URL syntax defined in [RFC2396], but continue to use the format regardless. This implementation flaw is likely to be due to the first documentation of the irc: URI scheme by the W3C's [PICS] recommendation. This implementation has never adequately considered the needs of IRC, nor even the implementation of IRC at the time. Some current implementations will need slight modification to accept the extended format defined in this specification, however most implementations which parse the URL in a standard form will continue to work. The majority of incongruities are simply caused by the problem of developers ignoring RFC-2396. The use of the channel name without specifying the channel option is to both maintain compatibility with the existing implementations, whilst providing an abbreviated form, similar to the design of the "mailto:" scheme defined by [RFC2368]. Some fields have been extended to allow additional characters outside of those normally needing to be encoded to allow for interoperability with existing implementations. S. Butcher Expires April 2004 [Page 10] INTERNET-DRAFT URL Schemes for IRC October 2003 6. Security Considerations Security problems arise only when the authentication portion of the URL is used, or channel keys are given. While the use of the password/key extensions is considered to be rare, they have been included for completeness. Clients SHOULD confirm the choice of nickname for the connection, if one is specified by the URL, or explicitly ignore the nickname given and use its own configured nickname. If a URL specifying a nickname is wide-spread, it could be used to confuse or annoy third parties. As the passwords and channel keys are unfortunately in clear-text, any user using the IRC URL should be aware of obvious insecurities. Furthermore, it is recommended that user software does not automatically initiate the connection specified by the URL without the knowledge and consent of the user. To do so would open the implementation up to a variety of malicious activities including, but not limited to, the purposes of direct advertising or channel advertising (also known as "spam") by way of pop-ups. When connecting using a secure connection ("ircs://"), user-space ports (those above port 1023) should not be used automatically, as their authority is questionable. If a secure connection cannot be established, the client MUST either give up, or prompt the user before attempting an insecure ("irc://") connection. Automated messages MUST NOT be sent to channels or other users upon connection to an IRC server as a direct action of this URL. Sending messages to channels and other users should be left up to the user, not the URL writer or the client software. The facility to send automated messages to other users has been explicitly avoided in this document to avoid abuse, common with IRC. Beyond this, there are security concerns with regards with associated protocols, including IRC and TLS, which must be taken into consideration, but are beyond the scope of this document. S. Butcher Expires April 2004 [Page 11] INTERNET-DRAFT URL Schemes for IRC October 2003 7. IANA Considerations The following is registration for the URL schemes as per [RFC2717]: URL scheme name: "irc" and "ircs". URL scheme syntax: See Section 2.1. Character encoding considerations: Characters must be encoded in UTF-8 and escaped. See Section 4. Intended usage: The scheme initiates connection to an IRC server, normally through the execution of IRC Client software. Interoperability considerations: See Section 5. Security considerations: See Section 6. Relevant publications: The IRC protocol is defined by [RFC2812]. Either [SSL] or [TLS] may be used for the "ircs" scheme, depending on client and server configuration. Person & email address to contact for further information: The Author; See Section 10 for details. Author/Change controller: The IETF is to maintain change control. 8. Acknowledgments Thanks must go to Khaled Mardam-Bey for his early implementation in his software, "mIRC", which provided the inspiration to clarify the specification. I acknowledge the previous work of Mandar Mirashi who originally wrote an Internet-Draft to similar effect, but of which this document has no direct derivation. The input of Petr Baudis, Samuel Sieb, Piotr Kucharski, and Scott Sinclair was greatly appreciated. I would also like to acknowledge those members of the IRC development community who encouraged me to publish this document, after more than 18 months of pretermission. S. Butcher Expires April 2004 [Page 12] INTERNET-DRAFT URL Schemes for IRC October 2003 9. References [ABNF] Crocker, D., and Overell, P., "Augmented BNF for Syntax Specifications: ABNF", RFC 2234, November 1997. [PICS] Miller, J., Resnick, P., Singer, D., "Rating Services and Rating Systems (and Their Machine Readable Descriptions)", Version 1.1, , October 1996. [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997. [RFC2368] Hoffman, P., Masinter, L., Zawinski, J., "The mailto URL scheme", RFC 2368, July 1998. [RFC2396] Berners-Lee, T, Fielding, T., Masinter, L., "Uniform Resource Identifiers (URI): Generic Syntax", RFC 2396, August 1998. [RFC2717] Petke, R., King, I., "Registration Procedures for URL Scheme Names", RFC 2717, November 1999. [RFC2718] Masinter, L., Alvestrand, H., Zigmond, D., Petke, R., "Guidelines for new URL Schemes", RFC 2718, November 1999. [RFC2811] Kalt, C., "Internet Relay Chat: Channel Management", RFC 2811, April 2000. [RFC2812] Kalt, C., "Internet Relay Chat: Client Protocol", RFC 2819, April 2000. [SSL] Hickman, K., "The SSL Protocol", Netscape Communications Corp., February 9, 1995. [TLS] Dierks, T. and Allen, C., "The TLS Protocol Version 1.0", RFC 2246, January 1999. [Unicode] The Unicode Consortium. The Unicode Standard, Version 4.0.0, (Reading, MA, Addison-Wesley, 2003. ISBN 0-321-18578-1). [UTF-8] Yergeau, F., "UTF-8, a transformation format of ISO 10646", RFC 2279, January 1998. S. Butcher Expires April 2004 [Page 13] INTERNET-DRAFT URL Schemes for IRC October 2003 10. Author's Address Simon Butcher Alien Internet Services PO Box 7041 Croydon South VIC 3136 Australia Phone: +61-3-9879-8052 Fax: +61-3-9893-2793 Email: simonb@alien.net.au simon@butcher.name simon@butcher.id.au 11. Intellectual Property Rights Notice The IETF takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this document or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Information on the IETF's procedures with respect to rights in standards-track and standards-related documentation can be found in BCP-11. Copies of claims of rights made available for publication and any assurances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementers or users of this specification can be obtained from the IETF Secretariat. The IETF invites any interested party to bring to its attention any copyrights, patents or patent applications, or other proprietary rights which may cover technology that may be required to practice this standard. Please address the information to the IETF Executive Director. S. Butcher Expires April 2004 [Page 14] INTERNET-DRAFT URL Schemes for IRC October 2003 12. Full Copyright Notice Copyright (C) The Internet Society (2003). All Rights Reserved. This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this paragraph are included on all such copies and derivative works. However, this document itself may not be modified in any way, such as by removing the copyright notice or references to the Internet Society or other Internet organizations, except as needed for the purpose of developing Internet standards in which case the procedures for copyrights defined in the Internet Standards process must be followed, or as required to translate it into languages other than English. The limited permissions granted above are perpetual and will not be revoked by the Internet Society or its successors or assigns. This document and the information contained herein is provided on an "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Document Expiration and Filename Please note that this is a draft document and it shall expire April 2004. Its filename is draft-butcher-irc-url-02.txt S. Butcher Expires April 2004 [Page 15]