<?xml version='1.0' encoding='utf-8'?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" version="3" category="info" docName="draft-dold-payto-14" indexInclude="true" ipr="trust200902" number="8905" prepTime="2020-10-24T13:38:23" scripts="Common,Latin" sortRefs="true" submissionType="independent" symRefs="true" tocDepth="3" tocInclude="true" xml:lang="en">
  <link href="https://datatracker.ietf.org/doc/draft-dold-payto-14" rel="prev"/>
  <link href="https://dx.doi.org/10.17487/rfc8905" rel="alternate"/>
  <link href="urn:issn:2070-1721" rel="alternate"/>
  <front>
    <title abbrev="The 'payto' URI Scheme">The 'payto' URI Scheme for Payments</title>
    <seriesInfo name="RFC" value="8905" stream="independent"/>
    <author fullname="Florian Dold" initials="F." surname="Dold">
      <organization showOnFrontPage="true">Taler Systems SA</organization>
      <address>
        <postal>
          <street>7, rue de Mondorf</street>
          <city>Erpeldange</city>
          <code>5421</code>
          <country>Luxembourg</country>
        </postal>
        <email>dold@taler.net</email>
      </address>
    </author>
    <author fullname="Christian Grothoff" initials="C." surname="Grothoff">
      <organization showOnFrontPage="true">Bern University of Applied Sciences</organization>
      <address>
        <postal>
          <street>Quellgasse 21</street>
          <street/>
          <city>Biel/Bienne</city>
          <code>2501</code>
          <country>Switzerland</country>
        </postal>
        <email>christian.grothoff@bfh.ch</email>
      </address>
    </author>
    <date month="10" year="2020"/>
    <area>General</area>
    <workgroup>Independent Stream</workgroup>
    <keyword>payments</keyword>
    <abstract pn="section-abstract">
      <t indent="0" pn="section-abstract-1">This document defines the 'payto' Uniform Resource Identifier (URI)
      scheme for designating targets for payments.</t>
      <t indent="0" pn="section-abstract-2">A unified URI scheme for all payment target types allows applications
      to offer user interactions with URIs that represent payment targets,
      simplifying the introduction of new payment systems and
      applications.</t>
    </abstract>
    <boilerplate>
      <section anchor="status-of-memo" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.1">
        <name slugifiedName="name-status-of-this-memo">Status of This Memo</name>
        <t indent="0" pn="section-boilerplate.1-1">
            This document is not an Internet Standards Track specification; it is
            published for informational purposes.
        </t>
        <t indent="0" pn="section-boilerplate.1-2">
            This is a contribution to the RFC Series, independently of any
            other RFC stream.  The RFC Editor has chosen to publish this
            document at its discretion and makes no statement about its value
            for implementation or deployment.  Documents approved for
            publication by the RFC Editor are not candidates for any level of
            Internet Standard; see Section 2 of RFC 7841.
        </t>
        <t indent="0" pn="section-boilerplate.1-3">
            Information about the current status of this document, any
            errata, and how to provide feedback on it may be obtained at
            <eref target="https://www.rfc-editor.org/info/rfc8905" brackets="none"/>.
        </t>
      </section>
      <section anchor="copyright" numbered="false" removeInRFC="false" toc="exclude" pn="section-boilerplate.2">
        <name slugifiedName="name-copyright-notice">Copyright Notice</name>
        <t indent="0" pn="section-boilerplate.2-1">
            Copyright (c) 2020 IETF Trust and the persons identified as the
            document authors. All rights reserved.
        </t>
        <t indent="0" pn="section-boilerplate.2-2">
            This document is subject to BCP 78 and the IETF Trust's Legal
            Provisions Relating to IETF Documents
            (<eref target="https://trustee.ietf.org/license-info" brackets="none"/>) in effect on the date of
            publication of this document. Please review these documents
            carefully, as they describe your rights and restrictions with
            respect to this document.
        </t>
      </section>
    </boilerplate>
    <toc>
      <section anchor="toc" numbered="false" removeInRFC="false" toc="exclude" pn="section-toc.1">
        <name slugifiedName="name-table-of-contents">Table of Contents</name>
        <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1">
          <li pn="section-toc.1-1.1">
            <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.1"><xref derivedContent="1" format="counter" sectionFormat="of" target="section-1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-introduction">Introduction</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.1.2">
              <li pn="section-toc.1-1.1.2.1">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.1.1"><xref derivedContent="1.1" format="counter" sectionFormat="of" target="section-1.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-objective">Objective</xref></t>
              </li>
              <li pn="section-toc.1-1.1.2.2">
                <t indent="0" keepWithNext="true" pn="section-toc.1-1.1.2.2.1"><xref derivedContent="1.2" format="counter" sectionFormat="of" target="section-1.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-requirements-language">Requirements Language</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.2">
            <t indent="0" pn="section-toc.1-1.2.1"><xref derivedContent="2" format="counter" sectionFormat="of" target="section-2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-syntax-of-a-payto-uri">Syntax of a 'payto' URI</xref></t>
          </li>
          <li pn="section-toc.1-1.3">
            <t indent="0" pn="section-toc.1-1.3.1"><xref derivedContent="3" format="counter" sectionFormat="of" target="section-3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-semantics">Semantics</xref></t>
          </li>
          <li pn="section-toc.1-1.4">
            <t indent="0" pn="section-toc.1-1.4.1"><xref derivedContent="4" format="counter" sectionFormat="of" target="section-4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-examples">Examples</xref></t>
          </li>
          <li pn="section-toc.1-1.5">
            <t indent="0" pn="section-toc.1-1.5.1"><xref derivedContent="5" format="counter" sectionFormat="of" target="section-5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-generic-options">Generic Options</xref></t>
          </li>
          <li pn="section-toc.1-1.6">
            <t indent="0" pn="section-toc.1-1.6.1"><xref derivedContent="6" format="counter" sectionFormat="of" target="section-6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-internationalization-and-ch">Internationalization and Character Encoding</xref></t>
          </li>
          <li pn="section-toc.1-1.7">
            <t indent="0" pn="section-toc.1-1.7.1"><xref derivedContent="7" format="counter" sectionFormat="of" target="section-7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-tracking-payment-target-typ">Tracking Payment Target Types</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.7.2">
              <li pn="section-toc.1-1.7.2.1">
                <t indent="0" pn="section-toc.1-1.7.2.1.1"><xref derivedContent="7.1" format="counter" sectionFormat="of" target="section-7.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-ach-bank-account">ACH Bank Account</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.2">
                <t indent="0" pn="section-toc.1-1.7.2.2.1"><xref derivedContent="7.2" format="counter" sectionFormat="of" target="section-7.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-business-identifier-code">Business Identifier Code</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.3">
                <t indent="0" pn="section-toc.1-1.7.2.3.1"><xref derivedContent="7.3" format="counter" sectionFormat="of" target="section-7.3"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-international-bank-account-">International Bank Account Number</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.4">
                <t indent="0" pn="section-toc.1-1.7.2.4.1"><xref derivedContent="7.4" format="counter" sectionFormat="of" target="section-7.4"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-unified-payments-interface">Unified Payments Interface</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.5">
                <t indent="0" pn="section-toc.1-1.7.2.5.1"><xref derivedContent="7.5" format="counter" sectionFormat="of" target="section-7.5"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-bitcoin-address">Bitcoin Address</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.6">
                <t indent="0" pn="section-toc.1-1.7.2.6.1"><xref derivedContent="7.6" format="counter" sectionFormat="of" target="section-7.6"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-interledger-protocol-addres">Interledger Protocol Address</xref></t>
              </li>
              <li pn="section-toc.1-1.7.2.7">
                <t indent="0" pn="section-toc.1-1.7.2.7.1"><xref derivedContent="7.7" format="counter" sectionFormat="of" target="section-7.7"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-void-payment-target">Void Payment Target</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.8">
            <t indent="0" pn="section-toc.1-1.8.1"><xref derivedContent="8" format="counter" sectionFormat="of" target="section-8"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-security-considerations">Security Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.9">
            <t indent="0" pn="section-toc.1-1.9.1"><xref derivedContent="9" format="counter" sectionFormat="of" target="section-9"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-iana-considerations">IANA Considerations</xref></t>
          </li>
          <li pn="section-toc.1-1.10">
            <t indent="0" pn="section-toc.1-1.10.1"><xref derivedContent="10" format="counter" sectionFormat="of" target="section-10"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-payto-payment-target-types">Payto Payment Target Types</xref></t>
          </li>
          <li pn="section-toc.1-1.11">
            <t indent="0" pn="section-toc.1-1.11.1"><xref derivedContent="11" format="counter" sectionFormat="of" target="section-11"/>. <xref derivedContent="" format="title" sectionFormat="of" target="name-references">References</xref></t>
            <ul bare="true" empty="true" indent="2" spacing="compact" pn="section-toc.1-1.11.2">
              <li pn="section-toc.1-1.11.2.1">
                <t indent="0" pn="section-toc.1-1.11.2.1.1"><xref derivedContent="11.1" format="counter" sectionFormat="of" target="section-11.1"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-normative-references">Normative References</xref></t>
              </li>
              <li pn="section-toc.1-1.11.2.2">
                <t indent="0" pn="section-toc.1-1.11.2.2.1"><xref derivedContent="11.2" format="counter" sectionFormat="of" target="section-11.2"/>.  <xref derivedContent="" format="title" sectionFormat="of" target="name-informative-references">Informative References</xref></t>
              </li>
            </ul>
          </li>
          <li pn="section-toc.1-1.12">
            <t indent="0" pn="section-toc.1-1.12.1"><xref derivedContent="" format="none" sectionFormat="of" target="section-appendix.a"/><xref derivedContent="" format="title" sectionFormat="of" target="name-authors-addresses">Authors' Addresses</xref></t>
          </li>
        </ul>
      </section>
    </toc>
  </front>
  <middle>
    <section anchor="introduction" numbered="true" toc="include" removeInRFC="false" pn="section-1">
      <name slugifiedName="name-introduction">Introduction</name>
      <t indent="0" pn="section-1-1">This document defines the 'payto' Uniform Resource Identifier (URI)
      <xref target="RFC3986" format="default" sectionFormat="of" derivedContent="RFC3986"/> scheme for designating
      transfer form data for payments.</t>
      <section numbered="true" toc="include" removeInRFC="false" pn="section-1.1">
        <name slugifiedName="name-objective">Objective</name>
        <t indent="0" pn="section-1.1-1">A 'payto' URI always identifies the target of a payment. A 'payto'
	URI
	consists of a payment target type, a target identifier, and optional
	parameters such as an amount or a payment reference.</t>
        <t indent="0" pn="section-1.1-2">The interpretation of the target identifier is defined by the
	payment target type and typically represents either a bank account or
	an (unsettled) transaction.</t>
        <t indent="0" pn="section-1.1-3">A unified URI scheme for all payment target types allows
	applications to offer user interactions with URIs that represent
	payment targets, simplifying the introduction of new payment systems
	and applications.</t>
      </section>
      <section numbered="true" toc="include" removeInRFC="false" pn="section-1.2">
        <name slugifiedName="name-requirements-language">Requirements Language</name>
        <t indent="0" pn="section-1.2-1">
    The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>",
    "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>",
    "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
    "<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are
    to be interpreted as
    described in BCP 14 <xref target="RFC2119" format="default" sectionFormat="of" derivedContent="RFC2119"/> <xref target="RFC8174" format="default" sectionFormat="of" derivedContent="RFC8174"/>
    when, and only when, they appear in all capitals, as shown here.
        </t>
      </section>
    </section>
    <section anchor="syntax" numbered="true" toc="include" removeInRFC="false" pn="section-2">
      <name slugifiedName="name-syntax-of-a-payto-uri">Syntax of a 'payto' URI</name>
      <t indent="0" pn="section-2-1">This document uses the Augmented Backus-Naur Form (ABNF) of <xref target="RFC5234" format="default" sectionFormat="of" derivedContent="RFC5234"/>.</t>
      <sourcecode type="abnf" markers="false" pn="section-2-2">
  payto-URI = "payto://" authority path-abempty [ "?" opts ]
  opts = opt *( "&amp;" opt )
  opt-name = generic-opt / authority-specific-opt
  opt-value = *pchar
  opt = opt-name "=" opt-value
  generic-opt = "amount" / "receiver-name" / "sender-name" /
                "message" / "instruction"
  authority-specific-opt = ALPHA *( ALPHA / DIGIT / "-" / "." )
  authority = ALPHA *( ALPHA / DIGIT / "-" / "." )
