Configure Policy Webhooks
What is a Policy webhook?
A Policy webhook is an HTTPS Callback that you've defined on a Policy to call an external REST API endpoint before or after a Privacy Request executes.
You can define as many webhooks as you'd like.  Webhooks can be one_way, where we will just ping your API and move on,
or two_way, where we will wait for a response. Any derived_identities returned from a two_way webhook will be saved
and can be used to locate other user information.  For example, a webhook might take a known email identity and
use that to find a phone_number derived_identity.
Another use case for a Policy Webhook might be to log a user out of your mobile app after you've cleared
their data from your system.  In this case, you'd create a Policy and a ConnectionConfig to describe the URL to hit
to clear the cache. You'd then create a one-way PolicyPostWebhook to run after your PrivacyRequest executes.
Configuration
Big picture, you will define an https ConnectionConfig that contains the details to make a request to your API endpoint.
You will then define a PolicyPreWebhook or a PolicyPostWebhookfor a specific Policy using that ConnectionConfig.
Create an HTTPS ConnectionConfig
The information that describes how to connect to your API endpoint lives on a ConnectionConfig. We also use
ConnectionConfigs to connect to databases like PostgreSQL and MongoDB.  This same construct can help us store
how to connect to an external API endpoint.
For more information on ConnectionConfigs, see how to Create a ConnectionConfig.
| PATCH /v1/connection | |
|---|---|
| 1 2 3 4 5 6 7 8 |  | 
Adding ConnectionConfig secrets
The secret details needed to talk to your API endpoint are defined by making a PUT to the ConnectionConfig Secrets endpoint:
These credentials are stored encrypted in the fidesops app database.
See API docs on how to Set a ConnectionConfig's Secrets.
| PUT /v1/connection/test_webhook_connection_config | |
|---|---|
| 1 2 3 4 |  | 
Note that the authorization secret specified here will be added directly to an authorization header when fidesops later makes a call to the configured webhook:
| 1 |  | 
Define pre-execution or post-execution webhooks
After you've defined a ConnectionConfig, you can create lists of webhooks to run before (PolicyPreWebhooks)
or after (PolicyPostWebhooks) a PrivacyRequest is executed.
If you are defining PolicyPreWebhooks, all desired PolicyPreWebhooks should be included in the request body in the desired order. Any PolicyPreWebhooks on the Policy not included in the request, will be removed from the Policy. The same applies for PolicyPostWebhooks.
To update your list of PolicyPreWebhooks:
| PUT /policy/{policy_key}/webhook/pre_execution | |
|---|---|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 |  | 
This creates two webhooks that are run sequentially for the Policy before a PrivacyRequest runs.
Similarly, to update your list of Post-Execution webhooks on a Policy:
| 1 |  | 
See API docs for more information on how to Update PolicyPreWebhooks and how to Update PolicyPostWebhooks.
Update a single webhook
To update a single PolicyPreWebhook or PolicyPostWebhook, send a PATCH request to update selected attributes. Note that updates to order can likewise update the order of related webhooks.
The following example will update the PolicyPreWebhook with key webhook_hook to be two_way instead of
one_way and will update its order from 0 to 1.  Because we've defined two PolicyPreWebhooks, this causes the
webhook at position 1 to move to position 0.
| PATCH /policy/{policy_key}/webhook/pre-execution/wake_up_snowflake_db | |
|---|---|
| 1 2 3 4 |  | 
Because this PATCH request updated the order of other webhooks, a reordered summary is included under the
new_order attribute:
| Response | |
|---|---|
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |  | 
Similarly, to update your a Post-Execution webhook on a Policy:
| 1 |  | 
See API docs for more information on how to PATCH a PolicyPreWebhook and how to PATCH a PolicyPostWebhook.
Policy Webhook request format
Before and after running access or erasure requests, fidesops will send requests to any configured webhooks in sequential order with the following request body:
| POST {user-defined URL} | |
|---|---|
| 1 2 3 4 5 6 7 8 9 |  | 
Most of these attributes were configured by you: the direction, the callback_type ("pre" for PolicyPreWebhooks that will run
before PrivacyRequest execution or "post" for PolicyPostWebhooks that will run after PrivacyRequestExecution).
Known identities are also embedded in the request.
For two-way PolicyPreWebhooks, we include specific headers in case you need to pause PrivacyRequest
execution while you take care of additional processing on your end.
| 1 2 3 4 |  | 
To resume, you should send a request back to the reply-to URL with the reply-to-token.  The reply-to-token will
expire when your redis cache expires: config.redis.default_ttl_seconds (Fidesops uses the redis cache to temporarily
 store identity data).  At this point, your PrivacyRequest will be given an error status, and you would have to resubmit
the PrivacyRequest.
Webhook response format
Your webhook should respond immediately. If more processing time is needed, either make sure it is configured as a
one-way webhook, or reply with halt=True if you want to pause execution and wait for your processing to finish.
Note that only PolicyPreWebhooks can pause execution.
We don't expect a response from one-way webhooks, but two-way webhooks should respond with the following:
| 1 2 3 4 5 6 7 |  | 
Derived identity is optional: a returned email or phone number will replace currently known emails or phone numbers.
Resuming request execution
If your webhook needed more processing time, once completed, send a request to the reply-to URL
given to you in the original request header with the reply-to-token auth token.
| POST privacy_request/{privacy-request-id}/resume | |
|---|---|
| 1 2 3 4 5 6 |  | 
If there are no derived identities, an empty {} request body will suffice.
The reply-to-token is a JWE containing the current webhook id, scopes to access the callback endpoint,
and the datetime the token is issued.  We unpack this and resume the privacy request execution after the
specified webhook. The reply-to-token expires after a set amount of time, specified by the config.execution.privacy_request_delay_timeout config variable. Once the redis cache expires, fidesops no longer has the original identity data and the privacy request should be resubmitted.