The Secure Shell (SSH) Protocol Assigned Numbers
draft-ietf-secsh-assignednumbers-12
The information below is for an old version of the document that is already published as an RFC.
Document | Type |
This is an older version of an Internet-Draft that was ultimately published as RFC 4250.
|
|
---|---|---|---|
Authors | Chris M. Lonvick , Sami Lehtinen | ||
Last updated | 2015-10-14 (Latest revision 2005-03-16) | ||
RFC stream | Internet Engineering Task Force (IETF) | ||
Intended RFC status | Proposed Standard | ||
Formats | |||
Additional resources | Mailing list discussion | ||
Stream | WG state | WG Document | |
Document shepherd | (None) | ||
IESG | IESG state | Became RFC 4250 (Proposed Standard) | |
Action Holders |
(None)
|
||
Consensus boilerplate | Unknown | ||
Telechat date | (None) | ||
Responsible AD | Russ Housley | ||
Send notices to | (None) |
draft-ietf-secsh-assignednumbers-12
Network Working Group S. Lehtinen Internet-Draft SSH Communications Security Corp Expires: September 15, 2005 C. Lonvick, Ed. Cisco Systems, Inc. March 14, 2005 SSH Protocol Assigned Numbers draft-ietf-secsh-assignednumbers-12.txt Status of this Memo This document is an Internet-Draft and is subject to all provisions of Section 3 of RFC 3667. By submitting this Internet-Draft, each author represents that any applicable patent or other IPR claims of which he or she is aware have been or will be disclosed, and any of which he or she become aware will be disclosed, in accordance with RFC 3668. 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/ietf/1id-abstracts.txt. The list of Internet-Draft Shadow Directories can be accessed at http://www.ietf.org/shadow.html. This Internet-Draft will expire on September 15, 2005. Copyright Notice Copyright (C) The Internet Society (2005). Abstract This document defines the instructions to the IANA and the initial state of the IANA assigned numbers for the SSH protocol. It is intended only for the initialization of the IANA registries referenced in the documents. Lehtinen & Lonvick Expires September 15, 2005 [Page 1] Internet-Draft SSH Protocol Assigned Numbers March 2005 Table of Contents 1. Contributors . . . . . . . . . . . . . . . . . . . . . . . . 4 2. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 4 3. Conventions Used in This Document . . . . . . . . . . . . . 4 3.1 RFC2119 Keywords . . . . . . . . . . . . . . . . . . . . . 4 3.2 RFC2434 Keywords . . . . . . . . . . . . . . . . . . . . . 4 3.3 Protocol Fields and Values . . . . . . . . . . . . . . . . 5 4. IANA Considerations . . . . . . . . . . . . . . . . . . . . 6 4.1 Message Numbers . . . . . . . . . . . . . . . . . . . . . 7 4.1.1 Conventions . . . . . . . . . . . . . . . . . . . . . 7 4.1.2 Initial Assignments . . . . . . . . . . . . . . . . . 8 4.1.3 Future Assignments . . . . . . . . . . . . . . . . . . 8 4.2 Disconnection Messages Reason Codes and Descriptions . . . 9 4.2.1 Conventions . . . . . . . . . . . . . . . . . . . . . 9 4.2.2 Initial Assignments . . . . . . . . . . . . . . . . . 9 4.2.3 Future Assignments . . . . . . . . . . . . . . . . . . 10 4.3 Channel Connection Failure Reason Codes and Descriptions . 10 4.3.1 Conventions . . . . . . . . . . . . . . . . . . . . . 10 4.3.2 Initial Assignments . . . . . . . . . . . . . . . . . 10 4.3.3 Future Assignments . . . . . . . . . . . . . . . . . . 10 4.3.4 Notes about the PRIVATE USE Range . . . . . . . . . . 11 4.4 Extended Channel Data Transfer data_type_code and Data . . 11 4.4.1 Conventions . . . . . . . . . . . . . . . . . . . . . 11 4.4.2 Initial Assignments . . . . . . . . . . . . . . . . . 11 4.4.3 Future Assignments . . . . . . . . . . . . . . . . . . 12 4.5 Pseudo-Terminal Encoded Terminal Modes . . . . . . . . . . 12 4.5.1 Conventions . . . . . . . . . . . . . . . . . . . . . 12 4.5.2 Initial Assignments . . . . . . . . . . . . . . . . . 12 4.5.3 Future Assignments . . . . . . . . . . . . . . . . . . 14 4.6 Names . . . . . . . . . . . . . . . . . . . . . . . . . . 14 4.6.1 Conventions for Names . . . . . . . . . . . . . . . . 14 4.6.2 Future Assignments of Names . . . . . . . . . . . . . 15 4.7 Service Names . . . . . . . . . . . . . . . . . . . . . . 15 4.8 Authentication Method Names . . . . . . . . . . . . . . . 15 4.9 Connection Protocol Assigned Names . . . . . . . . . . . . 16 4.9.1 Connection Protocol Channel Types . . . . . . . . . . 16 4.9.2 Connection Protocol Global Request Names . . . . . . . 16 4.9.3 Connection Protocol Channel Request Names . . . . . . 16 4.9.4 Initial Assignment of Signal Names . . . . . . . . . . 17 4.9.5 Connection Protocol Subsystem Names . . . . . . . . . 17 4.10 Key Exchange Method Names . . . . . . . . . . . . . . . 17 4.11 Assigned Algorithm Names . . . . . . . . . . . . . . . . 18 4.11.1 Encryption Algorithm Names . . . . . . . . . . . . . 18 4.11.2 MAC Algorithm Names . . . . . . . . . . . . . . . . 18 4.11.3 Public Key Algorithm Names . . . . . . . . . . . . . 19 4.11.4 Compression Algorithm Names . . . . . . . . . . . . 19 5. Security Considerations . . . . . . . . . . . . . . . . . . 19 Lehtinen & Lonvick Expires September 15, 2005 [Page 2] Internet-Draft SSH Protocol Assigned Numbers March 2005 6. References . . . . . . . . . . . . . . . . . . . . . . . . . 19 6.1 Normative References . . . . . . . . . . . . . . . . . . . 19 6.2 Informative References . . . . . . . . . . . . . . . . . . 20 Authors' Addresses . . . . . . . . . . . . . . . . . . . . . 20 A. Trademark Notice . . . . . . . . . . . . . . . . . . . . . . 21 Intellectual Property and Copyright Statements . . . . . . . 22 Lehtinen & Lonvick Expires September 15, 2005 [Page 3] Internet-Draft SSH Protocol Assigned Numbers March 2005 1. Contributors The major original contributors of this set of documents have been: Tatu Ylonen, Tero Kivinen, Timo J. Rinne, Sami Lehtinen (all of SSH Communications Security Corp), and Markku-Juhani O. Saarinen (University of Jyvaskyla). Darren Moffit was the original editor of this set of documents and also made very substantial contributions. Many people contributed to the development of this document over the years. People who should be acknowledged include Mats Andersson, Ben Harris, Brent McClure, Niels Moller, Damien Miller, Derek Fawcus, Frank Cusack, Heikki Nousiainen, Jakob Schlyter, Jeff Van Dyke, Jeffrey Altman, Jeffrey Hutzelman, Jon Bright, Joseph Galbraith, Ken Hornstein, Markus Friedl, Martin Forssen, Nicolas Williams, Niels Provos, Perry Metzger, Peter Gutmann, Simon Josefsson, Simon Tatham, Wei Dai, Denis Bider, der Mouse, and Tadayoshi Kohno. Listing their names here does not mean that they endorse this document, but that they have contributed to it. 2. Introduction This document does not define any new protocols. It is intended only to create the initial state of the IANA databases for the SSH protocol and also contains instructions for future assignments. Except for one HISTORIC algorithm generally regarded as obsolete, this document does not define any new protocols or any number ranges not already defined in: [SSH-ARCH], [SSH-TRANS], [SSH-USERAUTH], [SSH-CONNECT]. 3. Conventions Used in This Document 3.1 RFC2119 Keywords All documents related to the SSH protocols shall use the keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" to describe requirements. These keywords are to be interpreted as described in [RFC2119]. 3.2 RFC2434 Keywords The keywords "PRIVATE USE", "HIERARCHICAL ALLOCATION", "FIRST COME FIRST SERVED", "EXPERT REVIEW", "SPECIFICATION REQUIRED", "IESG APPROVAL", "IETF CONSENSUS", and "STANDARDS ACTION" that appear in this document when used to describe namespace allocation are to be interpreted as described in [RFC2434]. These designations are repeated in this document for clarity. Lehtinen & Lonvick Expires September 15, 2005 [Page 4] Internet-Draft SSH Protocol Assigned Numbers March 2005 PRIVATE USE - For private or local use only, with the type and purpose defined by the local site. No attempt is made to prevent multiple sites from using the same value in different (and incompatible) ways. There is no need for IANA to review such assignments and assignments are not generally useful for interoperability. HIERARCHICAL ALLOCATION - Delegated managers can assign values provided they have been given control over that part of the name space. IANA controls the higher levels of the namespace according to one of the other policies. FIRST COME FIRST SERVED - Anyone can obtain an assigned number, so long as they provide a point of contact and a brief description of what the value would be used for. For numbers, the exact value is generally assigned by the IANA; with names, specific names are usually requested. EXPERT REVIEW - approval by a Designated Expert is required. SPECIFICATION REQUIRED - Values and their meaning must be documented in an RFC or other permanent and readily available reference, in sufficient detail so that interoperability between independent implementations is possible. IESG APPROVAL - New assignments must be approved by the IESG, but there is no requirement that the request be documented in an RFC (though the IESG has discretion to request documents or other supporting materials on a case-by-case basis). IETF CONSENSUS - New values are assigned through the IETF consensus process. Specifically, new assignments are made via RFCs approved by the IESG. Typically, the IESG will seek input on prospective assignments from appropriate persons (e.g., a relevant Working Group if one exists). STANDARDS ACTION - Values are assigned only for Standards Track RFCs approved by the IESG. 3.3 Protocol Fields and Values Protocol fields and possible values to fill them are defined in this set of documents. Protocol fields will be defined in the message definitions. As an example, SSH_MSG_CHANNEL_DATA is defined as follows. byte SSH_MSG_CHANNEL_DATA uint32 recipient channel Lehtinen & Lonvick Expires September 15, 2005 [Page 5] Internet-Draft SSH Protocol Assigned Numbers March 2005 string data Throughout these documents, when the fields are referenced, they will appear within single quotes. When values to fill those fields are referenced, they will appear within double quotes. Using the above example, possible values for 'data' are "foo" and "bar". 4. IANA Considerations This entire document is the IANA considerations for the SSH protocol as is defined in [SSH-ARCH], [SSH-TRANS], [SSH-USERAUTH], [SSH-CONNECT]. This section contains conventions used in naming the namespaces, the initial state of the registry, and instructions for future assignments. Lehtinen & Lonvick Expires September 15, 2005 [Page 6] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.1 Message Numbers The Message Number is a byte value, which describes the payload of a packet. 4.1.1 Conventions Protocol packets have message numbers in the range 1 to 255. These numbers are allocated as follows: Transport layer protocol: 1 to 19 Transport layer generic (e.g., disconnect, ignore, debug, etc.) 20 to 29 Algorithm negotiation 30 to 49 Key exchange method specific (numbers can be reused for different authentication methods) User authentication protocol: 50 to 59 User authentication generic 60 to 79 User authentication method specific (numbers can be reused for different authentication methods) Connection protocol: 80 to 89 Connection protocol generic 90 to 127 Channel related messages Reserved for client protocols: 128 to 191 Reserved Local extensions: 192 to 255 Local extensions Lehtinen & Lonvick Expires September 15, 2005 [Page 7] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.1.2 Initial Assignments The following table identifies the initial assignments of the Message ID values. Message ID Value Reference ----------- ----- --------- SSH_MSG_DISCONNECT 1 [SSH-TRANS] SSH_MSG_IGNORE 2 [SSH-TRANS] SSH_MSG_UNIMPLEMENTED 3 [SSH-TRANS] SSH_MSG_DEBUG 4 [SSH-TRANS] SSH_MSG_SERVICE_REQUEST 5 [SSH-TRANS] SSH_MSG_SERVICE_ACCEPT 6 [SSH-TRANS] SSH_MSG_KEXINIT 20 [SSH-TRANS] SSH_MSG_NEWKEYS 21 [SSH-TRANS] SSH_MSG_KEXDH_INIT 30 [SSH-TRANS] SSH_MSG_KEXDH_REPLY 31 [SSH-TRANS] SSH_MSG_USERAUTH_REQUEST 50 [SSH-USERAUTH] SSH_MSG_USERAUTH_FAILURE 51 [SSH-USERAUTH] SSH_MSG_USERAUTH_SUCCESS 52 [SSH-USERAUTH] SSH_MSG_USERAUTH_BANNER 53 [SSH-USERAUTH] SSH_MSG_GLOBAL_REQUEST 80 [SSH-CONNECT] SSH_MSG_REQUEST_SUCCESS 81 [SSH-CONNECT] SSH_MSG_REQUEST_FAILURE 82 [SSH-CONNECT] SSH_MSG_CHANNEL_OPEN 90 [SSH-CONNECT] SSH_MSG_CHANNEL_OPEN_CONFIRMATION 91 [SSH-CONNECT] SSH_MSG_CHANNEL_OPEN_FAILURE 92 [SSH-CONNECT] SSH_MSG_CHANNEL_WINDOW_ADJUST 93 [SSH-CONNECT] SSH_MSG_CHANNEL_DATA 94 [SSH-CONNECT] SSH_MSG_CHANNEL_EXTENDED_DATA 95 [SSH-CONNECT] SSH_MSG_CHANNEL_EOF 96 [SSH-CONNECT] SSH_MSG_CHANNEL_CLOSE 97 [SSH-CONNECT] SSH_MSG_CHANNEL_REQUEST 98 [SSH-CONNECT] SSH_MSG_CHANNEL_SUCCESS 99 [SSH-CONNECT] SSH_MSG_CHANNEL_FAILURE 100 [SSH-CONNECT] 4.1.3 Future Assignments Requests for assignments of new message numbers in the range of 1 to 29, 50 to 59, and 80 to 127 MUST be done through the STANDARDS ACTION method as described in [RFC2434]. The meanings of message numbers in the range of 30 to 49 are specific to the key exchange method in use, and their meaning will be specified by the definition of that method. The meanings of message numbers in the range of 60 to 79 are specific Lehtinen & Lonvick Expires September 15, 2005 [Page 8] Internet-Draft SSH Protocol Assigned Numbers March 2005 to the user authentication method in use, and their meaning will be specified by the definition of that method. Requests for assignments of new message numbers in the range of 128 to 191 MUST be done through the IETF CONSENSUS method as described in [RFC2434]. The IANA will not control the message numbers range of 192 through 255. This range will be left for PRIVATE USE. 4.2 Disconnection Messages Reason Codes and Descriptions The Disconnection Message 'reason code' is a uint32 value. The associated Disconnection Message 'description' is a human-readable message which describes the disconnect reason. 4.2.1 Conventions Protocol packets containing the SSH_MSG_DISCONNECT message MUST have Disconnection Message 'reason code' values in the range of 0x00000001 to 0xFFFFFFFF. These are described in [SSH-TRANS]. 4.2.2 Initial Assignments The following table identifies the initial assignments of the SSH_MSG_DISCONNECT 'description' and 'reason code' values. Symbolic Name reason code ------------- ----------- SSH_DISCONNECT_HOST_NOT_ALLOWED_TO_CONNECT 1 SSH_DISCONNECT_PROTOCOL_ERROR 2 SSH_DISCONNECT_KEY_EXCHANGE_FAILED 3 SSH_DISCONNECT_RESERVED 4 SSH_DISCONNECT_MAC_ERROR 5 SSH_DISCONNECT_COMPRESSION_ERROR 6 SSH_DISCONNECT_SERVICE_NOT_AVAILABLE 7 SSH_DISCONNECT_PROTOCOL_VERSION_NOT_SUPPORTED 8 SSH_DISCONNECT_HOST_KEY_NOT_VERIFIABLE 9 SSH_DISCONNECT_CONNECTION_LOST 10 SSH_DISCONNECT_BY_APPLICATION 11 SSH_DISCONNECT_TOO_MANY_CONNECTIONS 12 SSH_DISCONNECT_AUTH_CANCELLED_BY_USER 13 SSH_DISCONNECT_NO_MORE_AUTH_METHODS_AVAILABLE 14 SSH_DISCONNECT_ILLEGAL_USER_NAME 15 Lehtinen & Lonvick Expires September 15, 2005 [Page 9] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.2.3 Future Assignments Disconnection Message 'reason code' values MUST be assigned sequentially. Requests for assignments of new Disconnection Message 'reason code' values, and their associated Disconnection Message 'description' text, in the range of 0x00000010 through 0xFDFFFFFF MUST be done through the IETF CONSENSUS method as described in [RFC2434]. The IANA will not assign Disconnection Message 'reason code' values in the range of 0xFE000000 through 0xFFFFFFFF. Disconnection Message 'reason code' values in that range are left for PRIVATE USE as described in [RFC2434]. 4.3 Channel Connection Failure Reason Codes and Descriptions The Channel Connection Failure 'reason code' is a uint32 value. The associated Channel Connection Failure 'description' text is a human-readable message which describes the channel connection failure reason. This is described in [SSH-CONNECT]. 4.3.1 Conventions Protocol packets containing the SSH_MSG_CHANNEL_OPEN_FAILURE message MUST have Channel Connection Failure 'reason code' values in the range of 0x00000001 to 0xFFFFFFFF. 4.3.2 Initial Assignments The initial assignments for the 'reason code' values and 'description' values are given in the table below. Note that the values for the 'reason code' are given in decimal format for readability but that they are actually uint32 values. Symbolic Name reason code ------------- ----------- SSH_OPEN_ADMINISTRATIVELY_PROHIBITED 1 SSH_OPEN_CONNECT_FAILED 2 SSH_OPEN_UNKNOWN_CHANNEL_TYPE 3 SSH_OPEN_RESOURCE_SHORTAGE 4 4.3.3 Future Assignments Channel Connection Failure 'reason code' values MUST be assigned sequentially. Requests for assignments of new Channel Connection Failure 'reason code' values, and their associated Channel Connection Failure 'description string', in the range of 0x00000005 to 0xFDFFFFFF MUST be done through the IETF CONSENSUS method as described in [RFC2434]. The IANA will not assign Channel Connection Lehtinen & Lonvick Expires September 15, 2005 [Page 10] Internet-Draft SSH Protocol Assigned Numbers March 2005 Failure 'reason code' values in the range of 0xFE000000 to 0xFFFFFFFF. Channel Connection Failure 'reason code' values in that range are left for PRIVATE USE as described in [RFC2434]. 4.3.4 Notes about the PRIVATE USE Range While it is understood that the IANA will have no control over the range of 0xFE000000 to 0xFFFFFFFF, this range will be split in two parts and administered by the following conventions. o The range of 0xFE000000 to 0xFEFFFFFF is to be used in conjunction with locally assigned channels. For example: if a channel is proposed with a 'channel type' of "example_session@example.com" but fails, then the server will respond with either a 'reason code' assigned by the IANA (as listed above and in the range of 0x00000001 to 0xFDFFFFFF), or with a locally assigned value in the range of 0xFE000000 to 0xFEFFFFFF. Naturally, if the server does not understand the proposed 'channel type', even if it is a locally defined 'channel type', then the 'reason code' MUST be 0x00000003 as described above. If the server does understand the 'channel type' but the channel still fails to open, then the server SHOULD respond with a locally assigned 'reason code' value consistent with the proposed, local 'channel type'. It is assumed that practitioners will first attempt to use the IANA assigned 'reason code' values and then document their locally assigned 'reason code' values. o There are no restrictions or suggestions for the range starting with 0xFF. No interoperability is expected for anything used in this range. Essentially it is for experimentation. 4.4 Extended Channel Data Transfer data_type_code and Data The Extended Channel Data Transfer 'data_type_code' is an uint23 value. The associated Extended Channel Data Transfer 'data' is a human-readable message which describes the type of data allowed to be transferred in the channel. 4.4.1 Conventions Protocol packets containing the SSH_MSG_CHANNEL_EXTENDED_DATA message MUST have Extended Channel Data Transfer 'data_type_code' values in the range of 0x00000001 to 0xFFFFFFFF. This is described in [SSH-CONNECT]. 4.4.2 Initial Assignments The initial assignments for the 'data_type_code' values and 'data' Lehtinen & Lonvick Expires September 15, 2005 [Page 11] Internet-Draft SSH Protocol Assigned Numbers March 2005 values are given in the table below. Note that the value for the 'data_type_code' is given in decimal format for readability but that the values are actually uint32 values. Symbolic name data_type_code ------------- -------------- SSH_EXTENDED_DATA_STDERR 1 4.4.3 Future Assignments Extended Channel Data Transfer 'data_type_code' values MUST be assigned sequentially. Requests for assignments of new Extended Channel Data Transfer 'data_type_code' values, and their associated Extended Channel Data Transfer 'data' strings, in the range of 0x00000002 to 0xFDFFFFFF MUST be done through the IETF CONSENSUS method as described in [RFC2434]. The IANA will not assign Extended Channel Data Transfer 'data_type_code' values in the range of 0xFE000000 to 0xFFFFFFFF. Extended Channel Data Transfer 'data_type_code' values in that range are left for PRIVATE USE as described in [RFC2434]. 4.5 Pseudo-Terminal Encoded Terminal Modes SSH_MSG_CHANNEL_REQUEST messages with a "pty-req" string MUST contain "encoded terminal modes". These "encoded terminal modes" are opcode-argument pairs consisting of an opcode and an argument. 4.5.1 Conventions Protocol packets containing the SSH_MSG_CHANNEL_REQUEST message with a "pty-req" string MUST contain "encoded terminal modes" with an opcode of 1 byte. The opcode values are in the range of 1 to 255. Opcodes 1 to 159 have a single uint32 argument. Opcodes 160 to 255 are not yet defined. 4.5.2 Initial Assignments The following table identifies the initial assignments of the opcode and argument values which make up the "encoded terminal modes" values. opcode argument description ------ -------- ----------- 0 TTY_OP_END Indicates end of options. 1 VINTR Interrupt character; 255 if none. Similarly for the other characters. Not all of these characters are supported on all systems. Lehtinen & Lonvick Expires September 15, 2005 [Page 12] Internet-Draft SSH Protocol Assigned Numbers March 2005 2 VQUIT The quit character (sends SIGQUIT signal on POSIX systems). 3 VERASE Erase the character to left of the cursor. 4 VKILL Kill the current input line. 5 VEOF End-of-file character (sends EOF from the terminal). 6 VEOL End-of-line character in addition to carriage return and/or linefeed. 7 VEOL2 Additional end-of-line character. 8 VSTART Continues paused output (normally control-Q). 9 VSTOP Pauses output (normally control-S). 10 VSUSP Suspends the current program. 11 VDSUSP Another suspend character. 12 VREPRINT Reprints the current input line. 13 VWERASE Erases a word left of cursor. 14 VLNEXT Enter the next character typed literally, even if it is a special character 15 VFLUSH Character to flush output. 16 VSWTCH Switch to a different shell layer. 17 VSTATUS Prints system status line (load, command, pid, etc). 18 VDISCARD Toggles the flushing of terminal output. 30 IGNPAR The ignore parity flag. The parameter SHOULD be 0 if this flag is FALSE, and 1 if it is TRUE. 31 PARMRK Mark parity and framing errors. 32 INPCK Enable checking of parity errors. 33 ISTRIP Strip 8th bit off characters. 34 INLCR Map NL into CR on input. 35 IGNCR Ignore CR on input. 36 ICRNL Map CR to NL on input. 37 IUCLC Translate uppercase characters to lowercase. 38 IXON Enable output flow control. 39 IXANY Any char will restart after stop. 40 IXOFF Enable input flow control. 41 IMAXBEL Ring bell on input queue full. 50 ISIG Enable signals INTR, QUIT, [D]SUSP. 51 ICANON Canonicalize input lines. 52 XCASE Enable input and output of uppercase characters by preceding their lowercase equivalents with "\". 53 ECHO Enable echoing. 54 ECHOE Visually erase chars. 55 ECHOK Kill character discards current line. 56 ECHONL Echo NL even if ECHO is off. 57 NOFLSH Don't flush after interrupt. Lehtinen & Lonvick Expires September 15, 2005 [Page 13] Internet-Draft SSH Protocol Assigned Numbers March 2005 58 TOSTOP Stop background jobs from output. 59 IEXTEN Enable extensions. 60 ECHOCTL Echo control characters as ^(Char). 61 ECHOKE Visual erase for line kill. 62 PENDIN Retype pending input. 70 OPOST Enable output processing. 71 OLCUC Convert lowercase to uppercase. 72 ONLCR Map NL to CR-NL. 73 OCRNL Translate carriage return to newline (output). 74 ONOCR Translate newline to carriage return-newline (output). 75 ONLRET Newline performs a carriage return (output). 90 CS7 7 bit mode. 91 CS8 8 bit mode. 92 PARENB Parity enable. 93 PARODD Odd parity, else even. 128 TTY_OP_ISPEED Specifies the input baud rate in bits per second. 129 TTY_OP_OSPEED Specifies the output baud rate in bits per second. 4.5.3 Future Assignments Requests for assignments of new opcodes and their associated arguments MUST be done through the IETF CONSENSUS method as described in [RFC2434]. 4.6 Names In the following sections, the values for the name spaces are textual. The conventions and instructions to the IANA for future assignments are given in this section. The initial assignments are given in their respective sections. 4.6.1 Conventions for Names All names registered by the IANA in the following sections MUST be printable US-ASCII strings, and MUST NOT contain the characters at-sign ("@"), comma (","), or whitespace or control characters (ASCII codes 32 or less). Names are case-sensitive, and MUST NOT be longer than 64 characters. A provision is made here for locally extensible names. The IANA will not register, and will not control names with the at-sign in them. Lehtinen & Lonvick Expires September 15, 2005 [Page 14] Internet-Draft SSH Protocol Assigned Numbers March 2005 Names with the at-sign in them will have the format of "name@domainname" (without the double quotes) where the part preceeding the at-sign is the name. The format of the part preceding the at-sign is not specified, however these names MUST be printable US-ASCII strings, and MUST NOT contain the comma character (","), or whitespace, or control characters (ASCII codes 32 or less). The part following the at-sign MUST be a valid, fully qualified internet domain name [RFC1034] controlled by the person or organization defining the name. Names are case-sensitive, and MUST NOT be longer than 64 characters. It is up to each domain how it manages its local namespace. It has been noted that these names resemble STD 11 [RFC0822] email addresses. This is purely coincidental and actually has nothing to do with STD 11 [RFC0822]. An example of a locally defined name is "ourcipher-cbc@example.com" (without the double quotes). 4.6.2 Future Assignments of Names Requests for assignments of new Names MUST be done through the IETF CONSENSUS method as described in [RFC2434]. 4.7 Service Names The Service Name is used to describe a protocol layer. The following table lists the initial assignments of the Service Names. Service Name Reference ------------- --------- ssh-userauth [SSH-USERAUTH] ssh-connection [SSH-CONNECT] 4.8 Authentication Method Names The Authentication Method Name is used to describe an authentication method for the "ssh-userauth" service [SSH-USERAUTH]. The following table identifies the initial assignments of the Authentication Method Names. Method Name Reference ------------ --------- publickey [SSH-USERAUTH, Section 7] password [SSH-USERAUTH, Section 8] hostbased [SSH-USERAUTH, Section 9] none [SSH-USERAUTH, Section 5.2] Lehtinen & Lonvick Expires September 15, 2005 [Page 15] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.9 Connection Protocol Assigned Names The following table lists the initial assignments of the Connection Protocol Type and Request names. 4.9.1 Connection Protocol Channel Types The following table lists the initial assignments of the Connection Protocol Channel Types. Channel type Reference ------------ --------- session [SSH-CONNECT, Section 6.1] x11 [SSH-CONNECT, Section 6.3.2] forwarded-tcpip [SSH-CONNECT, Section 7.2] direct-tcpip [SSH-CONNECT, Section 7.2] 4.9.2 Connection Protocol Global Request Names The following table lists the initial assignments of the Connection Protocol Global Request Names. Request type Reference ------------ --------- tcpip-forward [SSH-CONNECT, Section 7.1] cancel-tcpip-forward [SSH-CONNECT, Section 7.1] 4.9.3 Connection Protocol Channel Request Names The following table lists the initial assignments of the Connection Protocol Channel Request Names. Request type Reference ------------ --------- pty-req [SSH-CONNECT, Section 6.2] x11-req [SSH-CONNECT, Section 6.3.1] env [SSH-CONNECT, Section 6.4] shell [SSH-CONNECT, Section 6.5] exec [SSH-CONNECT, Section 6.5] subsystem [SSH-CONNECT, Section 6.5] window-change [SSH-CONNECT, Section 6.7] xon-xoff [SSH-CONNECT, Section 6.8] signal [SSH-CONNECT, Section 6.9] exit-status [SSH-CONNECT, Section 6.10] exit-signal [SSH-CONNECT, Section 6.10] Lehtinen & Lonvick Expires September 15, 2005 [Page 16] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.9.4 Initial Assignment of Signal Names The following table lists the initial assignments of the Signal Names. Signal Reference ------ --------- ABRT [SSH-CONNECT] ALRM [SSH-CONNECT] FPE [SSH-CONNECT] HUP [SSH-CONNECT] ILL [SSH-CONNECT] INT [SSH-CONNECT] KILL [SSH-CONNECT] PIPE [SSH-CONNECT] QUIT [SSH-CONNECT] SEGV [SSH-CONNECT] TERM [SSH-CONNECT] USR1 [SSH-CONNECT] USR2 [SSH-CONNECT] 4.9.5 Connection Protocol Subsystem Names There are no initial assignments of Connection Protocol Subsystem Names. 4.10 Key Exchange Method Names The name "diffie-hellman-group1-sha1" is used for a key exchange method using an Oakley group as defined in [RFC2409]. SSH maintains its own group identifier space which is logically distinct from Oakley [RFC2412] and IKE; however, for one additional group, the Working Group adopted the number assigned by [RFC3526], using diffie-hellman-group14-sha1 for the name of the second defined group. Implementations should treat these names as opaque identifiers and should not assume any relationship between the groups used by SSH and the groups defined for IKE. The following table identifies the initial assignments of the key-exchange methods. Method name Reference ------------ --------- diffie-hellman-group1-sha1 [SSH-TRANS, Section 8.1] diffie-hellman-group14-sha1 [SSH-TRANS, Section 8.2] Lehtinen & Lonvick Expires September 15, 2005 [Page 17] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.11 Assigned Algorithm Names 4.11.1 Encryption Algorithm Names The following table identifies the initial assignment of the Encryption Algorithm Names. Encryption Algorithm Name Reference ------------------------- --------- 3des-cbc [SSH-TRANS, Section 6.3] blowfish-cbc [SSH-TRANS, Section 6.3] twofish256-cbc [SSH-TRANS, Section 6.3] twofish-cbc [SSH-TRANS, Section 6.3] twofish192-cbc [SSH-TRANS, Section 6.3] twofish128-cbc [SSH-TRANS, Section 6.3] aes256-cbc [SSH-TRANS, Section 6.3] aes192-cbc [SSH-TRANS, Section 6.3] aes128-cbc [SSH-TRANS, Section 6.3] serpent256-cbc [SSH-TRANS, Section 6.3] serpent192-cbc [SSH-TRANS, Section 6.3] serpent128-cbc [SSH-TRANS, Section 6.3] arcfour [SSH-TRANS, Section 6.3] idea-cbc [SSH-TRANS, Section 6.3] cast128-cbc [SSH-TRANS, Section 6.3] none [SSH-TRANS, Section 6.3] des-cbc [FIPS-46-3] HISTORIC; See page 4 of [FIPS 46-3] 4.11.2 MAC Algorithm Names The following table identifies the initial assignments of the MAC Algorithm Names. MAC Algorithm Name Reference ------------------ --------- hmac-sha1 [SSH-TRANS, Section 6.4] hmac-sha1-96 [SSH-TRANS, Section 6.4] hmac-md5 [SSH-TRANS, Section 6.4] hmac-md5-96 [SSH-TRANS, Section 6.4] none [SSH-TRANS, Section 6.4] Lehtinen & Lonvick Expires September 15, 2005 [Page 18] Internet-Draft SSH Protocol Assigned Numbers March 2005 4.11.3 Public Key Algorithm Names The following table identifies the initial assignments of the Public Key Algorithm names. Public Key Algorithm Name Reference ------------------------- --------- ssh-dss [SSH-TRANS, Section 6.6] ssh-rsa [SSH-TRANS, Section 6.6] spki-sign-rsa [SSH-TRANS, Section 6.6] spki-sign-dss [SSH-TRANS, Section 6.6] pgp-sign-rsa [SSH-TRANS, Section 6.6] pgp-sign-dss [SSH-TRANS, Section 6.6] 4.11.4 Compression Algorithm Names The following table identifies the initial assignments of the Compression Algorithm names. Compression Algorithm Name Reference -------------------------- --------- none [SSH-TRANS, Section 6.2] zlib [SSH-TRANS, Section 6.2] 5. Security Considerations This protocol provides a secure encrypted channel over an insecure network. Full security considerations for this protocol are provided in [SSH-ARCH]. 6. References 6.1 Normative References [SSH-ARCH] Lonvick, C., "SSH Protocol Architecture", I-D draft-ietf-secsh-architecture-22.txt, March 2005. [SSH-TRANS] Lonvick, C., "SSH Transport Layer Protocol", I-D draft-ietf-secsh-transport-24.txt, March 2005. [SSH-USERAUTH] Lonvick, C., "SSH Authentication Protocol", Lehtinen & Lonvick Expires September 15, 2005 [Page 19] Internet-Draft SSH Protocol Assigned Numbers March 2005 I-D draft-ietf-secsh-userauth-27.txt, March 2005. [SSH-CONNECT] Lonvick, C., "SSH Connection Protocol", I-D draft-ietf-secsh-connect-25.txt, March 2005. [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997. [RFC2409] Harkins, D. and D. Carrel, "The Internet Key Exchange (IKE)", RFC 2409, November 1998. [RFC2434] Narten, T. and H. Alvestrand, "Guidelines for Writing an IANA Considerations Section in RFCs", BCP 26, RFC 2434, October 1998. [RFC3526] Kivinen, T. and M. Kojo, "More Modular Exponential (MODP) Diffie-Hellman groups for Internet Key Exchange (IKE)", RFC 3526, May 2003. 6.2 Informative References [RFC0822] Crocker, D., "Standard for the format of ARPA Internet text messages", STD 11, RFC 822, August 1982. [RFC1034] Mockapetris, P., "Domain names - concepts and facilities", STD 13, RFC 1034, November 1987. [RFC2412] Orman, H., "The OAKLEY Key Determination Protocol", RFC 2412, November 1998. [FIPS-46-3] National Institute of Standards and Technology, "Data Encryption Standard (DES)", Federal Information Processing Standards Publication 46-3, October 1999. Authors' Addresses Sami Lehtinen SSH Communications Security Corp Fredrikinkatu 42 HELSINKI FIN-00100 Finland Email: sjl@ssh.com Lehtinen & Lonvick Expires September 15, 2005 [Page 20] Internet-Draft SSH Protocol Assigned Numbers March 2005 Chris Lonvick (editor) Cisco Systems, Inc. 12515 Research Blvd. Austin 78759 USA Email: clonvick@cisco.com Appendix A. Trademark Notice "ssh" is a registered trademark in the United States and/or other countries. Note to the RFC Editor: This should be a separate section like the subsequent ones, and not an appendix. This paragraph to be removed before publication. Lehtinen & Lonvick Expires September 15, 2005 [Page 21] Internet-Draft SSH Protocol Assigned Numbers March 2005 Intellectual Property Statement The IETF takes no position regarding the validity or scope of any Intellectual Property Rights 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; nor does it represent that it has made any independent effort to identify any such rights. Information on the procedures with respect to rights in RFC documents can be found in BCP 78 and BCP 79. Copies of IPR disclosures made to the IETF Secretariat 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 on-line IPR repository at http://www.ietf.org/ipr. The IETF invites any interested party to bring to its attention any copyrights, patents or patent applications, or other proprietary rights that may cover technology that may be required to implement this standard. Please address the information to the IETF at ietf-ipr@ietf.org. The IETF has been notified of intellectual property rights claimed in regard to some or all of the specification contained in this document. For more information consult the online list of claimed rights. Disclaimer of Validity This document and the information contained herein are provided on an "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET ENGINEERING TASK FORCE DISCLAIM 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. Copyright Statement Copyright (C) The Internet Society (2005). This document is subject to the rights, licenses and restrictions contained in BCP 78, and except as set forth therein, the authors retain all their rights. Lehtinen & Lonvick Expires September 15, 2005 [Page 22] Internet-Draft SSH Protocol Assigned Numbers March 2005 Acknowledgment Funding for the RFC Editor function is currently provided by the Internet Society. Lehtinen & Lonvick Expires September 15, 2005 [Page 23]