data:image/s3,"s3://crabby-images/e7a84/e7a8428dd4bb0a85f421340c32afd4a12ee53fa8" alt="image"
Gevulot — a PostgreSQL proxy for masking sensitive data
Gvulot (Hebrew: גְּבוּלוֹת, lit. "Borders")
Gevulot is a TCP proxy that sits between your PostgreSQL database and client and proxies data back and forth.
It listens to all messages sent from database to the client and provides a mechanism for users to modify data in-transit and before received by the client. The main purpose of Gevulot is to mask personally identifiable information sent to clients.
data:image/s3,"s3://crabby-images/3f1b9/3f1b9f460a538acd678bf76919e7dd43d0520f0d" alt="image"
Usage
To start the Gevulot:
gevulot
(by default it will load gevulot.toml
from the current directory)
If you need to specify config path:
gevulot --config=/path/to/config.toml
For help:
gevulot --help
Architecture
CSP view:
data:image/s3,"s3://crabby-images/45b77/45b7708321f1de51cf36feaa485b8912445f4547" alt="image"
Dispatcher
Dispatcher is responsible for processing messages from a database to a client and vice versa.
PostgreSQL protocol has deterministic message flow except when it doesn't :(
Following messages can arrive at any time:
- NoticeResponse
- ParameterStatus
- NotificationResponse
To simplify the logic we use 2 parallel processing routines: one handles normal deterministic flow and
another one — async out-of-order flow.
data:image/s3,"s3://crabby-images/3159c/3159cd5f5216efef39974593a02ff2cc24d58b13" alt="image"
Configuration File Reference
Gevolut uses TOML format for its config.
Here is an example:
listen = "0.0.0.0:4242"
database-url = "postgres://localhost/hired_dev"
The listen
field (mandatory)
Sets local address and port on which Gevolut will listen for client connections.
NB: UNIX sockets are not supported yet.
Example: listen = "0.0.0.0:4242"
The database-url
field (mandatory)
Sets URL to use to connect to the database. Gevulot requires access to the proxied database to load metadata (i.e., OID mapping).
NB: If a client attempt to connect to a different database than specified here, the proxy will return an error.
Example: database-url = "postgres://localhost/hired_dev"