<?xml version="1.0" encoding="UTF-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.5 (Ruby 2.6.10) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

<!ENTITY RFC8615 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8615.xml">
<!ENTITY RFC2119 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml">
<!ENTITY RFC8174 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml">
<!ENTITY RFC9264 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9264.xml">
<!ENTITY RFC9110 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.9110.xml">
<!ENTITY RFC6415 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.6415.xml">
<!ENTITY RFC8288 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8288.xml">
<!ENTITY RFC7284 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.7284.xml">
<!ENTITY RFC8631 SYSTEM "https://bib.ietf.org/public/rfc/bibxml/reference.RFC.8631.xml">
]>

<?rfc tocindent="yes"?>
<?rfc strict="yes"?>
<?rfc compact="yes"?>
<?rfc comments="yes"?>
<?rfc inline="yes"?>

<rfc ipr="trust200902" docName="draft-ietf-httpapi-api-catalog-02" category="std" consensus="true" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="api-catalog well-known URI">api-catalog: a well-known URI and link relation to help discovery of APIs</title>

    <author initials="K." surname="Smith" fullname="Kevin Smith">
      <organization>Vodafone</organization>
      <address>
        <email>kevin.smith@vodafone.com</email>
        <uri>https://www.vodafone.com</uri>
      </address>
    </author>

    <date />

    <area>IETF</area>
    
    <keyword>internet-draft</keyword>

    <abstract>


<?line 78?>

<t>This document defines the "api-catalog" well-known URI and link relation. It is intended to facilitate automated discovery and usage of the APIs published by a given organisation or individual.</t>



    </abstract>

    <note title="About This Document" removeInRFC="true">
      <t>
        The latest revision of this draft can be found at <eref target="https://ietf-wg-httpapi.github.io/api-catalog/draft-ietf-httpapi-api-catalog.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        Building Blocks for HTTP APIs Working Group mailing list (<eref target="mailto:httpapi@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/httpapi/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/httpapi/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/ietf-wg-httpapi/api-catalog"/>.</t>
    </note>


  </front>

  <middle>


<?line 83?>

<section anchor="introduction"><name>Introduction</name>

<t>An organisation or individual may publish Application Programming Interfaces (APIs) to encourage requests for interaction from external parties. Such APIs must be discovered before they may be used - i.e., the external party needs to know what APIs a given publisher exposes, their purpose, any policies for usage, and the endpoint to interact with each APIs. To facilitate automated discovery of this information, and automated usage of the APIs, this document proposes:</t>

<t><list style="symbols">
  <t>a well-known URI, 'api-catalog', as a reference to the URI of an API Catalog document describing a Publisher's API endpoints.</t>
  <t>a link relation, 'api-catalog', of which the target resource is the Publisher's API Catalog document.</t>
</list></t>

<section anchor="terminology"><name>Terminology</name>

<t><list style="symbols">
  <t>'Publisher' - an organisation, company or individual that publishes one or more APIs for usage by external third parties.</t>
</list></t>

</section>
<section anchor="goals"><name>Goals and non-goals</name>

<t>The primary goal is to facilitate the automated discovery of a Publisher's public API endpoints, along with metadata that describes the purpose and usage of each API, by specifying a well-known URI <xref target="RFC8615"/> that returns an API catalog document. The API catalog document is primarily machine-readable to enable automated discovery and usage of APIs, and it may also include links to human-readable documentation.</t>

<t>Non-goals: this document does not mandate paths for API endpoints. i.e., it does not mandate that my_example_api's endpoint should be example.com/.well-known/api-catalog/my_example_api , nor even to be hosted at example.com (although it is not forbidden to do so). This document does not mandate a specific format for the API catalog document, although it does suggest some existing formats and provide a recommendation.</t>

</section>
<section anchor="requirements"><name>Requirements Language</name>

<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
"MAY", and "OPTIONAL" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>

</section>
</section>
<section anchor="usage"><name>Using the 'api-catalog' well-known URI</name>
<t>The api-catalog well-known URI is intended for HTTP(S) servers that publish APIs. As the key aim is to facilitate discovery and usage of APIs, a Publisher supporting this URI:</t>

