2017-12-01 16:15:21 +00:00
|
|
|
import json
|
2018-02-06 09:35:33 +00:00
|
|
|
|
2018-03-19 17:38:20 +00:00
|
|
|
from flask import current_app
|
2021-03-10 13:55:06 +00:00
|
|
|
from requests import HTTPError, RequestException, request
|
2018-03-19 17:38:20 +00:00
|
|
|
|
2020-12-18 17:39:35 +00:00
|
|
|
from app import encryption, notify_celery
|
2017-12-01 16:15:21 +00:00
|
|
|
from app.config import QueueNames
|
2020-12-18 17:39:35 +00:00
|
|
|
from app.utils import DATETIME_FORMAT
|
2017-12-01 16:15:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@notify_celery.task(bind=True, name="send-delivery-status", max_retries=5, default_retry_delay=300)
|
2018-07-18 17:03:16 +01:00
|
|
|
def send_delivery_status_to_service(
|
|
|
|
|
self, notification_id, encrypted_status_update
|
|
|
|
|
):
|
|
|
|
|
status_update = encryption.decrypt(encrypted_status_update)
|
|
|
|
|
|
|
|
|
|
data = {
|
2018-07-20 11:22:38 +01:00
|
|
|
"id": str(notification_id),
|
2018-07-18 17:03:16 +01:00
|
|
|
"reference": status_update['notification_client_reference'],
|
|
|
|
|
"to": status_update['notification_to'],
|
|
|
|
|
"status": status_update['notification_status'],
|
|
|
|
|
"created_at": status_update['notification_created_at'],
|
|
|
|
|
"completed_at": status_update['notification_updated_at'],
|
|
|
|
|
"sent_at": status_update['notification_sent_at'],
|
2021-03-18 17:08:44 +00:00
|
|
|
"notification_type": status_update['notification_type'],
|
|
|
|
|
"template_id": status_update['template_id'],
|
|
|
|
|
"template_version": status_update['template_version']
|
2018-07-18 17:03:16 +01:00
|
|
|
}
|
2021-03-18 15:04:23 +00:00
|
|
|
|
2018-07-18 17:03:16 +01:00
|
|
|
_send_data_to_service_callback_api(
|
|
|
|
|
self,
|
|
|
|
|
data,
|
|
|
|
|
status_update['service_callback_api_url'],
|
|
|
|
|
status_update['service_callback_api_bearer_token'],
|
|
|
|
|
'send_delivery_status_to_service'
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@notify_celery.task(bind=True, name="send-complaint", max_retries=5, default_retry_delay=300)
|
|
|
|
|
def send_complaint_to_service(self, complaint_data):
|
|
|
|
|
complaint = encryption.decrypt(complaint_data)
|
|
|
|
|
|
|
|
|
|
data = {
|
|
|
|
|
"notification_id": complaint['notification_id'],
|
|
|
|
|
"complaint_id": complaint['complaint_id'],
|
|
|
|
|
"reference": complaint['reference'],
|
|
|
|
|
"to": complaint['to'],
|
|
|
|
|
"complaint_date": complaint['complaint_date']
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_send_data_to_service_callback_api(
|
|
|
|
|
self,
|
|
|
|
|
data,
|
|
|
|
|
complaint['service_callback_api_url'],
|
|
|
|
|
complaint['service_callback_api_bearer_token'],
|
|
|
|
|
'send_complaint_to_service'
|
|
|
|
|
)
|
2018-02-12 15:44:05 +00:00
|
|
|
|
2017-12-01 16:15:21 +00:00
|
|
|
|
2018-07-18 17:03:16 +01:00
|
|
|
def _send_data_to_service_callback_api(self, data, service_callback_url, token, function_name):
|
2018-07-20 11:22:38 +01:00
|
|
|
notification_id = (data["notification_id"] if "notification_id" in data else data["id"])
|
2018-07-18 17:03:16 +01:00
|
|
|
try:
|
2017-12-01 16:15:21 +00:00
|
|
|
response = request(
|
|
|
|
|
method="POST",
|
2018-07-18 17:03:16 +01:00
|
|
|
url=service_callback_url,
|
2017-12-01 16:15:21 +00:00
|
|
|
data=json.dumps(data),
|
|
|
|
|
headers={
|
|
|
|
|
'Content-Type': 'application/json',
|
2018-07-18 17:03:16 +01:00
|
|
|
'Authorization': 'Bearer {}'.format(token)
|
2017-12-01 16:15:21 +00:00
|
|
|
},
|
|
|
|
|
timeout=60
|
|
|
|
|
)
|
2018-07-18 17:03:16 +01:00
|
|
|
current_app.logger.info('{} sending {} to {}, response {}'.format(
|
|
|
|
|
function_name,
|
2017-12-01 16:15:21 +00:00
|
|
|
notification_id,
|
2018-07-18 17:03:16 +01:00
|
|
|
service_callback_url,
|
2017-12-01 16:15:21 +00:00
|
|
|
response.status_code
|
|
|
|
|
))
|
|
|
|
|
response.raise_for_status()
|
|
|
|
|
except RequestException as e:
|
|
|
|
|
current_app.logger.warning(
|
2020-11-13 16:41:48 +00:00
|
|
|
"{} request failed for notification_id: {} and url: {}. exception: {}".format(
|
2018-07-18 17:03:16 +01:00
|
|
|
function_name,
|
2017-12-01 16:15:21 +00:00
|
|
|
notification_id,
|
2018-07-18 17:03:16 +01:00
|
|
|
service_callback_url,
|
2017-12-01 16:15:21 +00:00
|
|
|
e
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
if not isinstance(e, HTTPError) or e.response.status_code >= 500:
|
2018-03-19 17:38:20 +00:00
|
|
|
try:
|
2021-02-04 11:53:22 +00:00
|
|
|
self.retry(queue=QueueNames.CALLBACKS_RETRY)
|
2018-03-19 17:38:20 +00:00
|
|
|
except self.MaxRetriesExceededError:
|
2019-06-27 14:55:10 +01:00
|
|
|
current_app.logger.warning(
|
2018-10-24 11:24:53 +01:00
|
|
|
"Retry: {} has retried the max num of times for callback url {} and notification_id: {}".format(
|
2018-10-22 11:11:07 +01:00
|
|
|
function_name,
|
2018-10-24 11:24:53 +01:00
|
|
|
service_callback_url,
|
2018-10-22 11:11:07 +01:00
|
|
|
notification_id
|
|
|
|
|
)
|
2018-03-19 17:38:20 +00:00
|
|
|
)
|
2020-11-13 16:41:48 +00:00
|
|
|
else:
|
|
|
|
|
current_app.logger.warning(
|
|
|
|
|
"{} callback is not being retried for notification_id: {} and url: {}. exception: {}".format(
|
|
|
|
|
function_name,
|
|
|
|
|
notification_id,
|
|
|
|
|
service_callback_url,
|
|
|
|
|
e
|
|
|
|
|
)
|
|
|
|
|
)
|
2018-03-16 14:00:49 +00:00
|
|
|
|
|
|
|
|
|
2018-07-18 17:03:16 +01:00
|
|
|
def create_delivery_status_callback_data(notification, service_callback_api):
|
2018-03-16 14:00:49 +00:00
|
|
|
data = {
|
|
|
|
|
"notification_id": str(notification.id),
|
|
|
|
|
"notification_client_reference": notification.client_reference,
|
|
|
|
|
"notification_to": notification.to,
|
|
|
|
|
"notification_status": notification.status,
|
|
|
|
|
"notification_created_at": notification.created_at.strftime(DATETIME_FORMAT),
|
|
|
|
|
"notification_updated_at":
|
|
|
|
|
notification.updated_at.strftime(DATETIME_FORMAT) if notification.updated_at else None,
|
|
|
|
|
"notification_sent_at": notification.sent_at.strftime(DATETIME_FORMAT) if notification.sent_at else None,
|
|
|
|
|
"notification_type": notification.notification_type,
|
|
|
|
|
"service_callback_api_url": service_callback_api.url,
|
|
|
|
|
"service_callback_api_bearer_token": service_callback_api.bearer_token,
|
2021-03-18 15:04:23 +00:00
|
|
|
"template_id": str(notification.template_id),
|
|
|
|
|
"template_version": notification.template_version,
|
2018-03-16 14:00:49 +00:00
|
|
|
}
|
|
|
|
|
return encryption.encrypt(data)
|
2018-07-18 17:03:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def create_complaint_callback_data(complaint, notification, service_callback_api, recipient):
|
|
|
|
|
data = {
|
|
|
|
|
"complaint_id": str(complaint.id),
|
|
|
|
|
"notification_id": str(notification.id),
|
|
|
|
|
"reference": notification.client_reference,
|
|
|
|
|
"to": recipient,
|
|
|
|
|
"complaint_date": complaint.complaint_date.strftime(DATETIME_FORMAT),
|
|
|
|
|
"service_callback_api_url": service_callback_api.url,
|
|
|
|
|
"service_callback_api_bearer_token": service_callback_api.bearer_token,
|
|
|
|
|
}
|
|
|
|
|
return encryption.encrypt(data)
|