Skip to content

Commit

Permalink
Create user-data-protection.md
Browse files Browse the repository at this point in the history
  • Loading branch information
Rajdip019 authored May 13, 2024
1 parent c399ae6 commit d5b04b1
Showing 1 changed file with 48 additions and 0 deletions.
48 changes: 48 additions & 0 deletions docs/backend/user-data-protection.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@

# User Data Protection

Data protection is one of the main things for a auth server and we have taken that seriously. Here is a breif how the data gets encrypted and stored in the database.



## Method

The method we are using for encryption is **Envelope Encryption**

### Terminology ( to keep in mind )
- `DEK`: Data Encryption Key
- `KEK` : Key Encryption Key


## Diagram

![data-protection-inhouse-auth](https://github.com/Rajdip019/in-house-auth/assets/91758830/163fdd5a-1757-481c-ba18-3a4bfacb72d2)


## Explaination

Here is a strp by step guide on how it works.

### Step 1:
Every user is assigned a new and unique `DEK` when they sign up.

### Step 2:
We encrypt all the user data from `Session Details`, `Password Reset Request` and all with the user `DEK` using the `AESGcm256` algorithm and store it to DB.

### Step 3:
The auth server has his own `KEK`. This is unique for the server. You can generate it by running the command below from the root of your project. ( Make sure you have cargo installed ) - [How to install cargo](https://doc.rust-lang.org/cargo/getting-started/installation.html)
```
cargo run --bin create_kek
```

### Step 4:
We use the `KEK` to encrypt the `DEK` using the same `AESGcm256` algorithm and store it to DB.

### Step 5: ( Additional )
For additional safety you can use `GCP KMS`, `AWS KMS` or any other cloud provider for additional safety.



## Feedback

If you have any feedback, please raise a issue or start a discussion. Thank you.

0 comments on commit d5b04b1

Please sign in to comment.