<t><list style="symbols">
  <t>SHOULD publish the /.well-known/api-catalog URI at a predictable location. For example as companies typically own a .com TLD, a predictable location for the company 'example' would be https://www.example.com/.well-known/api-catalog</t>
  <t>SHALL resolve an HTTP(S) GET request to /.well-known/api-catalog and return an API catalog document ( as described in <xref target="API-CATALOG"/> ).</t>
  <t>SHOULD resolve an HTTP(S) HEAD request to /.well-known/api-catalog with a response including a Link header with the relation(s) defined in <xref target="LINK-RELATION"/></t>
</list></t>

<t>The location (URL) of the API Catalog document is decided by the Publisher: the./well-known/api-catalog URI provides a convenient reference to that URL.</t>

</section>
<section anchor="LINK-RELATION"><name>Link relations</name>

<t><list style="symbols">
  <t>"api-catalog": the 'api-catalog' link relation identifies a target resource that represents a list of APIs available from the Publisher of the context resource. The target resource URI may be ./well-known/api-catalog , or any other URI chosen by the Publisher. For example, the Publisher 'example.com' could include the api-catalog link relation in the HTTP header and/or content payload when responding to a request to https://example.com :</t>
</list></t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Content-Type: text/html; charset=UTF-8
Location: http\://www.example.com/
Link: </my_api_catalog.json.>; rel=api-catalog
Content-Length: 356

<!DOCTYPE HTML>
  <html>
    <head>
      <title>Welcome to Example Publisher</title>
    </head>
    <body>
      <p/><a href="my_api_catalog.json" rel="api-catalog">Example Publisher's APIs</a>.</p>
      <p>(remainder of content)</p>
    </body>
  </html>

]]></sourcecode></figure>

<t><list style="symbols">
  <t>"item" <xref target="RFC9264"/>. When used in an API Catalog document, the 'item' link relation identifies a target resource that represents an API that is a member of the API Catalog.</t>
</list></t>

</section>
<section anchor="multiple_domains"><name>Accounting for APIs distributed across multiple domains</name>

<t>A Publisher ('example') may have their APIs hosted across multiple domains that they manage: e.g., at example.com, developer.example.com, apis.example.com, apis.example.net etc. They may also use a third party API hosting provider which hosts APIs on a distinct domain.</t>

<t>To account for this scenario, it is recommended that:</t>

<t><list style="symbols">
  <t>the Publisher publish the api-catalog well-known URI at a predictable location, e.g. example.com/.well-known/api-catalog .</t>
  <t>the Publisher also publish the api-catalog well-known URI at each of their API domains e.g. apis.example.com/.well-known/api-catalog, developer.example.net/.well-known/api-catalog etc.</t>
  <t>an HTTP GET request to any of these URIs should return the same result, namely, the API Catalog document.</t>
  <t>Since the physical location (URL) of the API Catalog document is decided by the Publisher, and may change, it is RECOMMENDED that the Publisher choose one of their instances of .well-known/api-catalog as a canonical reference to the location of the latest API Catalog. The Publisher's other instances of ./well-known/api-catalog SHOULD redirect to this canonical instance of /.well-known/api-catalog , using HTTP Status Code 308 Permanent Redirect <xref target="RFC9110"/>, to ensure the latest API Catalog is returned.</t>
</list></t>

<t>As illustration, if the Publisher's primary API portal is apis.example.com, then apis.example.com/.well-known/api-catalog should resolve to the location of the latest API Catalog document. If the Publisher is also the domain authority for example.net, which also hosts a selection of their APIs, then a request to www.example.net/.well-known/api-catalog SHOULD return a redirect as follows.</t>

<t>Client request:</t>

<figure><sourcecode type="http-message"><![CDATA[
GET /.well-known/api-catalog HTTP/1.1
User-Agent: curl/7.16.3 libcurl/7.16.3 OpenSSL/0.9.7l zlib/1.2.3
Host: www.example.net
]]></sourcecode></figure>

<t>Server response:</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 308 Permanent Redirect
Content-Type: text/html; charset=UTF-8
Location: http\://apis.example.com/.well-known/api-catalog
Content-Length: 356

<!DOCTYPE HTML>
  <html>
    <head>
      <title>Permanent Redirect</title>
      <meta http-equiv="refresh" content="0; url=https://apis.example.com/.well-known/api-catalog">
    </head>
    <body>
      <p>Redirected to:  <a href=https://apis.example.com/.well-known/api-catalog>https://apis.example.com/.well-known/api-catalog</a>.</p>
    </body>
  </html>

]]></sourcecode></figure>

