This is an introductory document intended to provide a summary of the OpenDSR framework. For full reference details, please see the complete specification at https://github.com/OpenGDPR/OpenDSR. This project was formerly known as OpenGDPR and existed at https://www.OpenGDPR.org and https://github.com/OpenGDPR/OpenGDPR.
The OpenDSR specification defines a common approach for data Controllers and Processors to build interoperable systems for tracking and fulfilling Data Subject requests as defined under the General Data Protection Regulation (GDPR) and California Consumer Privacy Act (CCPA). To reduce confusion, this document uses the language and terminology of the GDPR.
This framework is intended to:
- Provide a well defined JSON specification that allows Controllers and Processors to communicate and manage Data Subject Requests (DSRs) in a uniform and scalable manner.
- Provide strong cryptographic verification of request receipts to provide chain of processing assurance and demonstrate accountability to regulatory authorities (Article 5.2).
- Provide for a callback mechanism to enable Controllers to track the status of all DSRs.
This specification does not cover:
- Defining the technical measures to describe the fulfill of Data Subject requests. It is the responsibility of each Data Controller and Data Processor to interpret and apply relevant regulatory analysis and expertise to honor DSRs (the text of the GDPR and CCPA).
- The protocol for communications between Controllers and Data Subjects.
- The protocol for communications between Controllers, Processors and Supervisory Authorities.
- The protocol for communication of the results of an access or portability request.
Data Subject The person whose data is being collected and/or processed.
The CCPA refers to data subjects as 'consumers'.
Data Controller The Data Controller receives DSRs from the Data Subjects and validates them. The Controller submits requests to the Data Processors.
The CCPA refers to controllers as businesses.
Data Processor The Data processor acts on behalf of the controller and fulfills requests within the Controllers scope.
The CCPA refers to processors as service providers.
This diagram outlines the flow of DSRs all the way from the data subject to the fulfillment by each Processor. This flow includes optional callbacks that allow the Controller to receive status changes.
- New Data Subject Request: The data subject files a request to the data controller containing appropriate information. Request may be of any type defined herein.
- Request Distribution: The controller verifies the request and if it will be honored, it is submitted to Processors.
- Request Fulfillment: The Processor fulfills their obligation within the scope of this request. For example, this may include deleting user data in the case of a deletion request.
- Request Status via Callback: The processor will submit status updates to the controller if callbacks are included in the request.
- Communication to the Data Subject: The Controller communicates the results to the data subject.
The spec supports request types of “erasure”, "access" and “portability”. For all types, the details of how a processor fulfills the request is defined by the regulations and is out of scope for this specification. For access and portability requests, secure transmission of the resulting personal data is left up to the controller and processor.
This is an overview of available HTTP methods for communicating between Controllers and Processors. The following endpoints should be provided by the Processor (to receive requests from the Controller).
Restful API endpoints for the resource "request":
HTTP Method | Path | Description | Supported? |
---|---|---|---|
POST | requests/ | Create a new OpenDSR request | Yes |
GET | requests/{RequestId} | Retrieve status of a single OpenDSR request | Yes |
PUT | requests/{RequestId} | - | No, requests cannot be updated after being created |
DELETE | requests/{RequestId} | Cancel an OpenDSR request | Yes, cancellation is valid in status “pending” only |
Non-Restful endpoints:
HTTP Method | Path | Description | Supported? |
---|---|---|---|
GET | /discovery | Processors describe their OpenDSR support | Yes |
POST | /callback | Sent by Processors when a request status changes | Yes |
Refer to the full specification for definitions of objects and fields.
{
"subject_request_id":"a7551968-d5d6-44b2-9831-815ac9017798",
"regulation": "gdpr",
"subject_request_type":"erasure",
"submitted_time":"2018-10-02T15:00:00Z",
"subject_identities":[
{
"identity_type":"email",
"identity_value":"johndoe@example.com",
"identity_format":"raw"
}
],
"api_version":"2.0",
"status_callback_urls":[
"https://example-controller.com/opendsr/callbacks"
]
}