</sourcecode>
      <t indent="0" pn="section-2-3">
    'path-abempty' is defined in <xref target="RFC3986" sectionFormat="of" section="3.3" format="default" derivedLink="https://rfc-editor.org/rfc/rfc3986#section-3.3" derivedContent="RFC3986"/>.
    'pchar' is defined in <xref target="RFC3986" sectionFormat="of" section="A" format="default" derivedLink="https://rfc-editor.org/rfc/rfc3986#appendix-A" derivedContent="RFC3986"/>.
      </t>
    </section>
    <section anchor="semantics" numbered="true" toc="include" removeInRFC="false" pn="section-3">
      <name slugifiedName="name-semantics">Semantics</name>
      <t indent="0" pn="section-3-1">The authority component of a payment URI identifies the payment
      target type.  The payment target types are defined in the "Payto Payment
      Target Types" registry (see <xref target="payto-registry" format="default" sectionFormat="of" derivedContent="Section 10"/>). The path component of the URI identifies the target
      for a payment as interpreted by the respective payment target type. The
      query component of the URI can provide additional parameters for a
      payment. Every payment target type <bcp14>SHOULD</bcp14> accept the
      options defined in generic-opt. The default operation of applications
      that invoke a URI with the 'payto' scheme <bcp14>MUST</bcp14> be to
      launch
      an application (if available) associated with the payment target type
      that can initiate a payment.

      If multiple handlers are registered for the
      same payment target type, the user <bcp14>SHOULD</bcp14> be able to
      choose which application to launch. This allows users with multiple bank
      accounts (each accessed via the respective bank's banking application)
      to
      choose which account to pay with. An application <bcp14>SHOULD</bcp14>
      allow dereferencing a 'payto' URI even if the payment target type of
      that
      URI is not registered in the "Payto Payment Target Types"
      registry. Details
      of the payment <bcp14>MUST</bcp14> be taken from the path and options
      given in the URI.  The user <bcp14>SHOULD</bcp14> be allowed to modify
      these details before confirming a payment.</t>
    </section>
    <section anchor="examples" numbered="true" toc="include" removeInRFC="false" pn="section-4">
      <name slugifiedName="name-examples">Examples</name>
      <t indent="0" pn="section-4-1">Valid Example:</t>
      <sourcecode markers="false" pn="section-4-2">
payto://iban/DE75512108001245126199?amount=EUR:200.0&amp;message=hello
</sourcecode>
      <t indent="0" pn="section-4-3">Invalid Example (authority missing):</t>
      <sourcecode markers="false" pn="section-4-4">
payto:iban/12345
</sourcecode>
    </section>
    <section anchor="generic-options" numbered="true" toc="include" removeInRFC="false" pn="section-5">
      <name slugifiedName="name-generic-options">Generic Options</name>
      <t indent="0" pn="section-5-1">Applications <bcp14>MUST</bcp14> accept URIs with options in any
      order.  The "amount" option <bcp14>MUST NOT</bcp14> occur more than
      once.  Other options <bcp14>MAY</bcp14> be allowed multiple times, with
      further restrictions depending on the payment target type. The following
      options <bcp14>SHOULD</bcp14> be understood by every payment target
      type.</t>
      <dl newline="false" spacing="normal" indent="3" pn="section-5-2">
        <dt pn="section-5-2.1">amount:</dt>
        <dd pn="section-5-2.2">
          <t indent="0" pn="section-5-2.2.1">The amount to transfer.  The format <bcp14>MUST</bcp14> be:</t>
          <sourcecode type="abnf" markers="false" pn="section-5-2.2.2">
  amount = currency ":" unit [ "." fraction ]
  currency = 1*ALPHA
  unit = 1*(DIGIT / ",")
  fraction = 1*(DIGIT / ",")
</sourcecode>
          <t indent="0" pn="section-5-2.2.3">If a 3-letter 'currency' is used, it <bcp14>MUST</bcp14> be an <xref target="ISO4217" format="default" sectionFormat="of" derivedContent="ISO4217"/> alphabetic code. A payment target
      type <bcp14>MAY</bcp14> define semantics beyond ISO 4217 for currency
      codes that are not 3 characters. The 'unit' value <bcp14>MUST</bcp14> be
      smaller than 2^53. If present, the 'fraction' <bcp14>MUST</bcp14>
      consist of no more than 8 decimal digits. The use of commas is optional
      for readability, and they <bcp14>MUST</bcp14> be ignored.</t>
        </dd>
        <dt pn="section-5-2.3">receiver-name:</dt>
        <dd pn="section-5-2.4">Name of the entity that receives the payment (creditor). The value of
  this option <bcp14>MAY</bcp14> be subject to lossy conversion, modification,
  and truncation (for example, due to line wrapping or character set
  conversion).</dd>
        <dt pn="section-5-2.5">sender-name:</dt>
        <dd pn="section-5-2.6">Name of the entity that makes the payment (debtor). The value of this
  option <bcp14>MAY</bcp14> be subject to lossy conversion, modification, and
  truncation (for example, due to line wrapping or character set
  conversion).</dd>
        <dt pn="section-5-2.7">message:</dt>
        <dd pn="section-5-2.8">A short message to identify the purpose of the payment. The value of
  this option <bcp14>MAY</bcp14> be subject to lossy conversion, modification,
  and truncation (for example, due to line wrapping or character set
  conversion).</dd>
        <dt pn="section-5-2.9">instruction:</dt>
        <dd pn="section-5-2.10">A short message giving payment reconciliation instructions to the
  recipient. An instruction that follows the character set and length
  limitation defined by the respective payment target type <bcp14>SHOULD NOT</bcp14> be subject to lossy conversion.</dd>
      </dl>
    </section>
    <section anchor="encoding" numbered="true" toc="include" removeInRFC="false" pn="section-6">
      <name slugifiedName="name-internationalization-and-ch">Internationalization and Character Encoding</name>
      <t indent="0" pn="section-6-1">
  Various payment systems use restricted character sets.
  An application that processes 'payto' URIs <bcp14>MUST</bcp14> convert
  characters that are not allowed by the respective payment systems
  into allowable characters using either an encoding or a replacement table.
  This conversion process <bcp14>MAY</bcp14> be lossy, except for the
  instruction field.
  If the value of the instruction field would be subject to lossy conversion,
  modification, or truncation,
  the application <bcp14>SHOULD</bcp14> refuse further processing of the
  payment until a
  different value for the instruction is provided.
      </t>
      <t indent="0" pn="section-6-2">To avoid special encoding rules for the payment target identifier,
      the userinfo component <xref target="RFC3986" format="default" sectionFormat="of" derivedContent="RFC3986"/> is
      disallowed in 'payto' URIs.  Instead, the payment target identifier is
      given as an option, where encoding rules are uniform for all
      options.</t>
      <t indent="0" pn="section-6-3">
  Defining a generic way of tagging the language of option fields containing
  natural
  language text (such as "receiver-name", "sender-name", and "message)
  is out of the scope of this document, as internationalization must
  accommodate the restrictions
  and requirements of the underlying banking system of the payment target
  type.

  The internationalization concerns <bcp14>SHOULD</bcp14> be individually
  defined by each payment target type.
      </t>
    </section>
    <section anchor="tracking" numbered="true" toc="include" removeInRFC="false" pn="section-7">
      <name slugifiedName="name-tracking-payment-target-typ">Tracking Payment Target Types</name>
      <t indent="0" pn="section-7-1"> A registry of "Payto Payment Target Types" is described in <xref target="payto-registry" format="default" sectionFormat="of" derivedContent="Section 10"/>. The registration policy for
      this registry is "First Come First Served", as described in <xref target="RFC8126" format="default" sectionFormat="of" derivedContent="RFC8126"/>. When requesting new entries,
      careful consideration of the following criteria is strongly advised:</t>
      <ol spacing="normal" type="1" indent="adaptive" start="1" pn="section-7-2">
        <li pn="section-7-2.1" derivedCounter="1.">The description clearly defines the syntax and semantics of the
	payment target and optional parameters if applicable.</li>
        <li pn="section-7-2.2" derivedCounter="2.">Relevant references are provided if they are available.</li>
        <li pn="section-7-2.3" derivedCounter="3.">The chosen name is appropriate for the payment target type, does
	not conflict with well-known payment systems, and avoids potential to
	confuse users.</li>
        <li pn="section-7-2.4" derivedCounter="4.">The payment system underlying the payment target type is not
	fundamentally incompatible with the general options (such as positive
	decimal amounts) in this specification.</li>
        <li pn="section-7-2.5" derivedCounter="5.">The payment target type is not a vendor-specific version of a
	payment target type that could be described more generally by a
	vendor-neutral payment target type.</li>
        <li pn="section-7-2.6" derivedCounter="6.">The specification of the new payment target type remains within
	the scope of payment transfer form data. In particular, specifying
	complete invoices is not in scope. Neither are processing
	instructions to the payment processor or bank beyond a simple
	payment.</li>
        <li pn="section-7-2.7" derivedCounter="7.">The payment target and the options do not contain the payment
	sender's account details.</li>
      </ol>
      <t indent="0" pn="section-7-3">Documents that support requests for new registry entries should
      provide the following information for each entry:</t>
      <dl newline="false" spacing="normal" indent="3" pn="section-7-4">
        <dt pn="section-7-4.1">Name:</dt>
        <dd pn="section-7-4.2">The name of the payment target type (case-insensitive ASCII
	string, restricted to alphanumeric characters, dots, and dashes).</dd>
        <dt pn="section-7-4.3">Description:</dt>
        <dd pn="section-7-4.4">A description of the payment target type, including the semantics
	of the path in the URI if applicable.</dd>
        <dt pn="section-7-4.5">Example:</dt>
        <dd pn="section-7-4.6">At least one example URI to illustrate the payment target
	type.</dd>
        <dt pn="section-7-4.7">Contact:</dt>
        <dd pn="section-7-4.8">The contact information of a person to contact for further
	information.</dd>
        <dt pn="section-7-4.9">References:</dt>
        <dd pn="section-7-4.10">Optionally, references describing the payment target type (such as
	an RFC) and target-specific options or references describing the
	payment system underlying the payment target type.</dd>
      </dl>
      <t indent="0" pn="section-7-5">This document populates the registry with seven entries as follows
      (see
      also <xref target="payto-registry" format="default" sectionFormat="of" derivedContent="Section 10"/>).</t>
      <section anchor="registry-entry-ach" numbered="true" toc="include" removeInRFC="false" pn="section-7.1">
        <name slugifiedName="name-ach-bank-account">ACH Bank Account</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.1-1">
          <dt pn="section-7.1-1.1">Name:</dt>
          <dd pn="section-7.1-1.2">ach</dd>
          <dt pn="section-7.1-1.3">Description:</dt>
          <dd pn="section-7.1-1.4">Automated Clearing House (ACH). The path consists of two
	    components:
	      the routing number and the account number. Limitations on the
	      length
	        and character set of option values are defined by the
		implementation
		  of the handler. Language tagging and internationalization of
		  options
		    are not supported.</dd>
          <dt pn="section-7.1-1.5">Example:</dt>
          <dd pn="section-7.1-1.6">
            <sourcecode markers="false" pn="section-7.1-1.6.1">
payto://ach/122000661/1234
</sourcecode>
          </dd>
          <dt pn="section-7.1-1.7">Contact:</dt>
          <dd pn="section-7.1-1.8">N/A</dd>
          <dt pn="section-7.1-1.9">References:</dt>
          <dd pn="section-7.1-1.10">
            <xref target="NACHA" format="default" sectionFormat="of" derivedContent="NACHA"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-bic" numbered="true" toc="include" removeInRFC="false" pn="section-7.2">
        <name slugifiedName="name-business-identifier-code">Business Identifier Code</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.2-1">
          <dt pn="section-7.2-1.1">Name:</dt>
          <dd pn="section-7.2-1.2">bic</dd>
          <dt pn="section-7.2-1.3">Description:</dt>
          <dd pn="section-7.2-1.4">Business Identifier Code (BIC). The path consists of just
    a BIC. This is used for wire transfers between banks. The registry
      for BICs is provided by the Society for Worldwide Interbank
        Financial Telecommunication (SWIFT). The path does not allow
	specifying a
	  bank account number. Limitations on the length and character set of
	    option values are defined by the implementation of the
	      handler. Language tagging and internationalization of options
	      are not
	        supported.</dd>
          <dt pn="section-7.2-1.5">Example:</dt>
          <dd pn="section-7.2-1.6">
            <sourcecode markers="false" pn="section-7.2-1.6.1">
payto://bic/SOGEDEFFXXX
</sourcecode>
          </dd>
          <dt pn="section-7.2-1.7">Contact:</dt>
          <dd pn="section-7.2-1.8">N/A</dd>
          <dt pn="section-7.2-1.9">References:</dt>
          <dd pn="section-7.2-1.10">
            <xref target="BIC" format="default" sectionFormat="of" derivedContent="BIC"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-iban" numbered="true" toc="include" removeInRFC="false" pn="section-7.3">
        <name slugifiedName="name-international-bank-account-">International Bank Account Number</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.3-1">
          <dt pn="section-7.3-1.1">Name:</dt>
          <dd pn="section-7.3-1.2">iban</dd>
          <dt pn="section-7.3-1.3">Description:</dt>
          <dd pn="section-7.3-1.4">International Bank Account Number (IBAN).  Generally, the IBAN
    allows to unambiguously derive the associated Business
      Identifier Code (BIC) using a lookup in the respective
      proprietary translation table.  However, some legacy applications
      process
        payments to the same IBAN differently based on the specified BIC.
	  Thus, the path can consist of either a single component (the IBAN)
	  or
	    two components (BIC followed by IBAN).  The "message" option of
	    the
	      'payto' URI corresponds to the "unstructured remittance
	      information"
	        of Single Euro Payments Area (SEPA) credit transfers and is
		thus
		  limited to 140 characters with
		    character set limitations that differ according to the
		    countries of
		      the banks and payment processors involved in the
		      payment. The
		        "instruction" option of the 'payto' URI corresponds to
			the "end-to-end
			  identifier" of SEPA credit transfers and is thus
			  limited to, at most,
			    35 characters, which can be alphanumeric or from
			    the allowed set of
			      special characters, i.e., "+?/-:().,'". Language
			      tagging and
			        internationalization of options are not
  supported.</dd>
          <dt pn="section-7.3-1.5">Examples:</dt>
          <dd pn="section-7.3-1.6">
            <sourcecode markers="false" pn="section-7.3-1.6.1">
payto://iban/DE75512108001245126199
payto://iban/SOGEDEFFXXX/DE75512108001245126199
</sourcecode>
          </dd>
          <dt pn="section-7.3-1.7">Contact:</dt>
          <dd pn="section-7.3-1.8">N/A</dd>
          <dt pn="section-7.3-1.9">References:</dt>
          <dd pn="section-7.3-1.10">
            <xref target="ISO20022" format="default" sectionFormat="of" derivedContent="ISO20022"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-upi" numbered="true" toc="include" removeInRFC="false" pn="section-7.4">
        <name slugifiedName="name-unified-payments-interface">Unified Payments Interface</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.4-1">
          <dt pn="section-7.4-1.1">Name:</dt>
          <dd pn="section-7.4-1.2">upi</dd>
          <dt pn="section-7.4-1.3">Description:</dt>
          <dd pn="section-7.4-1.4">Unified Payment Interface (UPI). The path is an account
	    alias.  The
	      amount and receiver-name options are mandatory for this payment
	        target. Limitations on the length and character set of option
		values
		  are defined by the implementation of the handler. Language
		  tags and
		    internationalization of options are not supported.</dd>
          <dt pn="section-7.4-1.5">Example:</dt>
          <dd pn="section-7.4-1.6">
            <sourcecode markers="false" pn="section-7.4-1.6.1">
payto://upi/alice@example.com?receiver-name=Alice&amp;amount=INR:200
</sourcecode>
          </dd>
          <dt pn="section-7.4-1.7">Contact:</dt>
          <dd pn="section-7.4-1.8">N/A</dd>
          <dt pn="section-7.4-1.9">References:</dt>
          <dd pn="section-7.4-1.10">
            <xref target="UPILinking" format="default" sectionFormat="of" derivedContent="UPILinking"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-bitcoin" numbered="true" toc="include" removeInRFC="false" pn="section-7.5">
        <name slugifiedName="name-bitcoin-address">Bitcoin Address</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.5-1">
          <dt pn="section-7.5-1.1">Name:</dt>
          <dd pn="section-7.5-1.2">bitcoin</dd>
          <dt pn="section-7.5-1.3">Description:</dt>
          <dd pn="section-7.5-1.4">Bitcoin protocol. The path is a "bitcoinaddress", as per <xref target="BIP0021" format="default" sectionFormat="of" derivedContent="BIP0021"/>. Limitations on the length
	    and
	      character set of option values are defined by the implementation
	      of
	        the handler. Language tags and internationalization of options
		are
		  not supported.</dd>
          <dt pn="section-7.5-1.5">Example:</dt>
          <dd pn="section-7.5-1.6">
            <sourcecode markers="false" pn="section-7.5-1.6.1">
payto://bitcoin/12A1MyfXbW6RhdRAZEqofac5jCQQjwEPBu
</sourcecode>
          </dd>
          <dt pn="section-7.5-1.7">Contact:</dt>
          <dd pn="section-7.5-1.8">N/A</dd>
          <dt pn="section-7.5-1.9">References:</dt>
          <dd pn="section-7.5-1.10">
            <xref target="BIP0021" format="default" sectionFormat="of" derivedContent="BIP0021"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-ilp" numbered="true" toc="include" removeInRFC="false" pn="section-7.6">
        <name slugifiedName="name-interledger-protocol-addres">Interledger Protocol Address</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.6-1">
          <dt pn="section-7.6-1.1">Name:</dt>
          <dd pn="section-7.6-1.2">ilp</dd>
          <dt pn="section-7.6-1.3">Description:</dt>
          <dd pn="section-7.6-1.4">Interledger protocol (ILP). The path is an ILP address, as per
	    <xref target="ILP-ADDR" format="default" sectionFormat="of" derivedContent="ILP-ADDR"/>. Limitations on the
	    length and
	      character set of option values are defined by the implementation
	      of
	        the handler. Language tagging and internationalization of
		options
		  are not supported.</dd>
          <dt pn="section-7.6-1.5">Example:</dt>
          <dd pn="section-7.6-1.6">
            <sourcecode markers="false" pn="section-7.6-1.6.1">
payto://ilp/g.acme.bob
</sourcecode>
          </dd>
          <dt pn="section-7.6-1.7">Contact: </dt>
          <dd pn="section-7.6-1.8">N/A</dd>
          <dt pn="section-7.6-1.9">References:</dt>
          <dd pn="section-7.6-1.10">
            <xref target="ILP-ADDR" format="default" sectionFormat="of" derivedContent="ILP-ADDR"/>, RFC 8905</dd>
        </dl>
      </section>
      <section anchor="registry-entry-void" numbered="true" toc="include" removeInRFC="false" pn="section-7.7">
        <name slugifiedName="name-void-payment-target">Void Payment Target</name>
        <dl newline="false" spacing="normal" indent="3" pn="section-7.7-1">
          <dt pn="section-7.7-1.1">Name:</dt>
          <dd pn="section-7.7-1.2">void</dd>
          <dt pn="section-7.7-1.3">Description:</dt>
          <dd pn="section-7.7-1.4">The "void" payment target type allows specifying the
	    parameters
	      of an out-of-band payment (such as cash or other types of
	      in-person
	        transactions).  The path is optional and interpreted as a
		  comment. Limitations on the length and character set of
		  option
		    values are defined by the implementation of the
		    handler. Language
		      tags and internationalization of options are not
	    supported.</dd>
          <dt pn="section-7.7-1.5">Example:</dt>
          <dd pn="section-7.7-1.6">
            <sourcecode markers="false" pn="section-7.7-1.6.1">
payto://void/?amount=EUR:10.5
</sourcecode>
          </dd>
          <dt pn="section-7.7-1.7">Contact:</dt>
          <dd pn="section-7.7-1.8">N/A</dd>
          <dt pn="section-7.7-1.9">References:</dt>
          <dd pn="section-7.7-1.10">RFC 8905</dd>
        </dl>
      </section>
    </section>
    <section anchor="security" numbered="true" toc="include" removeInRFC="false" pn="section-8">
      <name slugifiedName="name-security-considerations">Security Considerations</name>
      <t indent="0" pn="section-8-1">Interactive applications handling the 'payto' URI scheme <bcp14>MUST NOT</bcp14> initiate any financial transactions without prior review and
      confirmation from the user and <bcp14>MUST</bcp14> take measures to
      prevent clickjacking <xref target="HMW12" format="default" sectionFormat="of" derivedContent="HMW12"/>.</t>
      <t indent="0" pn="section-8-2">Unless a 'payto' URI is received over a trusted, authenticated
      channel,
      a user might not be able to identify the target of a payment.  In
      particular, due to homographs <xref target="unicode-tr36" format="default" sectionFormat="of" derivedContent="unicode-tr36"/>, a payment target type <bcp14>SHOULD NOT</bcp14> use
      human-readable names in combination with unicode in the target account
      specification, as it could give the user the illusion of being able to
      identify the target account from the URI.</t>
      <t indent="0" pn="section-8-3">The authentication/authorization mechanisms and transport security
      services used to process a payment encoded in a 'payto' URI are handled
      by
      the application and are not in scope of this document.</t>
      <t indent="0" pn="section-8-4">To avoid unnecessary data collection, payment target types
      <bcp14>SHOULD NOT</bcp14> include personally identifying information
      about the sender of a payment that is not essential for an application
      to conduct a payment.</t>
    </section>
    <section anchor="iana" numbered="true" toc="include" removeInRFC="false" pn="section-9">
      <name slugifiedName="name-iana-considerations">IANA Considerations</name>
      <t indent="0" pn="section-9-1">
  IANA maintains the "Uniform Resource Identifier (URI) Schemes" registry,
  which contains an entry for the 'payto' URI scheme as follows.  IANA has updated that
  entry to reference this document.</t>
      <dl indent="3" newline="false" spacing="normal" pn="section-9-2">
        <dt pn="section-9-2.1">Scheme name:</dt>
        <dd pn="section-9-2.2"> payto</dd>
        <dt pn="section-9-2.3">Status:</dt>
        <dd pn="section-9-2.4"> provisional</dd>
        <dt pn="section-9-2.5">URI scheme syntax:</dt>
        <dd pn="section-9-2.6">See <xref target="syntax" format="default" sectionFormat="of" derivedContent="Section 2"/> of RFC 8905.</dd>
        <dt pn="section-9-2.7">URI scheme semantics:</dt>
        <dd pn="section-9-2.8">See <xref target="semantics" format="default" sectionFormat="of" derivedContent="Section 3"/> of RFC
  8905.
</dd>
        <dt pn="section-9-2.9">Applications/protocols that use this scheme name:</dt>
        <dd pn="section-9-2.10"> payto URIs are
  mainly used by financial software.</dd>
        <dt pn="section-9-2.11">Contact:</dt>
        <dd pn="section-9-2.12">
          <t indent="0" pn="section-9-2.12.1"><contact fullname="Christian Grothoff"/> &lt;grothoff@gnu.org&gt;</t>
        </dd>
        <dt pn="section-9-2.13">Change controller:</dt>
        <dd pn="section-9-2.14">
          <t indent="0" pn="section-9-2.14.1"><contact fullname="Christian Grothoff"/> &lt;grothoff@gnu.org&gt;</t>
        </dd>
        <dt pn="section-9-2.15">References:</dt>
        <dd pn="section-9-2.16"> See <xref target="refs" format="default" sectionFormat="of" derivedContent="Section 11"/> of RFC 8905.</dd>
      </dl>
    </section>
    <section anchor="payto-registry" numbered="true" toc="include" removeInRFC="false" pn="section-10">
      <name slugifiedName="name-payto-payment-target-types">Payto Payment Target Types</name>
      <t indent="0" pn="section-10-1">
   This document specifies a list of payment target types.  It is
   possible that future work will need to specify additional payment
   target types.  The GNUnet Assigned Numbers Authority (GANA) <xref target="GANA" format="default" sectionFormat="of" derivedContent="GANA"/>
   operates the "Payto Payment Target Types" registry to track
   the following information for each payment target type:
      </t>
      <dl newline="false" spacing="normal" indent="3" pn="section-10-2">
        <dt pn="section-10-2.1">Name:</dt>
        <dd pn="section-10-2.2">The name of the payment target type (case-insensitive ASCII
	string, restricted to alphanumeric characters, dots, and dashes)</dd>
        <dt pn="section-10-2.3">Contact:</dt>
        <dd pn="section-10-2.4">The contact information of a person to contact for further
	information</dd>
        <dt pn="section-10-2.5">References:</dt>
        <dd pn="section-10-2.6">Optionally, references describing the payment target type (such as
	an RFC) and target-specific options or references describing the
	payment system underlying the payment target type</dd>
      </dl>
      <t indent="0" pn="section-10-3">
  The entries in the "Payto Payment Target Types" registry
  defined in this document are as follows:
      </t>
      <table align="center" pn="table-1">
        <thead>
          <tr>
            <th align="left" colspan="1" rowspan="1">Name</th>
            <th align="left" colspan="1" rowspan="1">Contact</th>
            <th align="left" colspan="1" rowspan="1">Reference</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td align="left" colspan="1" rowspan="1">ach</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">bic</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">iban</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">upi</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">bitcoin</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">ilp</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
          <tr>
            <td align="left" colspan="1" rowspan="1">void</td>
            <td align="left" colspan="1" rowspan="1">N/A</td>
            <td align="left" colspan="1" rowspan="1">RFC 8905</td>
          </tr>
        </tbody>
      </table>
    </section>
  </middle>
  <back>
    <references anchor="refs" pn="section-11">
      <name slugifiedName="name-references">References</name>
      <references pn="section-11.1">
        <name slugifiedName="name-normative-references">Normative References</name>
        <reference anchor="ISO20022" target="https://www.iso.org" quoteTitle="true" derivedAnchor="ISO20022">
          <front>
            <title>Financial Services - Universal financial industry message scheme</title>
            <author>
              <organization showOnFrontPage="true">International Organization for Standardization</organization>
            </author>
            <date month="May" year="2013"/>
          </front>
          <seriesInfo name="ISO" value="20022"/>
        </reference>
        <reference anchor="ISO4217" target="https://www.iso.org" quoteTitle="true" derivedAnchor="ISO4217">
          <front>
            <title>Codes for the representation of currencies</title>
            <author>
              <organization showOnFrontPage="true">International Organization for Standardization</organization>
            </author>
            <date month="August" year="2015"/>
          </front>
          <seriesInfo name="ISO" value="4217"/>
        </reference>
        <reference anchor="NACHA" quoteTitle="true" derivedAnchor="NACHA">
          <front>
            <title>2020 Nacha Operating Rules &amp; Guidelines</title>
            <author>
              <organization showOnFrontPage="true">Nacha</organization>
              <address>
                <uri>https://www.nacha.org/</uri>
              </address>
            </author>
            <date year="2019"/>
          </front>
        </reference>
        <reference anchor="RFC2119" target="https://www.rfc-editor.org/info/rfc2119" quoteTitle="true" derivedAnchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author initials="S." surname="Bradner" fullname="S. Bradner">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="1997" month="March"/>
            <abstract>
              <t indent="0">In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC3986" target="https://www.rfc-editor.org/info/rfc3986" quoteTitle="true" derivedAnchor="RFC3986">
          <front>
            <title>Uniform Resource Identifier (URI): Generic Syntax</title>
            <author initials="T." surname="Berners-Lee" fullname="T. Berners-Lee">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="R." surname="Fielding" fullname="R. Fielding">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="L." surname="Masinter" fullname="L. Masinter">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2005" month="January"/>
            <abstract>
              <t indent="0">A Uniform Resource Identifier (URI) is a compact sequence of characters that identifies an abstract or physical resource.  This specification defines the generic URI syntax and a process for resolving URI references that might be in relative form, along with guidelines and security considerations for the use of URIs on the Internet.  The URI syntax defines a grammar that is a superset of all valid URIs, allowing an implementation to parse the common components of a URI reference without knowing the scheme-specific requirements of every possible identifier.  This specification does not define a generative grammar for URIs; that task is performed by the individual specifications of each URI scheme.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="66"/>
          <seriesInfo name="RFC" value="3986"/>
          <seriesInfo name="DOI" value="10.17487/RFC3986"/>
        </reference>
        <reference anchor="RFC5234" target="https://www.rfc-editor.org/info/rfc5234" quoteTitle="true" derivedAnchor="RFC5234">
          <front>
            <title>Augmented BNF for Syntax Specifications: ABNF</title>
            <author initials="D." surname="Crocker" fullname="D. Crocker" role="editor">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="P." surname="Overell" fullname="P. Overell">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2008" month="January"/>
            <abstract>
              <t indent="0">Internet technical specifications often need to define a formal syntax.  Over the years, a modified version of Backus-Naur Form (BNF), called Augmented BNF (ABNF), has been popular among many Internet specifications.  The current specification documents ABNF. It balances compactness and simplicity with reasonable representational power.  The differences between standard BNF and ABNF involve naming rules, repetition, alternatives, order-independence, and value ranges.  This specification also supplies additional rule definitions and encoding for a core lexical analyzer of the type common to several Internet specifications.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="68"/>
          <seriesInfo name="RFC" value="5234"/>
          <seriesInfo name="DOI" value="10.17487/RFC5234"/>
        </reference>
        <reference anchor="RFC8126" target="https://www.rfc-editor.org/info/rfc8126" quoteTitle="true" derivedAnchor="RFC8126">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author initials="M." surname="Cotton" fullname="M. Cotton">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="B." surname="Leiba" fullname="B. Leiba">
              <organization showOnFrontPage="true"/>
            </author>
            <author initials="T." surname="Narten" fullname="T. Narten">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2017" month="June"/>
            <abstract>
              <t indent="0">Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
              <t indent="0">To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
              <t indent="0">This is the third edition of this document; it obsoletes RFC 5226.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="26"/>
          <seriesInfo name="RFC" value="8126"/>
          <seriesInfo name="DOI" value="10.17487/RFC8126"/>
        </reference>
        <reference anchor="RFC8174" target="https://www.rfc-editor.org/info/rfc8174" quoteTitle="true" derivedAnchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author initials="B." surname="Leiba" fullname="B. Leiba">
              <organization showOnFrontPage="true"/>
            </author>
            <date year="2017" month="May"/>
            <abstract>
              <t indent="0">RFC 2119 specifies common key words that may be used in protocol  specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the  defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="unicode-tr36" quoteTitle="true" derivedAnchor="unicode-tr36">
          <front>
            <title abbrev="Unicode Security Considerations">Unicode Technical Report #36: Unicode Security Considerations</title>
            <author initials="M." surname="Davis" fullname="Mark Davis" role="editor">
              <address>
                <email>markdavis@google.com</email>
              </address>
            </author>
            <author initials="M." surname="Suignard" fullname="Michael Suignard" role="editor">
              <address>
                <email>michel@suignard.com</email>
              </address>
            </author>
            <date month="September" year="2014"/>
          </front>
        </reference>
      </references>
      <references pn="section-11.2">
        <name slugifiedName="name-informative-references">Informative References</name>
        <reference anchor="BIC" target="https://www.iso.org" quoteTitle="true" derivedAnchor="BIC">
          <front>
            <title>Banking -- Banking telecommunication messages -- Business identifier code (BIC)</title>
            <author>
              <organization showOnFrontPage="true">International Organization for Standardization</organization>
            </author>
            <date month="December" year="2014"/>
          </front>
          <seriesInfo name="ISO" value="9362"/>
        </reference>
        <reference anchor="BIP0021" target="https://en.bitcoin.it/w/index.php?title=BIP_0021&amp;oldid=66778" quoteTitle="true" derivedAnchor="BIP0021">
          <front>
            <title>Bitcoin Improvement Proposal 21</title>
            <author initials="N." surname="Schneider" fullname="Nils         Schneider">
            </author>
            <author initials="M." surname="Corallo" fullname="Matt Corallo">
            </author>
            <date month="September" year="2019"/>
          </front>
        </reference>
        <reference anchor="GANA" target="https://gana.gnunet.org/" quoteTitle="true" derivedAnchor="GANA">
          <front>
            <title>GNUnet Assigned Numbers Authority (GANA)</title>
            <author>
              <organization showOnFrontPage="true">GNUnet e.V.</organization>
            </author>
            <date month="April" year="2020"/>
          </front>
        </reference>
        <reference anchor="HMW12" target="https://www.usenix.org/system/files/conference/usenixsecurity12/sec12-final39.pdf" quoteTitle="true" derivedAnchor="HMW12">
          <front>
            <title>Clickjacking: Attacks and Defenses</title>
            <author initials="L." surname="Huang" fullname="Lin-Shung Huang">
            </author>
            <author initials="A." surname="Moshchuk" fullname="Alexander               Moshchuk">
            </author>
            <author initials="H." surname="Wang" fullname="Helen J. Wang">
            </author>
            <author initials="S." surname="Schecter" fullname="Stuart               Schecter">
            </author>
            <author initials="C." surname="Jackson" fullname="Collin Jackson">
            </author>
            <date year="2012"/>
          </front>
        </reference>
        <reference anchor="ILP-ADDR" target="https://interledger.org/rfcs/0015-ilp-addresses/" quoteTitle="true" derivedAnchor="ILP-ADDR">
          <front>
            <title>ILP Addresses - v2.0.0</title>
            <author>
              <organization showOnFrontPage="true">Interledger</organization>
            </author>
          </front>
        </reference>
        <reference anchor="UPILinking" target="https://www.npci.org.in/sites/default/files/UPI%20Linking%20Specs_ver%201.6.pdf" quoteTitle="true" derivedAnchor="UPILinking">
          <front>
            <title>Unified Payment Interface - Common URL Specifications For Deep Linking And Proximity Integration</title>
            <author>
              <organization showOnFrontPage="true">National Payments Corporation of India</organization>
            </author>
            <date month="November" year="2017"/>
          </front>
        </reference>
      </references>
    </references>
    <section anchor="authors-addresses" numbered="false" removeInRFC="false" toc="include" pn="section-appendix.a">
      <name slugifiedName="name-authors-addresses">Authors' Addresses</name>
      <author fullname="Florian Dold" initials="F." surname="Dold">
        <organization showOnFrontPage="true">Taler Systems SA</organization>
        <address>
          <postal>
            <street>7, rue de Mondorf</street>
            <city>Erpeldange</city>
            <code>5421</code>
            <country>Luxembourg</country>
          </postal>
          <email>dold@taler.net</email>
        </address>
      </author>
      <author fullname="Christian Grothoff" initials="C." surname="Grothoff">
        <organization showOnFrontPage="true">Bern University of Applied Sciences</organization>
        <address>
          <postal>
            <street>Quellgasse 21</street>
            <street/>
            <city>Biel/Bienne</city>
            <code>2501</code>
            <country>Switzerland</country>
          </postal>
          <email>christian.grothoff@bfh.ch</email>
        </address>
      </author>
    </section>
  </back>
</rfc>