</section>
<section anchor="INTERNAL-USE"><name>Internal use of api-catalog for private APIs</name>

<t>A Publisher may wish to use the api-catalog well-known URI on their internal network, to signpost authorised users (e.g. company employees) towards internal/private APIs not intended for third-party use. This scenario may incur additional security considerations, as noted in <xref target="security"/></t>

</section>
<section anchor="API-CATALOG"><name>The API Catalog</name>

<t>The API Catalog is a document listing hyperlinks to a Publisher's APIs.  The Publisher may host this API Catalog document at any URI(s) they choose. Hence the API Catalog document URI of example.com/my_api_catalog.json can be requested directly, or via a request to example.com/.well-known/api-catalog, which the Publisher will resolve to example.com/my_api_catalog.</t>

<t>There is no mandated format for the API Catalog document: the Publisher is free to choose any format that supports the automated discovery, and machine (and human) usage of their APIs. However, it is RECOMMENDED to use a linkset <xref target="RFC9264"/> of API endpoints (see <xref target="api-catalog-example-linkset"/> for an example).</t>

<t>The API Catalog document MUST include hyperlinks to API endpoints, and is RECOMMENDED to include useful metadata, such as usage policies, API version information, links to the OpenAPI Specification <xref target="OAS"></xref> definitions for each API, etc. . If the Publisher does not include these metadata directly in the API Catalog document, they SHOULD make that metadata available at the API endpoint URIs they have listed (see <xref target="api-catalog-example-linkset-bookmarks"/> for an example).</t>

<t>Some suitable API Catalog document formats include:</t>

<t><list style="symbols">
  <t>(RECOMMENDED) A linkset <xref target="RFC9264"/> of API endpoints and information to facilitate API usage. The linkset SHOULD include a profile parameter (section 5 of <xref target="RFC9264"/>) with the Profile URI 'https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog' to indicate the linkset is representing an API Catalog document as defined above.</t>
  <t>An APIs.json document <xref target="APIsjson"></xref></t>
  <t>API bookmarks that represent an API entry-point URI, which may be followed to discover purpose and usage</t>
  <t>A RESTDesc semantic description for hypermedia APIs <xref target="RESTdesc"></xref></t>
  <t>A Hypertext Application Language document <xref target="HAL"></xref></t>
  <t>An extension to the Schema.org WebAPI type <xref target="WebAPIext"></xref></t>
</list></t>

<t>Appendix A includes example API Catalog documents based on the linkset format.</t>

</section>
<section anchor="CONFORM-RFC8615"><name>Conformance to RFC8615</name>

<t>The requirements in section 3 of <xref target="RFC8615"/> for defining Well-Known Uniform Resource Identifiers are met as follows:</t>

<section anchor="path-prefix"><name>Path prefix</name>

<t>The api-catalog URI SHALL be appended to the /.well-known/ path-prefix for "well-known locations".</t>

</section>
<section anchor="supported-uri-schemes"><name>Supported URI schemes</name>

<t>The api-catalog well-known URI may be used with the HTTP and HTTPS URI schemes.</t>

</section>
<section anchor="registration-of-the-api-catalog-well-known-uri"><name>Registration of the api-catalog well-known URI</name>

<t>See <xref target="IANA"/> considerations below.</t>

</section>
</section>
<section anchor="IANA"><name>IANA Considerations</name>

<section anchor="the-api-catalog-well-known-uri"><name>The api-catalog well-known URI</name>

<t>This specification registers the "api-catalog" well-known URI in the Well-Known URI Registry as defined by <xref target="RFC6415"/>.</t>

<t>URI suffix: api-catalog</t>

<t>Specification document(s):  draft-ietf-httpapi-api-catalog-02</t>

<t>Related information:  The "api-catalog" documents obtained from the same host using the HTTP and HTTPS protocols (using default ports) MUST be identical.</t>

</section>
<section anchor="the-api-catalog-link-relation"><name>The api-catalog link relation</name>

<t>This specification registers the "api-catalog" link relation by following the procedures per section 4.2.2 of <xref target="RFC8288"/></t>

<t><list style="symbols">
  <t>Relation Name:  api-catalog</t>
  <t>Description:  Identifies a catalog of APIs published by the context Publisher.</t>
  <t>Reference:  draft-ietf-httpapi-api-catalog-02</t>
</list></t>

</section>
<section anchor="the-api-catalog-profile-uri"><name>the api-catalog Profile URI</name>

