Network Working Group James E. White (JEW) Request for Comments: 479 SRI-ARC NIC: 14948 March 8, 1973 Use of FTP by the NIC Journal At the Network Mail Meeting (see -- 14317,) the NIC outlined it's requirements for implementing FTP Journal delivery and submission. It had always been our thinking that those two services should rely upon the File Transfer Protocol's MLFL command for their implementation. Prior to the meeting, we had envisioned that, in the case of submission, for example, the user would embed what parameters the NIC required (e.g., an indication that this piece of mail was to be journalized, a list of NIC idents, etc.) in the USERNAME field of the MLFL command, in a way that was transparent to his FTP user process, and that SRI-ARC's FTP server process would parse the 'user name' for the parameters and internally invoke the Journal System with them and the text of the mail as arguments. Our goal (which this scheme would have satisfied) was to provide the desired services while confining software changes to our own system and, in particular, to avoid requiring that user FTP processes or the File Transfer Protocol itself be modified. It was, however, the consensus of those present at the meeting that it was preferable to modify FTP in such a way that all required parameters could be explicitly declared, rather than require that they be hidden within what purported to be simply a user name. The intent of this RFC is to list what we (the NIC) believe were the new FTP commands it was agreed should be defined in support of mail submission and delivery. Actually, we've done some massaging after thinking about the issues for awhile, and so this is really a description of what we'd like to see included in the File Transfer Protocol (following the lines of thought which developed at the meeting), along with a short description of how the NIC would use them. Some of the commands currently make sense only if issued TO the NIC's FTP server process (as opposed to anybody else's) and others only if issued BY the NIC's FTP user process (as opposed to anybody else's). This is true because currently only the NIC plans to offer mail White [Page 1] RFC 479 Use of FTP by the NIC Journal March 1973 forwarding and recording (i.e., the Journal System) as a service. However, other hosts may in the future desire to implement a similar service, at which time these special commands will have wider use. Conceptually, all of these commands are sub-commands of a new MAIL command, but the intent for the moment is not to define their position within the FTP dialogue nor their syntax, but simply to describe them conceptually. Details of syntax and use are left to the FTP Interest Group which meets 16-MAR-73 in Boston (see -- 14333,). The new sub-commands are described below. Bracketed fields are optional; slash denotes a choice of two or more alternatives. (1) TITLE title Where 'title' is a character string describing for the human reader the contents of the mail. (2) USER-READABLE-AUTHOR author Where 'author' identifies the author of the mail to the human reader. This may be a nickname, or any other identifier with which the human sender chooses to sign his mail. (3) PROCESS-READABLE-AUTHOR last, first initial (ident) Where the author's name (and ident if known) is made available to the server in a form it can hope to parse (if need be). This sub-command is important to the NIC, providing a basis for locating the author in the NIC's Ident files. (4) FOR-ACKNOWLEDGMENT-AUTHOR username hostname Where 'username' and 'hostname' define the sender in a way useful in acknowledging delivery (of forwarded mail). The acknowledgment will itself be a piece of mail sent from the NIC to 'username' at 'hostname'. It's important, conceptually, to note the NIC's unique role here. Normally, acceptance of the mail by the server would constitute acknowledgment of delivery. But, in the case of Journal submission, the NIC acts only as a forwarding agent, and hence delivery of mail by the sender to SRI-ARC isn't White [Page 2] RFC 479 Use of FTP by the NIC Journal March 1973 really delivery at all -- only submission. Final delivery occurs when the NIC transmits a copy of the mail to each of its addressees; hence the need for this special kind of acknowledgment. Note that this sub-command and the previous two constitute different renderings of the sender's name. (5) ACKNOWLEDGMENT-DETAILS DEFAULT / (COMPLETION / FAILURE / PERIODIC interval GIVEUP time TERSE / VERBOSE) The value of the first parameter (ignoring 'DEFAULT' for the moment) determines the conditions under which acknowledgment will be made to the sender: -- upon completion, whether delivery was successful or timed out for one or more addressees, -- only if delivery failed for one or more addressees, or -- periodically until delivery is complete. The value of the second parameter determines the time after which delivery attempts will be discontinued. The value of the third parameter determines how detailed -- in some as yet unspecified sense -- an acknowledgment will be returned. A verbose acknowledgment might, in the case of delivery failure, include a copy of the text of the message, or, for mail sent by citation (see item 10 below), a pointer to it. If DEFAULT is specified (in which case, FOR-ACKNOWLEDGMENT- AUTHOR should not be specified, and 'DEFAULT' applies to it, too), the NIC will extract a set of default values from its Ident files, provided that a PROCESS-READABLE-AUTHOR subcommand is present and the sender's NIC Ident can be inferred from it; otherwise, the NIC will apply a set of (as yet unspecified) system defaults. The NIC's Ident files will be modified to contain, for each user known to it, the kind of acknowledgment the user usually wants (i.e., his default) and the username and hostname that define the destination for such acknowledgments. These last two pieces of information will White [Page 3] RFC 479 Use of FTP by the NIC Journal March 1973 also be used in delivering mail to the user if he has requested Network delivery (as opposed to Online (at the NIC) or hardcopy). (6) ADDRESSEES-ARE name1, name2, ... This sub-command identifies the recipient(s) of the mail. In general, 'namei' will be the name by which the recipient is known locally in the server's system. The NIC's server FTP process will permit 'namei' to be any of the following: -- a NIC Ident (designating either an individual or a group), -- username hostname, where 'username' is the name by which the addressee is known at host 'hostname', or -- lastname, firstname initial , which the NIC will attempt to parse and then locate in its Ident files. Note that now the possibility of multiple addressees is explicitly admitted by the Protocol, but the meaning of 'useri' (to the server) is left server-dependent. (7) MAIL-CLASS BULK/POSTCARD SPECIAL-DELIVERY/FIRST-CLASS The first parameter makes a statement about the size of the mail, and the server may choose to use it to decide how and where to store he mail for the addressee. The second parameter makes a statement about the importance of the mail, and the server may choose to expedite delivery (e.g., interrupt the user if he's logged in) for SPECIAL-DELIVERY mail. (8) RECORD [identifier] [miscellaneous] This is the command to the server to record the mail. 'Identifier' allows the sender the option of specifying a pre- assigned identifier if he has one; if this field is not present, the server assigns one. 'Miscellaneous' includes any server-dependent parameters which the server may require or allow. White [Page 4] RFC 479 Use of FTP by the NIC Journal March 1973 When this command is issued to the NIC, it will be taken as a command to Journalize the mail, and 'identifier' may be: NIC number [RFC number] The NIC may allow 'miscellaneous' to contain such information as comments, keywords, etc. (9) PRESERVED-AT hostname AS identifier This is not a command but a statement of fact which the FTP server will presumably relay to the user as it does the information contained in (for example) the TITLE command. The implication is that a copy of this piece of mail has been preserved at 'hostname' and is retrievable -- on a long-term basis -- with 'identifier'. 'Identifier' might, in general, be a pathname. When the NIC delivers Journal articles through the Net, it will include this sub-command, and 'identifier' will be a NIC number, and 'hostname' of course 'SRI-ARC' or 'NIC'. (10) TEXT text FILE pathname hostname One of these two sub-commands is used to actually transmit the mail: the first transmits the text of the mail, the second a pointer to it (leaving open to the FTP server (or his user) the option of retrieving the text of the mail from the specified host). The NIC will transmit mail created within NLS with 'Submit File' using the FILE command, and mail created with 'Submit Message' using the TEXT command. For mail entering the SRI- ARC system via its FTP server process, the NIC will employ the same command in delivery as was used in submission. [ This RFC was put into machine readable form for entry ] [ into the online RFC archives by Hannes Faestermann 12/97 ] White [Page 5]