The PostHog data warehouse enables you to link your most important data into PostHog from sources like your CRM, payment processor, or database. Once linked, you can combine this data with the product analytics data already in PostHog and query across all of it.
You can link a source to PostHog by either using one of our pre-built connectors below or by creating a custom source.
The data warehouse is currently in beta. To access it, enable the feature preview in your instance. It is free to use during the beta period.
Stripe
The Stripe connector can link charges, customers, invoices, prices, products, subscriptions, and balance transactions to PostHog.
To link Stripe:
- Go to the data warehouse tab in PostHog
- Click "Link Source" and select Stripe
- Get your Account ID from your Stripe user settings under Accounts then ID
- Get your Client Secret from your Stripe API keys under Standard keys then Secret key
- Optional: Add a prefix to your table names
- Click "Next"
The data warehouse then starts syncing your Stripe data. You can see details and progress in the data warehouse settings tab.
Hubspot
The Hubspot connector can link contacts, companies, deals, emails, meetings, quotes, and tickets to PostHog.
To link Hubspot:
- Go to the data warehouse tab in PostHog
- Click "Link Source" and select Hubspot
- Select the Hubspot account you want to link and click "Connect app"
- Optional: Add a prefix to your table names
- Click "Next"
The data warehouse then starts syncing your Hubspot data. You can see details and progress in the data warehouse settings tab.
Zendesk
The Zendesk connector can link brands, groups, organizations, tickets, users, and sla policies.
To link Zendesk:
- Go to the data warehouse tab in PostHog
- Click "Link Source" and select Zendesk
- Provide the subdomain of your zendesk account (https://posthoghelp.zendesk.com/ -> "posthoghelp" is the subdomain)
- Provide the API token and email associated with it
- Optional: Add a prefix to your table names
- Click "Next"
The data warehouse then starts syncing your Zendesk data. You can see details and progress in the data warehouse settings tab.
Postgres
The Postgres connector can link your database tables to PostHog.
To link Postgres:
- Go to the data warehouse tab in PostHog
- Click "Link Source" and select Postgres
- Enter your database connection details:- Host: The hostname or IP your database server like db.example.comor192.168.1.100.
- Port: The port your database server is listening to. The default is 5432.
- Database: The name of the database you want like analytics_db.
- User: The username with the necessary permissions to access the database.
- Password: The password for the user.
- Schema: The schema for your database where your tables are located. The default is public.
 
- Host: The hostname or IP your database server like 
- Click "Link"
The data warehouse then starts syncing your Postgres data. You can see details and progress in the data warehouse settings tab.
Inbound IP addresses
We use a set of IP addresses to access your Postgres instance. To ensure this connector works, add these IPs to your inbound security rules to enable the data import:
| US | EU | 
|---|---|
| 44.205.89.55 | 3.75.65.221 | 
| 44.208.188.173 | 18.197.246.42 | 
| 52.4.194.122 | 3.120.223.253 | 
Linking a custom source
The data warehouse can also link to data in your object storage system like S3 or GCS. To start, you'll need to:
- Create a bucket in your object storage system
- Set up an access key and secret
- Add data to the bucket (we'll use Airbyte)
- Create the table in PostHog
These docs are written for AWS S3 using Airbyte, but you can also use Google Cloud Storage (GCS) and Fivetran, Stitch, or other ETL tools.
Step 1: Creating a bucket in S3
- Log in to AWS.
- Open S3 in the AWS console and create a new bucket. We suggest us-east-1if you're using PostHog Cloud US, oreu-central-1if you're using PostHog Cloud EU.

Make sure to note both the name and region of your bucket, we'll need these later.
Step 2: Set up access policy and key
Next, we need to create a new user in our AWS console with programmatic access to our newly created bucket.
- Open IAM and create a new policy to enable access to this bucket
- On the left under "Access management," select "Policies," and click "Create policy"
- Under the service, choose "S3"
- Under "Actions," select:- "Write" -> "PutObject"
- "Permission Management" -> "PutObjectAcl"
 
- Under "Resources," select "Specific," and click "object" -> "Add ARN"
- Specify your bucket name and choose "any" for the object name. In the example below, replace posthog-s3-exportwith the bucket name you chose in the previous section

- Your config should now look like the following

- Click "Next" until you end up on the "Review Policy" page
- Give your policy a name and click "Create policy"
The final step is to create a new user and give them access to our bucket by attaching our newly created policy.
- Open IAM and navigate to "Users" on the left
- Click "Add Users"
- Specify a name and make sure to choose "Access key - Programmatic access"

- Click "Next"
- At the top, select "Attach existing policies directly"
- Search for the policy you just created and click the checkbox on the far left to attach it to this user

- Click "Next" until you reach the "Create user" button. Click that as well.
- Make sure to copy your "Access key" and "Secret access key". The latter will not be shown again.

Step 3: Add data to the bucket
For this section, we'll be using Airbyte. However, we accept any data in CSV or Parquet format, so if you already have data in S3 you can skip this section.
- Go to Airbyte and sign up for an account if you haven't already.
- Go to connections and click "New connection"
- Select a source. For this example, we'll grab data from Stripe, but you can use any of Airbyte's sources.
- Click "Set up a new destination"
- Select "S3" as the destination
- Fill in the "S3 Bucket Name", "S3 Bucket Region" with the name and region you created earlier.
- For "S3 Bucket Path", use airbyte.
- For the "Output Format", pick Parquet. You can use the default settings
- Under "Optional fields", you'll want to add the access key and secret from step 1.
- In the next step, pick the streams you want to fill. Given you'll manually need to create a table for each stream, we suggest being selective.
- Wait for the sync to finish

Step 4: Create the table in PostHog
- In PostHog, go to the "Data Warehouse" tab and click "New table"
- Fill in the table name.
- For the URL pattern, copy the URL from S3, up to the bucket name. Replace the file name with *, as Airbyte will split larges streams out into multiple files.
- For example: https://your-bucket.s3.amazonaws.com/airbyte/invoices/*
- For file format, select Parquet. Fill in the access key and secret key.
You'll want to repeat this step for each "stream" or folder that Airbyte created in your S3 bucket.

Step 5: Query the table.
Amazing! You can now query your new table.
Syncing
Once you add a source, you can see its status, sync frequency, and last successful run in the data warehouse settings page. You can also reload or delete sources here.
When you expand each source, you can see:
- Schema name
- Enable or disable syncing for that table
- Synced table name in PostHog
- Time the table was last synced

