Source code for swh.webhooks.utils

# Copyright (C) 2023  The Software Heritage developers
# See the AUTHORS file at the top-level directory of this distribution
# License: GNU General Public License version 3, or any later version
# See top-level LICENSE file for more information

from datetime import datetime
from typing import Any, Dict, Union

from svix.webhooks import Webhook, WebhookVerificationError


[docs] def get_verified_webhook_payload( request_data: Union[bytes, str], request_headers: Dict[str, str], secret: str ) -> Dict[str, Any]: """Verify the authenticity of a webhook message and returns JSON payload. Args: request_data: Body of received POST request request_hedaers: Headers of received POST request Returns: JSON payload as a dict Raises: ValueError: Webhook content verification failed """ webhook = Webhook(secret) try: return webhook.verify(request_data, request_headers) except WebhookVerificationError: raise ValueError("Webhook payload verification failed")
[docs] def sign_webhook_payload( payload: str, timestamp: datetime, msg_id: str, secret: str ) -> str: """Generate webhook payload signature. Args: payload: JSON representation of payload timestamp: webhook message timestamp msg_id: webhook message identifier secret: key used to sign and verify payload Returns: webhook payload signature """ return Webhook(secret).sign(msg_id, timestamp, payload)
[docs] def format_docstring(**substitutions): def decorator(f): f.__doc__ = f.__doc__.format(**substitutions) return f return decorator