Skip to content

Certificates

About

This document tracks existing procedures or proposals for integrating and validating TLS/HTTPS certificates for Onion Services.

While some depends on Certificate Authorities (CA) model, others rely on alternative certification and validation procedures that does not require built-in certificate chains in the client software or reliance on financial transactions.

Benefits

It may be argued that Onion Services connections are already self-authenticated -- since the public key and the URL are tied together and the connection is peer-to-peer encrypted --, and thus making the need for HTTPS pointless, or at most giving only an impression on users of additional security.

But having valid HTTPS connection in Onion Services could enable many other enhancements, such as:

  1. Some browser features are available only with HTTPS, like Secure Contexts, Content Security Policy (CSP), Secure cookies, WebAuthn, WebRTC and PaymentRequest.

  2. A user may be using a browser that isn't the Tor browser. For example on iOS there is only Safari, and in such cases the browser will not be aware of the different semantics of security for an onion site, and won't allow the use of secure browser features (such as secure cookies). This limits the kind of web apps people can develop on onionsites as many modern browser APIs mentioned above.

  3. Allows for the usage of HTTP/2, since some browsers only support it if on HTTPS1. In the future, HTTP2 and HTTP3 may only work with TLS, and thus valid certificates.

  4. It also opens up new opportunities such as payment processing, "as current PCI DSS requirements do not allow non-standard TLS"2 and may only work with certificates having some sort of validation3. Payments card networks require HTTPS for a payment to be taken. So if someone wants to do that over an onion site they would need a TLS certificate.

  5. It could be argued that this is also security-in-depth by having yet another layer of encryption atop of other existing encryption layers. Even if the theoretical gain in terms of interception and tampering resistance is not relevant, it would still allow for service operators to split their encryption keys in different servers -- like one with the Onion Service keys and a backend having the TLS keys, thus making a compromise in one of the servers exposing only the cryptographic material of one of the communication layers.

  6. The Tor daemon that hosts the onion site might not be the final computer in the chain. In larger organizations, deployment concerns may result in plain HTTP traveling across their network from the Tor daemon to the final web server. Having HTTPs protects those hops in the chain. This is something that distributed setups may need. The same could be said for a web browser using Tor SOCKS proxy somewhere else on the network.

  7. Non-web based applications, such as IMAP/POP/SMTP etc. can benefit from certificates being valid.

  8. There is simply too much software that isn't aware of onionsites, and trying to force HTTP-over-Onion to be as secure as HTTPS-over-TCP creates a compatibility mess of things which do and don't know about the semantics.

  9. There is value in exposing the existence of an onion site via CT Logs. If someone navigates to the plain web version of a site, and is presented with a certificate containing a Subject Alternative Name (SAN) for both the plain web and the onion site that provides a strong cryptographic guarantee that they are the same site. Effectively this would replace the Onion-Location header with something more authenticated4.

The following discussion is not yet conclusive, and the problem space may be hard to solve.

Overview

Proposal Certification Validation Status
Existing CA validation CA/B Baseline Requirements for .onion CA chain Implemented, fully supported
ACME for .onion CA/B Baseline Requirements for .onion CA chain Proposed specification
Self-signed certificates Self-signed certificate None Depends on per-application support
Self-signed X.509 from .onion Signed by a "CA" derived from the .onion private key Check if cert is issued by the .onion private key Proof-of-concept, no browser integration
Same Origin Onion Certificates (SOOC) Self-signed certs Skip for .onion addresses when conditions match Proposal (not yet submitted for specification)
DANE for .onion Self-signed certs DNSSEC Concept, no proposal yet
Onion-only CAs Checks SAN and an .onion signature in an extension CA chain Concept, no proposal yet

Main pros and cons

