This SDK provides convenient utilities for verifying FormSG webhooks and decrypting submissions in Python and Flask or Django.
pip install formsgThe SDK provides two main utility functions for handling FormSG webhook:
-
webhook_uri: str, signature_header: str, signature_expiry_seconds: float = 60) -> Mapping[str, Any]verifies that the incoming webhook's signature is valid based on the FormSG production public key. It raises anacl.exceptions.BadSignatureErrorif the signature is invalid. The signature header is usually found in theX-FormSG-Signatureheader. Details on how the signature is constructed can be found here. -
decrypt_content(body: Mapping[str, Any], secret_key: str) -> Mapping[str, Any]will decrypt the encrypted content using the given Base-64 encoded secret key.bodyis expected to be a dictionary-like object. -
decrypt_attachment(body: Mapping[str, Any], field_id: str, secret_key: str) -> byteswill download and decrypt the encrypted attachment for afieldand using the given Base-64 encoded secret key.bodyis expected to be a dictionary-like object.
For convenience, the SDK implements a decrypt_django_request and decrypt_flask_request which returns the decrypted FormSG content from a Django/Flask request object directly.
from formsg.flask import decrypt_flask_request
from flask import Flask
from flask import jsonify
from flask import request
app = Flask(__name__)
@app.route('/formsg_webhook', methods=['POST'])
def formsg_webhook():
decrypted = decrypt_flask_request(
request,
secret_key='xxx',
webhook_uri='https://xxx.ngrok.io/formsg_webhook', # we use ngrok to test our webhooks locally
)
return jsonify(decrypted)
#end def
if __name__ == '__main__':
app.run(debug=True)
#end ifIf you find any issues or would like to contribute improvements, please feel free to raise them in this repository directly.