notify-api-520 persist the provider response even for successful sms messages

This commit is contained in:
Kenneth Kehl
2023-09-29 13:39:10 -07:00
parent f81f048b5b
commit 8af7a5552f
4 changed files with 20 additions and 17 deletions

View File

@@ -60,7 +60,9 @@ def check_sms_delivery_receipt(self, message_id, notification_id, sent_at):
# if status is not success or failure the client raised an exception and this method will retry
if status == NOTIFICATION_DELIVERED:
sanitize_successful_notification_by_id(notification_id)
sanitize_successful_notification_by_id(
notification_id, provider_response=provider_response
)
current_app.logger.info(
f"Sanitized notification {notification_id} that was successfully delivered"
)

View File

@@ -103,7 +103,7 @@ class AwsCloudwatchClient(Client):
return "success", message["delivery"]["providerResponse"]
log_group_name = (
f"sns/{region}/{account_number}/DirectPublishToPhoneNumber/Failure"
f"sns/{region}/{account_number[4]}/DirectPublishToPhoneNumber/Failure"
)
# current_app.logger.info(f"Failure log group name: {log_group_name}")
all_failed_events = self._get_log(filter_pattern, log_group_name, created_at)

View File

@@ -139,7 +139,11 @@ def update_notification_status_by_id(
notification.provider_response = provider_response
if not notification.sent_by and sent_by:
notification.sent_by = sent_by
return _update_notification_status(notification=notification, status=status)
return _update_notification_status(
notification=notification,
status=status,
provider_response=notification.provider_response,
)
@autocommit
@@ -288,24 +292,15 @@ def _filter_query(query, filter_dict=None):
return query
@autocommit
def sanitize_successful_notification_by_id(notification_id):
# TODO what to do for international?
# phone_prefix = '1'
# Notification.query.filter(
# Notification.id.in_([notification_id]),
# ).update(
# {'to': phone_prefix, 'normalised_to': phone_prefix, 'status': 'delivered'}
# )
# db.session.commit()
def sanitize_successful_notification_by_id(notification_id, provider_response):
update_query = """
update notifications set notification_status='delivered', "to"='1', normalised_to='1'
update notifications set provider_response=:response, notification_status='delivered', "to"='1', normalised_to='1'
where id=:notification_id
"""
input_params = {"notification_id": notification_id}
input_params = {"notification_id": notification_id, "response": provider_response}
db.session.execute(update_query, input_params)
db.session.commit()
@autocommit

View File

@@ -109,10 +109,16 @@ def test_should_be_able_to_sanitize_successful_notification(
assert Notification.query.get(notification.id).status == "sending"
with freeze_time("2000-01-02 12:00:00"):
sanitize_successful_notification_by_id(notification.id)
sanitize_successful_notification_by_id(
notification.id, provider_response="Don't know what happened"
)
assert Notification.query.get(notification.id).status == "delivered"
assert Notification.query.get(notification.id).normalised_to == "1"
assert Notification.query.get(notification.id).to == "1"
assert (
Notification.query.get(notification.id).provider_response
== "Don't know what happened"
)
def test_should_not_update_status_by_id_if_not_sending_and_does_not_update_job(