Source code for contentful_management.webhook_call

from datetime import datetime
import dateutil.parser
from .resource import Resource


"""
contentful_management.webhook_call
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

This module implements the WebhookCall class.

API reference: https://www.contentful.com/developers/docs/references/content-management-api/#/reference/webhook-calls/webhook-call-overview

:copyright: (c) 2018 by Contentful GmbH.
:license: MIT, see LICENSE for more details.
"""


[docs]class WebhookCall(Resource): """ API reference: https://www.contentful.com/developers/docs/references/content-management-api/#/reference/webhook-calls/webhook-call-overview """ def __init__(self, item, **kwargs): super(WebhookCall, self).__init__(item, **kwargs) self.request = item.get('request', {}) self.response = item.get('response', {}) self.status_code = item.get('statusCode', -1) self.errors = item.get('errors', []) self.event_type = item.get('eventType', '') self.url = item.get('url', '') try: self.request_at = dateutil.parser.parse(item.get('requestAt', '')) except Exception: self.request_at = '' try: self.response_at = dateutil.parser.parse(item.get('responseAt', '')) except Exception: self.response_at = ''
[docs] @classmethod def base_url(klass, space_id, webhook_id, resource_id=None): """ Returns the URI for the webhook call. """ return "spaces/{0}/webhooks/{1}/calls/{2}".format( space_id, webhook_id, resource_id if resource_id is not None else '' )
def __repr__(self): return "<WebhookCall[{0}] id='{1}' url='{2}' request_at='{3}' response_at='{4}'>".format( self.status_code, self.sys.get('id', ''), self.url, self.request_at.isoformat() if isinstance(self.request_at, datetime) else 'N/A', self.response_at.isoformat() if isinstance(self.request_at, datetime) else 'N/A' )