Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/qascade/dcr

A PoC framework to orchestrate interoperable Differentially Private Data Clean Room Services using Intel SGX hardware as root of trust.
https://github.com/qascade/dcr

confidential-computing data data-security datacleanroom differential-privacy golang gssoc gssoc23 intel-sgx intel-sgx-sdk

Last synced: 3 months ago
JSON representation

A PoC framework to orchestrate interoperable Differentially Private Data Clean Room Services using Intel SGX hardware as root of trust.

Awesome Lists containing this project

README

        

# dcr ⭐️

[![forthebadge](http://forthebadge.com/images/badges/made-with-go.svg)](http://forthebadge.com)
[![forthebadge](http://forthebadge.com/images/badges/built-with-love.svg)](http://forthebadge.com)

[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=shields)](http://makeapullrequest.com)

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](https://github.com/qascade/dcr/blob/main/CONTRIBUTING.md)

NOTE: This project is hosted under [GSSoC'23](https://gssoc.girlscript.tech/). Please go through [GSSoc_CONTRIBUTING.md](/GSSoC_GUIDELINES.md) before moving on the any issues. You can ask any queries on discord channel or Discussion Board mentioned.

## NOTE:
1. 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.
2. Current PoC only shows an example of three collaborators, out of which two provide sources and one provides the transformation.
3. Currently only Confidential GoApps are supported for transformations.
4. The Code is not production ready and does not partake any security measures other than access control and differential privacy.
5. 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.
1. This framework will not work on Windows. Make sure you have a linux machine installed.
2. (Optional) Install [Intel-SGX](https://github.com/intel/linux-sgx-driver) SDK
3. Make sure you have [Go](https://go.dev/) 1.20+ installed.
4. Make sure you have [E-Go](https://github.com/edgelesssys/ego) 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:
1. 🏗 Build the `dcr` binary.
```bash
make build
```
Screenshot 2023-05-11 at 4 09 17 AM

Screenshot 2023-05-11 at 4 10 33 AM

2. 🏃🏻‍♀️ Run the demonstration
```bash
./bin/dcr run --pkgpath samples/init_collaboration
```

Links:
1. [Spec Doc]( https://cliff-colt-e2a.notion.site/Solution-3-07d81059daab40cb84180336a33c3dd9)
2. [Research Doc](https://cliff-colt-e2a.notion.site/Clean-Room-Doc-f606d90163ff4ca9b14bae92c0db328d)
3. [dcr YouTube Video](https://youtu.be/uQIePGL3kT8)
3. https://confidentialcomputing.io
4. https://differentialprivacy.org

## Contributors