dcr ⭐️
A proof of concept framework to orchestrate Interoperable Differentially Private Data Clean Room Services on Intel SGX.
A Data Clean Room is a secure environment where organizations can collect data from multiple sources and combine it with their first-party data. Doing so allows marketers to leverage large, aggregated datasets of consumer behavior to provide insight into critical factors like performance, demographics, campaigns, etc.
Data clean rooms allow companies to extract value from aggregate datasets sourced from multiple parties while prioritizing user privacy and maintaining strict security measures.
Contributing Guidelines
This Repo follows following Contributing Guidelines
NOTE: This project is hosted under GSSoC'23. Please go through GSSoc_CONTRIBUTING.md before moving on the any issues. You can ask any queries on discord channel or Discussion Board mentioned.
NOTE:
- As of now this framework is only able to show a Proof of Concept for the architecture described in the spec. This framework will be used in a paper that I will be publishing soon. The paper will try to formalise data clean rooms. So, any thing that deviates this project from realising the paper is not in the scope of this project.
- Current PoC only shows an example of three collaborators, out of which two provide sources and one provides the transformation.
- Currently only Confidential GoApps are supported for transformations.
- The Code is not production ready and does not partake any security measures other than access control and differential privacy.
- The library is still not tested on actual SGX backed machines and but the PoC can be tested on simulation mode.
To Run an example Data Clean Room Scenario.
- This framework will not work on Windows. Make sure you have a linux machine installed.
- (Optional) Install Intel-SGX SDK
- Make sure you have Go 1.20+ installed.
- Make sure you have E-Go Compiler installed on your PC's
You can see the sample collaboration package in samples/init_collaboration. You can also look at some sample packages under construction along with their graph images in samples/test_graph
⚡️ Quick Start:
- 🏗 Build the
dcr
binary.
make build
- 🏃🏻♀️ Run the demonstration
./dcr run --pkgpath samples/init_collaboration
Links:
- Spec Doc
- Research Doc
- dcr YouTube Video
- https://confidentialcomputing.io
- https://differentialprivacy.org