Encrypt Query Language (EQL) is a set of abstractions for transmitting, storing, and interacting with encrypted data and indexes in PostgreSQL.
[!TIP] > New to EQL? EQL is the basis for searchable encryption functionality when using Protect.js and/or CipherStash Proxy.
Store encrypted data alongside your existing data:
- Encrypted data is stored using a jsonbcolumn type
- Query encrypted data with specialized SQL functions (equality, range, full-text, etc.)
- Index encrypted columns to enable searchable encryption
The simplest way to get up and running with EQL is to execute the install SQL file directly in your PostgreSQL database.
-  Download the latest EQL install script: curl -sLo cipherstash-encrypt.sql https://github.com/cipherstash/encrypt-query-language/releases/latest/download/cipherstash-encrypt.sql 
-  Run this command to install the custom types and functions: psql -f cipherstash-encrypt.sql 
Warning
The version released on dbdev may not be in sync with the version released on GitHub until we automate the publishing process.
You can find the EQL extension on dbdev's extension catalog with instructions on how to install it.
Once the custom types and functions are installed in your PostgreSQL database, you can start using EQL in your queries.
Define encrypted columns using the eql_v2_encrypted type, which stores encrypted data as jsonb with additional constraints to ensure data integrity.
Example:
CREATE TABLE users ( id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY, encrypted_email eql_v2_encrypted );In order to enable searchable encryption, you will need to configure your CipehrStash integration appropriately.
- If you are using CipherStash Proxy, see this guide.
- If you are using Protect.js, use the Protect.js schema.
These frameworks use EQL to enable searchable encryption functionality in PostgreSQL.
| Framework | Repo | 
|---|---|
| Protect.js | Protect.js | 
| Protect.php | Protect.php | 
| CipherStash Proxy | CipherStash Proxy | 
See the development guide.