Proposal Pros Cons
Existing CA validation None (already implemented) None (already implemented)
ACME for .onion No need for client/lib implementation Depends on a CA willing to implement
Self-signed X.509 for .onion No CA-reliance for .onion, self-auth. Very hard to maintain and standardize, currently Ed25519 is unsupported by major browsers
Same Origin Onion Certificates (SOOC) No CA-reliance for .onion Very hard to maintain and standardize
DANE for .onion No CA-reliance for any domain or .onion Very hard to implement and maintain
Onion-only CAs Simplify CA-reliance Needs to convince existing CAs or trusted parties to maintain a whole CA organization and infrastructure

Main implementation characteristics

Proposal Implementation level Additional requirements
Existing CA validation Procedure happens at the CA side
ACME for .onion Procedure happens at the CA side
Self-signed X.509 for .onion Client or TLS library
Same Origin Onion Certificates (SOOC) Client or TLS library
DANE for .onion Client Portable DNSSEC library
Onion-only CAs Client or TLS (only needs CA installation)

Existing CA validation

The CA/Browser Forum, a consortium that produces guidelines for X.509 (TLS/HTTPS) certification, created validation rules for Onion Service v2 addresses (in 2015), later extended for Onion Services v3 (in 2020), standardizing the way Certificate Authorities can issue certificates for .onion addresses and supports wildcards5.

Only a few commercial providers currently provide this service6.

The Appendix B of the CA/B Baseline Requirements (current repository version) for the Issuance and Management of Publicly‐Trusted Certificates (since Version 1.7.4, released in 2021) establishes two validation methods to ensure that someone request the certificate really control a given .onion address:

  1. An "Agreed‑Upon Change to Website" (manually or via ACME), where the service operator must include some secret, such as at the /.well-known/pki-validation of the site.
  2. TLS using ALPN.
  3. Checking of a Certificate Signing Request (CSR) signed by the Onion Service private key and containing an specific cryptographic nonce (i.e, a shared secret to be used only once), like using the onion-csr tool.

Note that both methods does not require that operators disclose the location of the Onion Service, nor them need to have a regular site for the service using DNS. Validation can either happen by accessing directly the Onion Service or by using the service private key to sign a CSR.

But still commercial CAs (or financial institution) may still collect identifiable information during the purchase of the certificates.

ACME for .onion (CA-validated)

In general, getting certificates from CAs supporting the CA/B Baseline Requirements for .onion addresses is still a manual, or in the best-case scenario, semi-automated task.

The Automatic Certificate Management Environment (ACME) standard (RFC 8555) solves part of the automation problem, but currently (as of 2022) it does not support the methods for validating Onion Services.

Having support for .onion address in the ACME standard is the first step for projects like Let's Encrypt to offer free certificates for Onion Services, without financial transactions.

Existing proposals to bring ACME for Onion Services are discussed below.

ACME Onion Identifier Validation Extension

The "Automated Certificate Management Environment (ACME) Onion Identifier Validation Extension" internet draft (draft-suchan-acme-onion-00) was proposed on 2022.05 and is the first known proposal to bring ACME for .onion addresses.

As of 20230607, this internet draft is in the expired state.

References:

ACME for Onions

The "Automated Certificate Management Environment (ACME) Extensions for ".onion" Domain Names" (draft-misell-acme-onion) is the second known proposal to bring ACME for .onion addresses.

A detailed analysis on ACME for Onions is available in a special appendix.

References:

Self-signed certificates

This proposal consists in basically allowing for the use of self-signed certificates with Onion Services:

  1. For web applications like the Tor Browser, this would consist in disabling self-signed certificate warnings when visiting .onion sites. As an alternative, there's also the Self-authenticating TLS Certificates for Onion Services proposal relying on PKCS#11 modules or Authority Information Access (AIA) extensions, which could handle self-signed certificates matching the Onion Service address without the need to merge this logic directly in the applications, as it would remain decoupled in a PKCS#11 module, thus being easier to maintain.
  2. For other applications -- like the TorVPN and third-party software --, this would probably require patches or documentation instructing users to accept non-CA signed certificates when accessing Onion Services, which is very hard to provide and to maintain for a wide ranging of tools.

