Types and helper functions for Discord Interactions webhooks.
Available via pypi:
pip install discord-interactions
Use the InteractionType
and InteractionResponseType
enums to process and respond to webhooks.
Use verify_key
to check a request signature:
if verify_key(request.data, signature, timestamp, 'my_client_public_key'):
print('Signature is valid')
else:
print('Signature is invalid')
Use verify_key_decorator
to protect routes in a Flask app:
import os
from flask import Flask, request, jsonify
from discord_interactions import verify_key_decorator, InteractionType, InteractionResponseType
CLIENT_PUBLIC_KEY = os.getenv('CLIENT_PUBLIC_KEY')
app = Flask(__name__)
@app.route('/interactions', methods=['POST'])
@verify_key_decorator(CLIENT_PUBLIC_KEY)
def interactions():
if request.json['type'] == InteractionType.APPLICATION_COMMAND:
return jsonify({
'type': InteractionResponseType.CHANNEL_MESSAGE_WITH_SOURCE,
'data': {
'content': 'Hello world'
}
})
This module exports the following:
An enum of interaction types that can be POSTed to your webhook endpoint.
An enum of response types you may provide in reply to Discord's webhook.
An enum of flags you can set on your response data.
Verify a signed payload POSTed to your webhook endpoint.
Flask decorator that will verify request signatures and handle PING/PONG requests.