<t>This specification registers "https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog" in the "Profile URIs" registry according to <xref target="RFC7284"/>.</t>

<t>o  Profile URI: https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog</t>

<t>o  Common Name: API Catalog</t>

<t>o  Description: A profile URI to request or signal a linkset representing an API Catalog.</t>

<t>o  Reference: draft-ietf-httpapi-api-catalog-02</t>

</section>
</section>
<section anchor="security"><name>Security Considerations</name>

<t>For all scenarios: the Publisher SHOULD perform a security and privacy review of the API Catalog prior to deployment, to ensure it does not leak personal, business or other metadata, nor expose any vulnerability related to the APIs listed.</t>

<t>For the internal/private APIs scenario: the Publisher SHOULD take steps to ensure that appropriate access controls are in place to ensure only authorised users access the internal api-catalog well-known URI.</t>

</section>


  </middle>

  <back>


    <references title='Normative References' anchor="sec-normative-references">

&RFC8615;
&RFC2119;
&RFC8174;
&RFC9264;
&RFC9110;
&RFC6415;
&RFC8288;
&RFC7284;


    </references>

    <references title='Informative References' anchor="sec-informative-references">

<reference anchor="OAS" target="https://spec.openapis.org/oas/latest">
  <front>
    <title>OpenAPI Specification 3.1.0</title>
    <author initials="" surname="Darrel Miller">
      <organization></organization>
    </author>
    <author initials="" surname="Jeremy Whitlock">
      <organization></organization>
    </author>
    <author initials="" surname="Marsh Gardiner">
      <organization></organization>
    </author>
    <author initials="" surname="Mike Ralphson">
      <organization></organization>
    </author>
    <author initials="" surname="Ron Ratovsky">
      <organization></organization>
    </author>
    <author initials="" surname="Uri Sarid">
      <organization></organization>
    </author>
    <date year="2021" month="February" day="15"/>
  </front>
</reference>
<reference anchor="APIsjson" target="http://apisjson.org/format/apisjson_0.16.txt">
  <front>
    <title>APIs.json</title>
    <author initials="" surname="Kin Lane">
      <organization></organization>
    </author>
    <author initials="" surname="Steve Willmott">
      <organization></organization>
    </author>
    <date year="2020" month="September" day="15"/>
  </front>
</reference>
<reference anchor="HAL" target="https://datatracker.ietf.org/doc/html/draft-kelly-json-hal-11">
  <front>
    <title>JSON Hypertext Application Language</title>
    <author initials="" surname="Mike Kelly">
      <organization></organization>
    </author>
    <date year="2020" month="September" day="15"/>
  </front>
</reference>
<reference anchor="RESTdesc" target="http://apisjson.org/format/apisjson_0.16.txt">
  <front>
    <title>RESTdesc</title>
    <author initials="" surname="Ruben Verborgh">
      <organization></organization>
    </author>
    <author initials="" surname="Erik Mannens">
      <organization></organization>
    </author>
    <author initials="" surname="Rick Van de Walle">
      <organization></organization>
    </author>
    <author initials="" surname="Thomas Steiner">
      <organization></organization>
    </author>
    <date year="2023" month="September" day="15"/>
  </front>
</reference>
<reference anchor="WebAPIext" target="https://webapi-discovery.github.io/rfcs/rfc0001.html">
  <front>
    <title>WebAPI type extension</title>
    <author initials="" surname="Mike Ralphson">
      <organization></organization>
    </author>
    <author initials="" surname="Nick Evans">
      <organization></organization>
    </author>
    <date year="2020" month="July" day="08"/>
  </front>
</reference>
&RFC8631;


    </references>


<?line 266?>

<section anchor="api-catalog-example-linkset"><name>Example API Catalog document</name>

<t>This section is informative, and provides and example of an API Catalog document using the RECOMMENDED linkset format.</t>

<section anchor="using-linkset-with-rfc8615-relations"><name>Using Linkset with RFC8615 relations</name>

<t>This example uses the linkset format <xref target="RFC9264"/>, and the following link relations defined in <xref target="RFC8631"/>:</t>

<t><list style="symbols">
  <t>"service-desc", used to link to a description of the API that is primarily intended for machine consumption.</t>
  <t>"service-doc", used to link to API documentation that is primarily intended for human consumption.</t>
  <t>"service-meta", used to link to additional metadata about the API, and is primarily intended for machine consumption.</t>
  <t>"status", used to link to the API status (e.g. API "health" indication etc.) for machine and/or human consumption.</t>
