AWS Cognito
AWS Cognito is an identity platform for web and mobile apps.
The Cognito wrapper allows you to read data from your Cognito Userpool within your Postgres database.
Preparation
Before you can query AWS Cognito, you need to enable the Wrappers extension and store your credentials in Postgres.
Enable Wrappers
Make sure the wrappers
extension is installed on your database:
1 |
|
Enable the Cognito Wrapper
Enable the cognito_wrapper
FDW:
1 2 3 |
|
Store your credentials (optional)
By default, Postgres stores FDW credentials inside pg_catalog.pg_foreign_server
in plain text. Anyone with access to this table will be able to view these credentials. Wrappers are designed to work with Vault, which provides an additional level of security for storing credentials. We recommend using Vault to store your credentials.
1 2 3 4 5 6 |
|
Connecting to Cognito
We need to provide Postgres with the credentials to connect to Cognito, and any additional options. We can do this using the create server
command:
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 |
|
Create a schema
We recommend creating a schema to hold all the foreign tables:
1 |
|
Entities
Users
This is an object representing Cognito User Records.
Operations
Object | Select | Insert | Update | Delete | Truncate |
---|---|---|---|---|---|
Users | ✅ | ❌ | ❌ | ❌ | ❌ |
Usage
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
Notes
- Only the columns listed above are accepted in the foreign table
- The
attributes
column contains additional user attributes in JSON format
Query Pushdown Support
This FDW doesn't support query pushdown.
Limitations
This section describes important limitations and considerations when using this FDW:
- No query pushdown support, all filtering must be done locally
- Large result sets may experience slower performance due to full data transfer requirement
- Only supports User Pool objects from Cognito API
- No support for Identity Pool operations
- Materialized views using these foreign tables may fail during logical backups
Examples
Basic example
This will create a "foreign table" inside your Postgres database called cognito_table
:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
You can now fetch your Cognito data from within your Postgres database:
1 |
|