This proposal would not provide:

  1. A self-authentication mechanism (since the certificate is self-signed). This have a huge weight since an important piece of security provided by HTTPS is not just end-to-end encryption but also authentication.

Supporting self-signed certificates with Onion Services has a huge gain, but also introduces an authentication complexity. That's why proper UI indicators and hints are needed:

  1. For the encryption state of the site (HTTP and various HTTPS situations).
  2. For the authentication state of the site, telling how it was (not) authenticated.

There are already sketches for different scenarios for how various user interface hints and indicators could exist for Tor Browser and other software maintained by Tor, as well as existing certificate proposals that can change the certificate landscape for Onion Services in the future, which could be adopted by operators instead of relying on self-signed certs.

But all these enhancements would still limit the practical application domain of this proposal, since it would be readily available only to a small set of applications like Tor Browser, except if by pursuing some standardization such as the SOOC proposal below.

Self-signed X.509 from .onion (self-signed by the .onion address)

Another option for having HTTPS in Onion Services that may be available in the future is to use Onion Service keypair to self-validate an HTTPS certificate:

For an overview of Ed25519, check How do Ed5519 keys work?. For details about how Tor implements Ed25519, check prop220 (and rend-spec-v3 for how it implements at the Onion Services level).

This proposal has the advantage to not rely on Certificate Authorities, but the disadvantage that needs additional logic both server and client side to make it work, since a CA would needed to be installed for every visited Onion Service using this scheme.

It's important to note that the current (as of 2023-04-04) Onion Services v3 specification does not allow the Master Onion Service identity key to be used for purposes other than generating blinded signing keys (see Section 1.9 from the rend-spec-v3):

Master (hidden service) identity key -- A master signing keypair used as the identity for a hidden service. This key is long term and not used on its own to sign anything; it is only used to generate blinded signing keys as described in [KEYBLIND] and [SUBCRED]. The public key is encoded in the ".onion" address according to [NAMING]. KP_hs_id, KS_hs_id.

Also, while many TLS libraries support the Ed25519 signing scheme used for certificates (like in OpenSSL since version 1.1.1), major web browsers still does not support it (as of 2022-12)7, probably because they're not supported8 by the current (as of 2022-12) CA/B Baseline Requirements:

6.1.1.3 Subscriber Key Pair Generation

The CA SHALL reject a certificate request if one or more of the following conditions are met:

  1. The Key Pair does not meet the requirements set forth in Section 6.1.5 and/or Section 6.1.6;

[...]

6.1.5 Key sizes

For RSA key pairs the CA SHALL:

• Ensure that the modulus size, when encoded, is at least 2048 bits, and; • Ensure that the modulus size, in bits, is evenly divisible by 8.

For ECDSA key pairs, the CA SHALL:

• Ensure that the key represents a valid point on the NIST P‐256, NIST P‐384 or NIST P‐521 elliptic curve.

No other algorithms or key sizes are permitted.

In summary, implementing this proposal would require pushing at least two specification changes:

  1. A ballot with CA/B Forum about including Ed25519 support.
  2. An update in the Onion Services v3 spec, allowing the Onion Service identity keys to either:
    1. Also act as Certificate Authority root keys for the service.
    2. Derive long-term (1 year) blinded keys to be used as a Certificate Authority for the service, maybe using the same approach described by Appendix A ([KEYBLIND]) from rend-spec-v3 but covering the needed use case of a long-term key, i.e, depending in a long-term nonce and not in [TIME-PERIODS].

It's also important to avoid using the Onion Service key directly as the HTTPS certificate. That would:

  • Expose the Onion Service secret key material to more software than it's needed, like a web server.
  • Make it very difficult to manage offline Onion Service master keys.

Instead, it's better to use the Onion Service keypair to act as a CA that then certifies a separate key pair to be used with HTTPS.

