PoC e2ee of data with PGP in python and JavaScript
.gitignore | ||
admin.html | ||
config.js | ||
data.html | ||
database.py | ||
forms.html | ||
LICENSE | ||
public.js | ||
README.md | ||
register.html | ||
registered.js | ||
server.py | ||
websocket.py |
PoC WebSocket PGP JSON
This PoC shows a way to encrypt e2e data collected from forms for one or more users using PGP
Requirements
- Recent Python 3
- Python 3 binding for GPGME (python3-gpg)
- OpenPGP.js (openpgp.min.js)
Run
./server.py [port] [listen address] [datadir]
- default port:
8000
- default listen address:
127.0.0.1
- default data directory: random temporary one and in memory database
If you are running the server on a different address/port than the default one, you have to edit config.js SRV
constant.
Once the server is running you can browse:
- Server root (
/
) to generate user keys and upload the public key to the server. First one is admin. /admin.html
to set forms keys for encryption and reencrypt data after keys change./forms.html
to collect data./data.html
to view collected data.
Protocol brief overview
API request from registered users
- Client fetch the server public key (for this particular step we assume the link is secure)
- Client encrypt with server key and sign with its own key a JSON of the format
{ request: "api/request", payload: "optional payload" }
and send it over WebSocket - Server checks if it knows the client key. Then answer with the same JSON but without payload with an added random nonce encrypted for client and signed.
- Client checks if the JSON request field is the same and server signature is valid. Then sign and encrypt the message with the nonce and send it back to the server.
- Server checks if the nonce is the same and the signature from the client is valid and recent enough and then execute the request and answer it if needed and close the connection.
Public request
Simply done over basic HTTP with fetch. Again we trust that the link is secure
Notable missing feature
On key deletion there is no notification that data may needs to be reencrypted.