Skip to main content

Flask extension for github-webhooks

Project description

Flask-Github-Webhook

Build Status Coverage Status

Flask-Github-Webhook adds extension support for GitHub webhooks to Flask. This extension primarily extends the python-github-webhook project by making the Flask Extension Pattern available as an initialization option.

Initialization

The Github-Webhook Extension may be initialized directly or as an extension:

Direct Setup

from flask import Flask
from flask_github_webhook import GithubWebhook

app = Flask(__name__)
webhook = GithubWebhook(app)

Extension Setup

from flask import Flask

# The extension may be initialized from anywhere in the project, including
# inside this file, by calling GithubWebhook()
from .extension import WEBHOOK

app = Flask(__name__)
WEBHOOK.init_app(app)

Usage

The extension may be used in the same manner as python-github-webhook.

from .extension import WEBHOOK

@WEBHOOK.hook()
def push_handler(data):
    print('Received the following PUSH event:{}'.format(data))

@WEBHOOK.hook(event_type='pull_request')
def pullrequest_handler(data):
    print('Received the following PULL-REQUEST event:{}'.format(data))

Versions

Version 0.1.x supports ^2.7 and ^3.4.

Versions 0.2+ supports ^3.6.7. This is primarily due to Python version constraints on the package and test tools. For instance, here are some dependencies and their supported Python versions: poetry=^3.4, coveralls=^3.5, pre-commit=^3.6.1, and pytest=^3.6. Due to these constraints, the decision was made to drop official support for 2.7, 3.4 and 3.5. However, flask-github-webhook=^0.1.x should work for older Python versions.

Configuration

The extension has the same configurations available as the python-github-webhook package. However, unlike referenced package, this extension reads those configurations from the Flask application, not initialization arguments. The values below should be configured in the Flask application (app.config) prior to initializing the extension.

GITHUB_WEBHOOK_ENDPOINT

This setting declares the route that all webhook event handlers will use. If left unset, the setting will default to the endpoint as declared in python-github-webook. As of this writing, the default endpoint is /postreceive.

GITHUB_WEBHOOK_SECRET

If provided, this setting's value should match the secret set in the GitHub repository from which this extension will receive webhooks.

Contributing

Contributions are welcomed! If you would like to improve or modify Flask-Github-Webhook, please follow these steps:

  1. Fork this repository.
  2. Make your changes and create a pull request.
  3. Ensure that all status checks are passing.

Author & License

This package is released under an open source MIT License. Flask-Github-Webhook was originally written by Shawn Wallis.

References

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

flask-github-webhook-0.2.0.tar.gz (4.1 kB view details)

Uploaded Source

Built Distribution

flask_github_webhook-0.2.0-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file flask-github-webhook-0.2.0.tar.gz.

File metadata

  • Download URL: flask-github-webhook-0.2.0.tar.gz
  • Upload date:
  • Size: 4.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.3 Linux/5.3.0-1032-azure

File hashes

Hashes for flask-github-webhook-0.2.0.tar.gz
Algorithm Hash digest
SHA256 dd4579103bde71f520b82f57dfc34fdf2359b340b69b177aa908b9b22e3876dc
MD5 9deac0a00457991f3d4187a8e51b693f
BLAKE2b-256 54f61f09502db90c24aad0c6d2d193f8c3b91f3a3660df1ad23fcc3db69aeebd

See more details on using hashes here.

File details

Details for the file flask_github_webhook-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for flask_github_webhook-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8cfbb569f03b5a8bf5edd2681424ef8c3539838f9effadcd1383dbfa45a1324b
MD5 c098e715abf78385a1fac5b9fe5b4154
BLAKE2b-256 b3eeecaa06fce5f34e6a5e9462ba27fb9c0c4e5cd1d4d3f8e5cd6f303799bb89

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page