Internet-Draft | Privacy.txt File Format | June 2024 |
Sullivan, et al. | Expires 28 December 2024 | [Page] |
This proposal outlines a new file format called privacy.txt. It follows similar placement on a web server as robots.txt [RFC9309], security.txt [RFC9116], or ads.txt [ADS-TXT], in the / directory or /.well-known directory.¶
The file format adds structured data for three areas: 1. A machine parsable and complete privacy policy 2. Consumer actions under their privacy rights 3. Cookie disclosures¶
This note is to be removed before publishing as an RFC.¶
The latest revision of this draft can be found at https://www.privacytxt.dev. Status information for this document may be found at https://datatracker.ietf.org/doc/draft-colwell-privacy-txt/.¶
Discussion of this document takes place on the draft-colwell-privacy-txt Working Group mailing list (mailto:draft-colwell-privacy-txt@ietf.org), which is archived at https://mailarchive.ietf.org/arch/browse/draft-colwell-privacy-txt/. Subscribe at https://www.ietf.org/mailman/listinfo/draft-colwell-privacy-txt/.¶
Source for this draft and an issue tracker can be found at https://github.com/https://github.com/grittygrease/draft-colwell-privacy-txt.¶
This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79.¶
Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet-Drafts is at https://datatracker.ietf.org/drafts/current/.¶
Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress."¶
This Internet-Draft will expire on 28 December 2024.¶
Copyright (c) 2024 IETF Trust and the persons identified as the document authors. All rights reserved.¶
This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) 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. Code Components extracted from this document must include Revised BSD License text as described in Section 4.e of the Trust Legal Provisions and are provided without warranty as described in the Revised BSD License.¶
Consumers in many parts of the world have extensive privacy rights under laws such as the GDPR (https://gdpr.eu/tag/gdpr/), the CCPA (https://oag.ca.gov/privacy/ccpa). However, without some formalization of a service's privacy policy, it is difficult or often intractable for consumers to exercise those rights; enforcement to verify compliance with laws and develop effective monitoring; and researchers and technologists to develop tools to allow greater adoption and success of privacy practices.¶
Consumer data originally gets into the cloud by connections from consumer devices to web servers in the cloud. To be able to audit and technically enforce privacy it must be possible to track the privacy policies applied to every byte of consumer data entering the cloud. However, currently the association between a web request and the privacy policy is tenuous, leading to the possibility of incorrect or unverifiable consumer data usage at the very source. This proposal fills that hole by associating structured privacy data with every web server. Just like HTTPS security can be technically enforced, this proposal makes it possible to technically enforce privacy by verifying that the structured privacy information exists and is in good standing before sending data to the server.¶
This proposal outlines a new file format called privacy.txt. The file format adds structured data for three areas: 1. A machine-parsable and complete privacy policy 2. Consumer actions under their privacy rights 3. Cookie disclosures¶
The file format is UTF8 text [RFC3629] and lists Field:Value
, one per line. \n
is used a line break. Excess whitespace and lines that start with #
are ignored. All field are NOT case sensitive unless mentioned otherwise. Each field MUST appear on its own line. Unless otherwise specified by the field definition, multiple values MUST NOT be chained together for a single field. Unless otherwise indicated in a definition of a particular field, a field MAY appear multiple times.¶
Implementors should be aware that some of the fields may contain URIs using percent-encoding (as per Section 2.1 of [RFC3986]) and mailto URIs (as per [RFC6068]).¶
For web-based services, organizations MUST place the "privacy.txt" file under the "/.well-known/" path, e.g., https://example.com/.well-known/privacy.txt as per [RFC8615] of a domain name or IP address. For legacy compatibility, a "privacy.txt" file might be placed at the top-level path or redirect (as per Section 6.4 of [RFC7231]) to the "privacy.txt" file under the "/.well-known/" path. If a "privacy.txt" file is present in both locations, the one in the "/.well-known/" path MUST be used.¶
The file MUST be accessed via HTTP 1.0 or a higher version, and the file access MUST use the "https" scheme (as per Section 2.7.2 of [RFC7230]). It MUST have a Content-Type of "text/plain" with the default charset parameter set to "utf-8" (as per Section 4.1.3 of [RFC2046]).¶
Retrieval of "privacy.txt" files and resources indicated within such files may result in a redirect (as per Section 6.4 of [RFC7231]).¶
A string of maximum 50 characters. The string can contain any US-ASCII characters except for: control characters (ASCII characters 0 up to 31 and ASCII character 127) or separator characters (space, tab and the characters: (
)
<
>
@
,
;
:
\
"
/
[
]
?
=
{
}
). This field is case sensitive.¶
A boolean attribute, using 0 or 1 representing false (0) and true (1), whether a consent banner is present.¶
String attribute can be set to:
1. Label of consent platforms according to [MANAGERS] (extendable)
2. non-specific custom
or any identifying name if it is a custom banner
3. non-detected
when there is no banner¶
It is currently difficult to associate a complete privacy policy text with a service for a number of reasons. First, even though it must be linked from the company webpage, there is not a canonical URL. Second, it is common for services to use client-side rendering, interactive elements, break out links for addendums, and server rules to prevent machine parsing/scraping.¶
This file format proposes two fields for the privacy policy. One or both can be used, depending on the policy format.¶
Both privacy policy fields can be used for multi-language support, the default entry is the default language of the privacy policy.¶
Mandatory, single entry¶
Entity: NAME
Entity-country: COUNTRY_CODE
¶
The legal name of the entity issuing the privacy policy.¶
The current and historical mapping of hostname to entity can be used as a canonical key to associate privacy reputation or enforcement actions similar to a certificate authority. This proposal does not outline what a privacy authority would look like.¶
Optional, single entry¶
Privacy-policy-text: URL
¶
Multi-language support:
Privacy-policy-text-[LANGUAGE_CODE]: URL
¶
A complete privacy policy in a single UTF-8 text file that can be downloaded by any user agent or machine tool. This MUST include all addendums in the text file. It MUST NOT include links. Information about contact and consumer actions are covered in this file format and do not need to be linked to in the policy text.¶
Mandatory, single entry¶
Privacy-policy: URL
¶
Multi-language support:¶
Privacy-policy-[LANGUAGE_CODE]: URL
¶
If Privacy-policy-text is present, this can simply point to the existing privacy policy, in whatever form it currently exists. Otherwise, it must point to a machine parsable/scrapable static HTML file that contains the complete policy on a single page.¶
This file format proposed fields to structure the consumer actions described in the privacy policy and commonly required by law. Currently it is difficult to get even an email that can service privacy requests from many top-100 site privacy policies. There is currently no law about how easy it should be to take privacy actions, similar to the US CAN-SPAM Act [CAN-SPAM], which led to an industry standard one-click link for marketing emails. The spirit of these fields is similar, to make it as easy as possible for a consumer to exercise their privacy rights.¶
In this section, a one-click URL refers to a URL that can process a request without requiring a customer password or login. The URL should take customer identification such as email and verify as necessary to complete the request.¶
It is allowed to have multiple conforming Action-* values for the same action.¶
An API standard to make privacy actions more toolable is not covered in this proposal. This proposal could be extended in the future to allow some well-defined API actions given there is at least one other non-assisted option available.¶
Mandatory, single entry¶
Contact: mailto:EMAIL
¶
An email contact for the privacy office must be given. This email must be able to handle consumer requests via email where there is not an applicable Action-*
field for the request. Responses can ask for additional verification but should not require customer password or login. If Action-*
fields are defined for all applicable consumer requests, this email does not need to handle any requests. This proposal imagines companies would build self-service one-click URLs for all consumer actions as the most scalable outcome.¶
Optional, single entry¶
Action-delete-account-and-data: mailto:EMAIL|URL
¶
Email or one-click URL to process an account and data deletion request.¶
Optional, single entry¶
Action-delete-personal-data: mailto:EMAIL|URL
¶
Email or one-click URL to process a personal data deletion request.¶
Optional, single entry¶
Action-opt-out-sharing:mailto: EMAIL|URL
¶
Email or one-click URL to opt out of personal data sharing with third parties.¶
Optional, single entry¶
Action-shared-list:mailto: EMAIL|URL
¶
Email or one-click URL to get a list of all third parties where personal data has been shared.¶
Optional, single entry¶
Action-opt-out-marketing: mailto:EMAIL|URL
¶
Email or one-click URL to opt out of marketing.¶
Other records that are not part of the privacy.txt protocol may be included. For example, a regulation-specific record like action-fcra-freeze
could be added to comply to FCRA obligations.¶
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 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.¶
Following this file format makes it easier for consumers to take privacy actions, similar to one-click unsubscribe. Removing the barrier to actions makes it easier to make mistakes. It would be reasonable to allow some grace period of undo in case of a security incident.¶
This document has no IANA actions.¶