| TOC | 
| 
 | 
This Internet-Draft is submitted to IETF in full conformance with the provisions of BCP 78 and BCP 79. This document may contain material from IETF Documents or IETF Contributions published or made publicly available before November 10, 2008. The person(s) controlling the copyright in some of this material may not have granted the IETF Trust the right to allow modifications of such material outside the IETF Standards Process. Without obtaining an adequate license from the person(s) controlling the copyright in such materials, this document may not be modified outside the IETF Standards Process, and derivative works of it may not be created outside the IETF Standards Process, except to format it for publication as an RFC or to translate it into languages other than English.
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 March 23, 2010.
Copyright (c) 2009 IETF Trust and the persons identified as the document authors. All rights reserved.
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents in effect on the date of publication of this document (http://trustee.ietf.org/license-info). Please review these documents carefully, as they describe your rights and restrictions with respect to this document.
This document specifies MetaLinkHeader: Mirrors and Checksums in HTTP Headers, an alternative to the Metalink XML-based download description format. MetaLinkHeader describes multiple download locations (mirrors), Peer-to-Peer, checksums, digital signatures, and other information using existing standards. Clients can transparently use this information to make file transfers more robust and reliable.
1. 
Introduction
    1.1. 
Examples
    1.2. 
Notational Conventions
2. 
Requirements
3. 
Mirrors / Multiple Download Locations
4. 
Peer-to-Peer Descriptions / Metainfo
5. 
OpenPGP Signatures
6. 
Checksums
    6.1. 
Checksums of Whole Files
    6.2. 
Checksums of Chunks of Files
7. 
Client / Server Multi-source Download Interaction
8. 
Link Relation Type Registration: "duplicate"
9. 
Security Considerations
    9.1. 
URIs and IRIs
    9.2. 
Spoofing
    9.3. 
Cryptographic Hashes
    9.4. 
Signing
10. 
References
    10.1. 
Normative References
    10.2. 
Informative References
Appendix A. 
Acknowledgements and Contributors
Appendix B. 
Comparisons to Similar Options (to be removed by RFC Editor before publication)
Appendix C. 
Document History (to be removed by RFC Editor before publication)
§ 
Authors' Addresses
| TOC | 
MetaLinkHeader is an alternative to Metalink, usually an XML-based document format [draft‑bryan‑metalink] (Bryan, A., Ed., Tsujikawa, T., McNab, N., and P. Poeml, “The Metalink Download Description Format,” August 2009.). MetaLinkHeader attempts to provide as much functionality as the Metalink XML format by using existing standards such as Web Linking [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.), Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.), and Content-MD5 [RFC1864] (Myers, J. and M. Rose, “The Content-MD5 Header Field,” October 1995.). MetaLinkHeader is used to list information about a file to be downloaded. This includes lists of multiple URIs (mirrors), Peer-to-Peer information, checksums, and digital signatures.
Identical copies of a file are frequently accessible in multiple locations on the Internet over a variety of protocols (FTP, HTTP, and Peer-to-Peer). In some cases, Users are shown a list of these multiple download locations (mirrors) and must manually select a single one on the basis of geographical location, priority, or bandwidth. This distributes the load across multiple servers. At times, individual servers can be slow, outdated, or unreachable, but this can not be determined until the download has been initiated. This can lead to the user canceling the download and needing to restart it. During downloads, errors in transmission can corrupt the file. There are no easy ways to repair these files. For large downloads this can be extremely troublesome. Any of the number of problems that can occur during a download lead to frustration on the part of users.
All the information about a download, including mirrors, checksums, digital signatures, and more can be transferred in coordinated HTTP Headers. This Metalink transfers the knowledge of the download server (and mirror database) to the client. Clients can fallback to other mirrors if the current one has an issue. With this knowledge, the client is enabled to work its way to a successful download even under adverse circumstances. All this is done transparently to the user and the download is much more reliable and efficient. In contrast, a traditional HTTP redirect to a mirror conveys only extremely minimal information - one link to one server, and there is no provision in the HTTP protocol to handle failures. Other features that some clients provide include multi-source downloads, where chunks of a file are downloaded from multiple mirrors (and optionally, Peer-to-Peer) simultaneously, which frequently results in a faster download.
[[ Discussion of this draft should take place on IETF HTTP WG mailing list at ietf-http-wg@w3.org or the Metalink discussion mailing list located at metalink-discussion@googlegroups.com. To join the list, visit http://groups.google.com/group/metalink-discussion . ]]
| TOC | 
A brief Metalink server response with checksum, mirrors, .metalink, and OpenPGP signature:
Link: <http://www2.example.com/example.ext>; rel="duplicate"; Link: <ftp://ftp.example.com/example.ext>; rel="duplicate"; Link: <http://example.com/example.ext.metalink>; rel="describedby"; type="application/metalink4+xml"; Link: <http://example.com/example.ext.asc>; rel="describedby"; type="application/pgp-signature"; Digest: SHA=thvDyvhfIqlvFe+A9MYgxAfm1q5=
| TOC | 
This specification describes conformance of MetaLinkHeader.
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 BCP 14, [RFC2119] (Bradner, S., “Key words for use in RFCs to Indicate Requirement Levels,” March 1997.), as scoped to those conformance targets.
| TOC | 
In this context, "MetaLink" refers to a MetaLinkHeader which consists of mirrors and checksums in HTTP Headers as described in this document. "Metalink XML" refers to the XML format described in [draft‑bryan‑metalink] (Bryan, A., Ed., Tsujikawa, T., McNab, N., and P. Poeml, “The Metalink Download Description Format,” August 2009.).
Metalink servers are HTTP servers that MUST have lists of mirrors and use the Link header [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.) to indicate them. They also MUST provide checksums of files via Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.). Mirror and checksum information provided by the originating Metalink server MUST be considered authoritative. Metalink servers and their associated mirror servers SHOULD all share the same ETag policy, i.e. base it on the file contents (checksum) and not server-unique filesystem metadata. The emitted ETag may be implemented the same as the Instance Digest for simplicity.
Mirror servers are typically FTP or HTTP servers that "mirror" another server. That is, they provide identical copies of (at least some) files that are also on the mirrored server. Mirror servers MAY be Metalink servers. Mirror servers MUST support serving partial content. Mirror servers SHOULD support Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.).
Metalink clients use the mirrors provided by a Metalink server with Link header [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.). Metalink clients MUST support HTTP and MAY support FTP, BitTorrent, or other download methods. Metalink clients MUST switch downloads from one mirror to another if the one mirror becomes unreachable. Metalink clients are RECOMMENDED to support multi-source, or parallel, downloads, where chunks of a file are downloaded from multiple mirrors simultaneously (and optionally, from Peer-to-Peer sources). Metalink clients MUST support Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.) by requesting and verifying checksums. Metalink clients MAY make use of digital signatures if they are offered.
| TOC | 
Mirrors are specified with the Link header [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.) and a relation type of "duplicate" as defined in Section 8 (Link Relation Type Registration: "duplicate").
A brief Metalink server response with two mirrors only:
Link: <http://www2.example.com/example.ext>; rel="duplicate"; Link: <ftp://ftp.example.com/example.ext>; rel="duplicate";
Mirror servers are listed in order of priority.
[[Some organizations have many mirrors. Only send a few mirrors, or only use the Link header if Want-Digest is used?]]
| TOC | 
Ways to download a file over Peer-to-Peer networks are specified with the Link header [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.) and a relation type of "describedby" and a type parameter hat indicates the MIME type of the metadata available at the IRI.
A brief Metalink server response with .metalink only:
Link: <http://example.com/example.ext.metalink>; rel="describedby"; type="application/metalink4+xml";
| TOC | 
OpenPGP signatures are specified with the Link header [draft‑nottingham‑http‑link‑header] (Nottingham, M., “Web Linking,” July 2009.) and a relation type of "describedby" and a type parameter of "application/pgp-signature".
A brief Metalink server response with OpenPGP signature only:
Link: <http://example.com/example.ext.asc>; rel="describedby"; type="application/pgp-signature";
| TOC | 
| TOC | 
Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.) are used to request and retrieve whole file checksums.
A brief Metalink client request that prefers SHA-1 checksums over MD5:
Want-Digest: MD5;q=0.3, SHA;q=0.8
A brief Metalink server response with checksum:
Digest: SHA=thvDyvhfIqlvFe+A9MYgxAfm1q5=
| TOC | 
The Content-MD5 header [RFC1864] (Myers, J. and M. Rose, “The Content-MD5 Header Field,” October 1995.) provides checksums for a chunk, or portion, of a file, when requested with a Range header field.
Negotiation of Content-MD5 is described in [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.). A checksum for a chunk of a file can determine if there has been an error in transmission, which means the file is corrupt. If an error is detected in a chunk, then just that chunk can be requested again from the current mirror, or a different mirror.
A brief Metalink client request for Content-MD5 of a portion of a file:
Range: bytes=7433802- Want-Digest: contentMD5;q=0.8
A brief Metalink server response with checksum:
HTTP/1.1 206 Partial Content Accept-Ranges: bytes Content-Length: 7433801 Content-Range: bytes 7433802-14867602/14867603 Content-MD5: Q2hlY2sgSW50ZWdyaXR5IQ==
[[Content-MD5 for chunk checksums could lead to many random size chunk checksum requests. Use consistent chunk sizes? Could we get all chunk checksums from the referring Metalink server with Content-MD5? Otherwise, this could also be a lot to ask on a mirror network if you don't control it and most servers might not have this feature enabled.]]
| TOC | 
Metalink clients begin a download with a standard HTTP [RFC2616] (Fielding, R., Gettys, J., Mogul, J., Frystyk, H., Masinter, L., Leach, P., and T. Berners-Lee, “Hypertext Transfer Protocol -- HTTP/1.1,” June 1999.) GET request to the Metalink server. Here the client prefers SHA-1 checksums over MD5:
GET /distribution/example.ext HTTP/1.1 Host: www.example.com Want-Digest: MD5;q=0.3, SHA;q=0.8
Alternatively, Metalink clients can use a HEAD request to discover mirrors via Link headers. After that, it follows with a GET request as usual.
The Metalink server responds with this:
HTTP/1.1 200 OK Accept-Ranges: bytes Content-Length: 14867603 Content-Type: application/x-cd-image Link: <http://www2.example.com/example.ext>; rel="duplicate"; Link: <ftp://ftp.example.com/example.ext>; rel="duplicate"; Link: <http://example.com/example.ext.metalink>; rel="describedby"; type="application/metalink4+xml"; Link: <http://example.com/example.ext.asc>; rel="describedby"; type="application/pgp-signature"; Digest: SHA=thvDyvhfIqlvFe+A9MYgxAfm1q5=
The Metalink client then contacts the other mirrors requesting a portion of the file with the "Range" header field, and using the location of the original GET request in the "Referer" header field. One of the client requests to a mirror server:
GET /example.ext HTTP/1.1 Host: www2.example.com Range: bytes=7433802- Referer: http://www.example.com/distribution/example.ext
The mirror servers respond with a 206 Partial Content HTTP status code and appropriate "Content-Length" and "Content Range" header fields. The mirror response to the above request:
HTTP/1.1 206 Partial Content Accept-Ranges: bytes Content-Length: 7433801 Content-Range: bytes 7433802-14867602/14867603
Once the download has completed, the Metalink client MUST verify the checksum of the file.
| TOC | 
o Relation Name: duplicate
o Description: Refers to a resource whose available representations are byte-for-byte identical with the corresponding representations of the context IRI.
o Reference: This specification.
o Notes: This relation is for static resources. That is, an HTTP GET request on any duplicate will return the same representation. It does not make sense for dynamic or POSTable resources and should not be used for them.
| TOC | 
| TOC | 
Metalink clients handle URIs and IRIs. See Section 7 of [RFC3986] (Berners-Lee, T., Fielding, R., and L. Masinter, “Uniform Resource Identifier (URI): Generic Syntax,” January 2005.) and Section 8 of [RFC3987] (Duerst, M. and M. Suignard, “Internationalized Resource Identifiers (IRIs),” January 2005.) for security considerations related to their handling and use.
| TOC | 
There is potential for spoofing attacks where the attacker publishes Metalinks with false information. In that case, this could deceive unaware downloaders that they are downloading a malicious or worthless file. Also, malicious publishers could attempt a distributed denial of service attack by inserting unrelated IRIs into Metalinks.
| TOC | 
Currently, some of the hash types defined in Instance Digests in HTTP [RFC3230] (Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” January 2002.) and Content-MD5 header [RFC1864] (Myers, J. and M. Rose, “The Content-MD5 Header Field,” October 1995.) are considered insecure. These include the whole Message Digest family of algorithms which are not suitable for cryptographically strong verification. Malicious people could provide files that appear to be identical to another file because of a collision, i.e. the weak cryptographic hashes of the intended file and a substituted malicious file could match.
If a Metalink contains hashes as described in Section 6 (Checksums), it SHOULD include "sha" which is SHA-1, as specified in [RFC3174] (Eastlake, D. and P. Jones, “US Secure Hash Algorithm 1 (SHA1),” September 2001.). It MAY also include other hashes.
| TOC | 
Metalinks should include digital signatures, as described in Section 5 (OpenPGP Signatures).
Digital signatures provide authentication, message integrity, and non-repudiation with proof of origin.
| TOC | 
| TOC | 
| [RFC1864] | Myers, J. and M. Rose, “The Content-MD5 Header Field,” RFC 1864, October 1995. | 
| [RFC2119] | Bradner, S., “Key words for use in RFCs to Indicate Requirement Levels,” BCP 14, RFC 2119, March 1997. | 
| [RFC2616] | Fielding, R., Gettys, J., Mogul, J., Frystyk, H., Masinter, L., Leach, P., and T. Berners-Lee, “Hypertext Transfer Protocol -- HTTP/1.1,” RFC 2616, June 1999. | 
| [RFC3174] | Eastlake, D. and P. Jones, “US Secure Hash Algorithm 1 (SHA1),” RFC 3174, September 2001. | 
| [RFC3230] | Mogul, J. and A. Van Hoff, “Instance Digests in HTTP,” RFC 3230, January 2002. | 
| [RFC3986] | Berners-Lee, T., Fielding, R., and L. Masinter, “Uniform Resource Identifier (URI): Generic Syntax,” STD 66, RFC 3986, January 2005. | 
| [RFC3987] | Duerst, M. and M. Suignard, “Internationalized Resource Identifiers (IRIs),” RFC 3987, January 2005. | 
| [draft-nottingham-http-link-header] | Nottingham, M., “Web Linking,” draft-nottingham-http-link-header-06 (work in progress), July 2009. | 
| TOC | 
| [draft-bryan-metalink] | Bryan, A., Ed., Tsujikawa, T., McNab, N., and P. Poeml, “The Metalink Download Description Format,” draft-bryan-metalink-16 (work in progress), August 2009. | 
| TOC | 
Thanks to Mark Nottingham, Daniel Stenberg and Henrik Nordstrom.
| TOC | 
...or missing, compared to the Metalink XML format [draft‑bryan‑metalink] (Bryan, A., Ed., Tsujikawa, T., McNab, N., and P. Poeml, “The Metalink Download Description Format,” August 2009.) :
...or missing, draft-ford-http-multi-server compared to this draft :
| TOC | 
[[ to be removed by the RFC editor before publication as an RFC. ]]
Known issues concerning this draft:
-05 : September , 2009.
-04 : September 17, 2009.
-03 : September 16, 2009.
-02 : September 6, 2009.
-01 : September 1, 2009.
-00 : August 24, 2009.
| TOC | 
| Anthony Bryan (editor) | |
| Metalinker Project | |
| Email: | anthonybryan@gmail.com | 
| URI: | http://www.metalinker.org | 
| Neil McNab | |
| Metalinker Project | |
| Email: | nabber00@gmail.com | 
| URI: | http://www.nabber.org |