Similar to the self-signed certificate proposal, this approach would have limited adoption if only as small number of applications implement it -- such as the Tor Browser --, except if endorsed by many stakeholders in the form of a specification -- like the SOOC proposal discussed below.

Same Origin Onion Certificates (SOOC)

The Same Origin Onion Certificates (SOOC) proposal aims to specify when "in very limited circumstances, we shall not care about signatures at all", allowing clients to disable self-signed certificate warnings when visiting .onion sites.

The main difference between the SOOC proposal and to simply start allowing self-signed certificates is that SOOC is aimed to be an IETF proposal that could gain momentum and hence have a greater chance to be adopt by many different vendors.

See the SOOC document for details.

DANE for .onion

Another option is to use DNS-based Authentication of Named Entities (DANE), with DNS records like this to associate an Onion Service address with a given HTTPS certificate's public key hash:

_443._tcp.testk4ae7qr6nhlgahvyicxy7nsrmfmhigtdophufo3vumisvop2gryd.onion. TSLA 3 1 1 AB9BEB9919729F3239AF08214C1EF6CCA52D2DBAE788BB5BE834C13911292ED9

In order for that to work, logic should be implemented in the client software.

Drawbacks:

  1. Service operators must update this record whenever a new certificate is issued.
  2. Has some limits for wildcard certificates on specific ports.
  3. DANE is not widely supported, especially by web browsers.
  4. It would only work for service operators willing to publish the .onion address in the DNS.

Onion-only CAs

This proposal consists of:

  1. Having .onion-only CAs with name constraints (only allowing issuance for .onion). Services available both via DNS-based and .onion domains will need to have two TLS certificates in order to use this approach -- one certificate for the DNS-based domain (as usual) and another only for the .onion address.
  2. Certification procedure would be automated, so generated .onion addresses could easily have it's certificates issued by this special type of CA.
  3. Certification would then happen by checking a signature in a CSR and comparing the Subject Alternative Name (SAN). Signature must be validated by the .onion address in the SAN.
  4. So this type of CA would be mainly a basic notary that attests signatures and issues a corresponding certificate.
  5. The name constraint for this type of CA ensures that it only issues certificates for .onion domains.

Security considerations:

  • Suppose there's a malicious or bugged CA of this type that issues a certificate containing a SAN for $address1.onion but:
    1. Without checking whether the CSR has a signature made by $address1.onion's private key.
    2. Or if allowing that another, unrelated $address2.onion actually signs this CSR.
  • Even if that's the case, i.e, the CA wrongly issued a certificate for $address1.onion that did not match the requirements, this certificate won't work in practice, since in a successful Onion Service TLS connection to $address1.onion the following must happen:
    1. The underlying Tor Rendezvous connection should ensure that the client is connected to $address1.onion (Onion Services connections are self-authenticated by the .onion address).
    2. The Onion Service should then offer it's TLS certificate, which would not be the malicious one (except if the service is already compromised, but in that case the attacker would not need to forge an invalid certificate anyway...).
    3. Then the client's TLS library tests whether the certificate chain can be verified and any SAN in the presented certificate matches $address1.onion, among other checks (such as expiration).
  • That said, the work done by this special type of CA is only to expand the self-authentication property from the .onion address into a certificate. So the attack surface of this special type of CA may be inherently low.

Implementation considerations:

  • Since Ed25519 certificates probably won't be supported by major browsers/clients in the foreseeable future (see discussion above at the Self-signed X.509 for .onion section), issuance should probably follow the Appendix B of the CA/B Baseline Requirements.
  • The entire certification procedure could happen via Onion Services.
  • Actually the whole CA infrastructure (website, APIs, OCSP etc) could be interacted only via Onion Services, to reduce the attack surface and protect the service location.
  • Important to consider whether would be possible to organizations setup and maintain a Onion-only CA that's as most automated as possible, including root certificate packaging/distribution/rotation.