</list></t>

<t>Client request:</t>

<figure><sourcecode type="http-message"><![CDATA[
GET .well-know/api-catalog HTTP/1.1
Host: example.com
Accept: application/linkset+json
]]></sourcecode></figure>

<t>Server response:</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Date: Mon, 01 Jun 2023 00:00:01 GMT
Server: Apache-Coyote/1.1
Content-Type: application/linkset+json;
    profile="https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog"
]]></sourcecode></figure>

<figure><artwork><![CDATA[
{
  "linkset": [
  {
    "anchor": "https://developer.example.com/apis/foo_api",
    "service-desc": [
      {
        "href": "https://developer.example.com/apis/foo_api/spec",
        "type": "application/yaml"
      }
    ],
    "status": [
      {
        "href": "https://developer.example.com/apis/foo_api/status",
        "type": "application/json"
      }
    ],
    "service-doc": [
      {
        "href": "https://developer.example.com/apis/foo_api/doc",
        "type": "text/html"
      }
    ],
    "service-meta": [
      {
        "href": "https://developer.example.com/apis/foo_api/policies",
        "type": "text/xml"
      }
    ]
  },
  {
    "anchor": "https://developer.example.com/apis/bar_api",
    "service-desc": [
      {
        "href": "https://developer.example.com/apis/bar_api/spec",
        "type": "application/yaml"
      }
    ],
    "status": [
      {
        "href": "https://developer.example.com/apis/bar_api/status",
       "type": "application/json"
      }
    ],
    "service-doc": [
      {
        "href": "https://developer.example.com/apis/bar_api/doc",
        "type": "text/plain"
      }
    ]
  },
  {
    "anchor": "https://apis.example.net/apis/cantona_api",
    "service-desc": [
      {
        "href": "https://apis.example.net/apis/cantona_api/spec",
        "type": "text/n3"
      }
    ],
    "service-doc": [
      {
        "href": "https://apis.example.net/apis/cantona_api/doc",
        "type": "text/html"
      }
    ]
  }
  ]
}
]]></artwork></figure>

</section>
<section anchor="api-catalog-example-linkset-bookmarks"><name>Using Linkset with bookmarks</name>

<t>This example also uses the linkset format <xref target="RFC9264"/>, listing the API endpoints in an array of bookmarks. Each link shares the same context (the API Catalog) and "item" <xref target="RFC9264"/> link relation (to indicate they are an item in the catalog).The intent is that by following a bookmark link, a machine-client can discover the purpose and usage of each API, hence the document targeted by the bookmark link should support this.</t>

<t>Note in the example below, the context anchor is example/com/.well-known/api-catalog, however as explained above the  context anchor may be any other URI at which the api-catalog is available.</t>

<t>Client request:</t>

<figure><sourcecode type="http-message"><![CDATA[
GET .well-know/api-catalog HTTP/1.1
Host: example.com
Accept: application/linkset+json
]]></sourcecode></figure>

<t>Server response:</t>

<figure><sourcecode type="http-message"><![CDATA[
HTTP/1.1 200 OK
Date: Mon, 01 Jun 2023 00:00:01 GMT
Server: Apache-Coyote/1.1
Content-Type: application/linkset+json;
    profile="https://datatracker.ietf.org/doc/draft-ietf-httpapi-api-catalog"
]]></sourcecode></figure>

<figure><artwork><![CDATA[
[
  { "anchor": "https://example.com/.well-known/api-catalog",
    "item": [
      {"href": "https://developer.example.com/apis/foo_api"},
      {"href": "https://developer.example.com/apis/bar_api"}
      {"href": "https://developer.example.com/apis/cantona_api"}
    ]
  }
]
]]></artwork></figure>

</section>
</section>
<section anchor="acknowledgements"><name>Acknowledgements</name>

<t>Thanks to Phil Archer, Ben Bucksch, Sanjay Dalal, Max Maton, Darrel Miller, Mark Nottingham,  Roberto Polli, Rich Salz, Herbert Van De Sompel and Erik Wilde for their suggestions and feedback.</t>

</section>


  </back>

<!-- ##markdown-source:
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
NFZqRFWHtvcvFxeS3DxEAAA=

-->

</rfc>

