Webhook server to dynamically route Voys calls to on-call PagerDuty users.
Project description
python3-cyberfusion-pagerduty-voys-webhook
Webhook server to dynamically route Voys calls to on-call PagerDuty users.
This webhook server is intended to route phone calls (handled by VoIP provider Voys) to users that are on-call on PagerDuty - without having to keep both in sync manually.
When using the webhook offered by this program in your Voys dial plan (see instructions under 'Configure'), calls are routed to the phone number specified in the PagerDuty user's 'Notification Rules'.
If multiple PagerDuty users are on-call, calls are routed to a random user. If the chosen PagerDuty user has multiple phone numbers, a random one is chosen.
Install
PyPI
Run the following command to install the package from PyPI:
pip3 install python3-cyberfusion-pagerduty-voys-webhook
Debian
Run the following commands to build a Debian package:
mk-build-deps -i -t 'apt -o Debug::pkgProblemResolver=yes --no-install-recommends -y'
dpkg-buildpackage -us -uc
Configure
- Place your PagerDuty API key in
/etc/pagerduty-voys-webhook/api_key(regular text file). See instructions under 'Configure'. - Place a randomly generated secret key in
/etc/pagerduty-voys-webhook/secret_key(regular text file). When calling the webhook, this key must be specified - as a security measure. For example, you can generate a random secret usingopenssl:openssl rand -hex 32 - Place the escalation policy ID in
/etc/pagerduty-voys-webhook/escalation_policy_id(regular text file). Users to route calls to are retrieved from this escalation policy. For example, if you have a group of Customer Liaisons to route calls to, you can create a dedicated escalation policy for them.
Usage
Run
Manually
Run the app using an ASGI server such as Uvicorn.
systemd
systemctl start pagerduty-voys-webhook-server.service
Configure
Create PagerDuty API key
- Log in to PagerDuty.
- Navigate to Integrations -> API Access Keys.
- Click 'Create New API Key'.
- For 'Description', fill in a free-form description.
- Tick 'Read-only API Key'.
- Click 'Create Key'.
Add webhook in Voys Freedom
- Log in to Voys Freedom.
- Navigate to Admin -> Webhooks.
- Click 'Add'.
- For 'Name', fill in a free-form name.
- For 'Caller id forwarding', select 'Suppress (privacy)'. This program does not use it, and the fewer data one sends, the better.
- Set 'URL template' to: the URL on which this program runs +
/voys-webhook?secret_key=+ secret key (from/etc/pagerduty-voys-webhook/secret_key). For example:https://voys-webhook.example.com/voys-webhook?secret_key=r6cZPVkZdqujY6dME5uqDytK
Use webhook in dial plan
- Log in to Voys Freedom.
- Navigate to your dial plan.
- Click 'Edit dial plan'.
- Click 'add step'.
- Select your newly added webhook.
- In the 'HTTP and IVR success' branch, click 'Edit' next to 'Unfilled step'.
- Select 'Variable destination'.
Optionally, you can specify 'fallback' steps in the 'HTTP or IVR failed' branch. For example, if the specified secret key is invalid, or this program doesn't (properly) respond for any other reason.
For more information, see Voys' own documentation on https://help.voys.nl/integraties-koppelingen-webhooks/webhooks.
(Optional) IP-restrict webhook request
This program returns phone numbers, which might be considered confidential/sensitive.
Although this program requires a secret key for webhook calls, it's recommended to restrict requests to Voys' IP addresses.
Find Voys' outgoing IP addresses here: https://help.voys.nl/netwerk-trunk-videobellen-en-ata/firewall-instellen
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file python3_cyberfusion_pagerduty_voys_webhook-1.0.tar.gz.
File metadata
- Download URL: python3_cyberfusion_pagerduty_voys_webhook-1.0.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
038baf4db28a5b0faa226d793943ce705afd5de501306d0d64b3bf6a8a20e5d9
|
|
| MD5 |
d04466f2163cb322bf50f99fbc432e6f
|
|
| BLAKE2b-256 |
c67b208ea94a48fa5c2c8d9ce6112dba076b93469bbcf4b64775e70668397fdd
|
File details
Details for the file python3_cyberfusion_pagerduty_voys_webhook-1.0-py3-none-any.whl.
File metadata
- Download URL: python3_cyberfusion_pagerduty_voys_webhook-1.0-py3-none-any.whl
- Upload date:
- Size: 5.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
67a63263f291a59ab6206511847e3960640ce0954030a714be9c57dea56e4881
|
|
| MD5 |
c137c35f1d396decd53d8a5f7f687924
|
|
| BLAKE2b-256 |
6a229a4c4ef427003d777d8c44e04371505c33ab929737a863c3121e2e69debf
|