CKAN extension to push critical error to external URLs (like Slack).
Youu'll requerie an external service to receive the messages. This service must be able to receive POST or GET requests.
Compatibility with core CKAN versions:
CKAN version | Compatible? |
---|---|
2.9 and earlier | not tested |
2.10 | Yes |
2.11 | Yes |
To install ckanext-push-errors:
pip install -e git+https://github.com/unckan/ckanext-push-errors.git@TAG-VERSION#egg=ckanext-superset
pip install -r https://raw.githubusercontent.com/unckan/ckanext-push-errors/refs/tags/TAG-VERSION/requirements.txt
Then add push_errors
to the ckan.plugins
setting in your CKAN config file.
IMPORTANT: Add the push_errors
plugin as the first one in the list to ensure that all errors are captured.
Available settings. Many of them can be formatted with context values:
ckanext.push_errors.url=http://myserver.com
: The URL to push the messageckanext.push_errors.method=POST
: The method to use (POST or GET only)ckanext.push_errors.headers='{"Authorization": "Token 123"}'
: A JSON string with the headers to sendckanext.push_errors.data:'{"message": "{message}"}'
: A JSON string with the data to sendckanext.push_errors.title="PUSH_ERROR v{push_errors_version} - CKAN {ckan_version}\n{now}\n\n"
: The title (first part) of the message
You can post all errors to a Slack channel. You'll need to create a webhook in Slack. Then use the following settings:
ckanext.push_errors.url=https://hooks.slack.com/services/T02XXXXXX/B061XXXXXX/GASXXXxxxXXXxxx
(something like this).ckanext.push_errors.method=POST
ckanext.push_errors.headers={}
ckanext.push_errors.data={"text": "{message}", "username": "CKAN PUSH ERRORS", "icon_url": "https://github.com/unckan/ckanext-push-errors/raw/main/icons/server-error.png"}
: Slack requires thetext
field to be present.
To create a webhook in Slack:
- Create a new channel if you want to send this notifications to a new channel. If not, you can use any existing channel.
- Good look with this incredible complex way to create a webhook: https://api.slack.com/messaging/webhooks
- Probably going to https://api.slack.com/apps/YOUR-APP-ID/incoming-webhooks URL will help you.
To run the tests, do:
pytest --ckan-ini=test.ini