Pros:

  1. Easy to implement on the client side (just need to install the CA).
  2. Easy to implement and maintain on Tor-native applications such as Tor Browser and the Tor VPN.
  3. Possibly lowest attack surface than with regular CAs!
  4. Largest certification expiration dates could be used (like one year).

Cons:

  1. Might not be easy to find CAs willing to do this, or to a new one to be formed for this purpose.
  2. Might need a merge request to include this method in the CA/B Baseline Requirements, if wider acceptance is intended.
  3. No guarantees that these special CAs would be installed among all clients and libraries.
  4. Need additional security analysis.

Open questions:

  1. Need to check if Certificate Revocation Lists (CRLs) are needed, and how to handle it.
  2. Need to figure out how OCSP and OCSP Stapling could happen. OSCP connection could be available behind an Onion Service.
  3. Does sending certificates to CT Logs still makes sense for this special type of certification?
  4. Needs built-in DoS/service abuse protection:
    • An idea for that: implement a simple PoW by additionally requiring that service operators provide a proof-ownership of another .onion address made by an specific vanity address (like limited to 5 or 6 chars).

References:

Custom CAs

There are also discussions about how to properly manage custom Certificate Authorities, i.e, those not distributed in TLS libraries by default (such as the certificate store in a web browser):

Further references

Meeting notes

Blog posts

Notes


  1. But not HTTP/3 yet, since it uses UDP not available via Tor (as of 2023-05). The HTTP/2 standard does not require encryption, but all major browsers require encryption for HTTP/2 and encryption for HTTP/3 is required by default

  2. See PCI-DSS v4.0 - Appendix G - Term "Strong Cryptography" - page 355, which points only to "industry tested and accepted algorithms". While we could argue that PCI-DSS v4.0 is not precise enough about which transmission protocols might be used, it may be the case that the encryption used by the Onion Services' Rendezvous v3 protocol is not (yet) part of an "industry standard" (needs someone to carefully review this claim and open a merge request to update this information). It also may be the case that PCI-DSS compliance may be hard to get for a system that employs only the Rendezvous v3 protocol to transmit cardholder data between an user and an Onion Service, without TLS atop of it. And users might not trust the connection if not over TLS, or if their browser does not show certificate information. 

  3. It's worth note that PCI-DSS does allow for the use of self-signed certificates under some special conditions that may exclude some of the proposals in this document (see PCI-DSS v4.0 - Requirement 4.2 - Applicability Notes - page 106). In practice, this is only applicable for internal links within an organization or for clients and libraries that have the custom Certificate Authorities' root keys on it's keystores and that matches the standard requirements. And users would hardly trust a self-signed certificate for doing online purchases as their browsers would show warning messages. Recommendation (see PCI-DSS v4.0 - Requirement 4.2 - Guidance - page 106) goes instead towards a certificate trusted by a Certificate Authority. 

  4. However, the argument about revealing an onion site that would like to remain hidden, is a real one. For those services, it could be considered options such as a non-CT Logs issuing CA that may not be in the "valid" set, but operated by a friendly to Tor organization, which is added to Tor Browser as a valid certifier. The standards space may be moving towards requiring CT log submissions at some point, so this is something to keep an eye on. Another possibility would be to consider writing a standard for hashing onion site names in CT Logs, so they can be verified, but not revealed (such as what WhatsApp did in their Auditable Key Directory). Such a standard could take years to get to place of usefulness, and probably encounter resistance. Otherwise, the only option for such a service operator is to have a self-signed certificate, or none at all. 

  5. For a historical background on Domain Validation (DV) certs, check the CA/B forum thread DV issuance for next-generation onion services

  6. As of January 2023, there are only two CAs issuing certificates for .onion domains: DigiCert providing only Extended Validation (EV) certs and HARICA providing only Domain Validated (DV) certs

  7. They usually just support X25519, which is a key agreement scheme no to be confused with Ed25519

  8. Check Request For CertBot To Support The Signing of Ed25519 Certificates, Support Ed25519 and Ed448 and (Servercert-wg) Ed25519 certificates threads for details.