2016-05-31 16:55:26 +01:00
|
|
|
import json
|
|
|
|
|
|
|
|
|
|
from flask import current_app
|
|
|
|
|
from app import notify_celery
|
|
|
|
|
from requests import request, RequestException, HTTPError
|
|
|
|
|
|
2016-06-29 11:50:54 +01:00
|
|
|
from app.models import SMS_TYPE
|
|
|
|
|
|
2017-01-20 13:17:53 +00:00
|
|
|
temp_fail = "7700900003"
|
|
|
|
|
perm_fail = "7700900002"
|
|
|
|
|
delivered = "7700900001"
|
2016-05-31 16:55:26 +01:00
|
|
|
|
|
|
|
|
delivered_email = "delivered@simulator.notify"
|
|
|
|
|
perm_fail_email = "perm-fail@simulator.notify"
|
|
|
|
|
temp_fail_email = "temp-fail@simulator.notify"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def send_sms_response(provider, reference, to):
|
|
|
|
|
if provider == "mmg":
|
|
|
|
|
body = mmg_callback(reference, to)
|
|
|
|
|
headers = {"Content-type": "application/json"}
|
2016-06-01 16:57:57 +01:00
|
|
|
else:
|
2016-06-09 14:14:27 +01:00
|
|
|
headers = {"Content-type": "application/x-www-form-urlencoded"}
|
2016-05-31 16:55:26 +01:00
|
|
|
body = firetext_callback(reference, to)
|
2017-01-20 13:17:53 +00:00
|
|
|
# to simulate getting a temporary_failure from firetext
|
|
|
|
|
# we need to send a pending status updated then a permanent-failure
|
|
|
|
|
if body['status'] == '2': # pending status
|
|
|
|
|
make_request(SMS_TYPE, provider, body, headers)
|
2017-01-23 10:43:33 +00:00
|
|
|
# 1 is a declined status for firetext, will result in a temp-failure
|
|
|
|
|
body = {'mobile': to,
|
|
|
|
|
'status': "1",
|
|
|
|
|
'time': '2016-03-10 14:17:00',
|
|
|
|
|
'reference': reference
|
|
|
|
|
}
|
2017-01-20 13:17:53 +00:00
|
|
|
|
2016-06-29 11:50:54 +01:00
|
|
|
make_request(SMS_TYPE, provider, body, headers)
|
2016-05-31 16:55:26 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def send_email_response(provider, reference, to):
|
|
|
|
|
if to == perm_fail_email:
|
|
|
|
|
body = ses_hard_bounce_callback(reference)
|
|
|
|
|
elif to == temp_fail_email:
|
|
|
|
|
body = ses_soft_bounce_callback(reference)
|
|
|
|
|
else:
|
|
|
|
|
body = ses_notification_callback(reference)
|
|
|
|
|
|
|
|
|
|
make_request('email', provider, body, headers={"Content-type": "application/json"})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def make_request(notification_type, provider, data, headers):
|
|
|
|
|
api_call = "{}/notifications/{}/{}".format(current_app.config["API_HOST_NAME"], notification_type, provider)
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
response = request(
|
|
|
|
|
"POST",
|
|
|
|
|
api_call,
|
|
|
|
|
headers=headers,
|
|
|
|
|
data=data
|
|
|
|
|
)
|
|
|
|
|
response.raise_for_status()
|
|
|
|
|
except RequestException as e:
|
|
|
|
|
api_error = HTTPError(e)
|
|
|
|
|
current_app.logger.error(
|
|
|
|
|
"API {} request on {} failed with {}".format(
|
|
|
|
|
"POST",
|
|
|
|
|
api_call,
|
|
|
|
|
api_error.response
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
raise api_error
|
|
|
|
|
finally:
|
|
|
|
|
current_app.logger.info("Mocked provider callback request finished")
|
|
|
|
|
return response.json()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def mmg_callback(notification_id, to):
|
|
|
|
|
"""
|
|
|
|
|
status: 3 - delivered
|
|
|
|
|
status: 4 - expired (temp failure)
|
|
|
|
|
status: 5 - rejected (perm failure)
|
|
|
|
|
"""
|
|
|
|
|
|
2017-01-20 13:17:53 +00:00
|
|
|
if to.strip().endswith(temp_fail):
|
2016-05-31 16:55:26 +01:00
|
|
|
status = "4"
|
2017-01-20 13:17:53 +00:00
|
|
|
elif to.strip().endswith(perm_fail):
|
2016-05-31 16:55:26 +01:00
|
|
|
status = "5"
|
|
|
|
|
else:
|
|
|
|
|
status = "3"
|
|
|
|
|
|
|
|
|
|
return json.dumps({"reference": "mmg_reference",
|
|
|
|
|
"CID": str(notification_id),
|
|
|
|
|
"MSISDN": to,
|
|
|
|
|
"status": status,
|
|
|
|
|
"deliverytime": "2016-04-05 16:01:07"})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def firetext_callback(notification_id, to):
|
|
|
|
|
"""
|
|
|
|
|
status: 0 - delivered
|
|
|
|
|
status: 1 - perm failure
|
|
|
|
|
"""
|
2017-01-20 13:17:53 +00:00
|
|
|
if to.strip().endswith(perm_fail):
|
2016-05-31 16:55:26 +01:00
|
|
|
status = "1"
|
2017-01-20 13:17:53 +00:00
|
|
|
elif to.strip().endswith(temp_fail):
|
|
|
|
|
status = "2"
|
2016-05-31 16:55:26 +01:00
|
|
|
else:
|
|
|
|
|
status = "0"
|
2016-06-09 14:14:27 +01:00
|
|
|
return {
|
|
|
|
|
'mobile': to,
|
|
|
|
|
'status': status,
|
|
|
|
|
'time': '2016-03-10 14:17:00',
|
|
|
|
|
'reference': notification_id
|
|
|
|
|
}
|
2016-05-31 16:55:26 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def ses_notification_callback(reference):
|
2016-06-01 16:57:57 +01:00
|
|
|
return '{ "Type" : "Notification", "MessageId" : "%s", "TopicArn" : "arn:aws:sns:eu-west-1:123456789012:testing", "Message" : "{\\"notificationType\\":\\"Delivery\\",\\"mail\\":{\\"timestamp\\":\\"2016-03-14T12:35:25.909Z\\",\\"source\\":\\"test@test-domain.com\\",\\"sourceArn\\":\\"arn:aws:ses:eu-west-1:123456789012:identity/testing-notify\\",\\"sendingAccountId\\":\\"123456789012\\",\\"messageId\\":\\"%s\\",\\"destination\\":[\\"testing@digital.cabinet-office.gov.uk\\"]},\\"delivery\\":{\\"timestamp\\":\\"2016-03-14T12:35:26.567Z\\",\\"processingTimeMillis\\":658,\\"recipients\\":[\\"testing@digital.cabinet-office.gov.uk\\"],\\"smtpResponse\\":\\"250 2.0.0 OK 1457958926 uo5si26480932wjc.221 - gsmtp\\",\\"reportingMTA\\":\\"a6-238.smtp-out.eu-west-1.amazonses.com\\"}}", "Timestamp" : "2016-03-14T12:35:26.665Z", "SignatureVersion" : "1", "Signature" : "X8d7eTAOZ6wlnrdVVPYanrAlsX0SMPfOzhoTEBnQqYkrNWTqQY91C0f3bxtPdUhUtOowyPAOkTQ4KnZuzphfhVb2p1MyVYMxNKcBFB05/qaCX99+92fjw4x9LeUOwyGwMv5F0Vkfi5qZCcEw69uVrhYLVSTFTrzi/yCtru+yFULMQ6UhbY09GwiP6hjxZMVr8aROQy5lLHglqQzOuSZ4KeD85JjifHdKzlx8jjQ+uj+FLzHXPMAPmPU1JK9kpoHZ1oPshAFgPDpphJe+HwcJ8ezmk+3AEUr3wWli3xF+49y8Z2anASSVp6YI2YP95UT8Rlh3qT3T+V9V8rbSVislxA==", "SigningCertURL" : "https://sns.eu-west-1.amazonaws.com/SimpleNotificationService-bb750dd426d95ee9390147a5624348ee.pem", "UnsubscribeURL" : "https://sns.eu-west-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:eu-west-1:302763885840:preview-emails:d6aad3ef-83d6-4cf3-a470-54e2e75916da"}' % (reference, reference) # noqa
|
2016-05-31 16:55:26 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def ses_hard_bounce_callback(reference):
|
2016-06-01 16:57:57 +01:00
|
|
|
return '{ "Type" : "Notification", "MessageId" : "%s", "TopicArn" : "arn:aws:sns:eu-west-1:123456789012:testing", "Message" : "{\\"notificationType\\":\\"Bounce\\",\\"bounce\\":{\\"bounceType\\":\\"Permanent\\",\\"bounceSubType\\":\\"General\\"}, \\"mail\\":{\\"messageId\\":\\"%s\\",\\"timestamp\\":\\"2016-03-14T12:35:25.909Z\\",\\"source\\":\\"test@test-domain.com\\",\\"sourceArn\\":\\"arn:aws:ses:eu-west-1:123456789012:identity/testing-notify\\",\\"sendingAccountId\\":\\"123456789012\\",\\"destination\\":[\\"testing@digital.cabinet-office.gov.uk\\"]},\\"delivery\\":{\\"timestamp\\":\\"2016-03-14T12:35:26.567Z\\",\\"processingTimeMillis\\":658,\\"recipients\\":[\\"testing@digital.cabinet-office.gov.uk\\"],\\"smtpResponse\\":\\"250 2.0.0 OK 1457958926 uo5si26480932wjc.221 - gsmtp\\",\\"reportingMTA\\":\\"a6-238.smtp-out.eu-west-1.amazonses.com\\"}}", "Timestamp" : "2016-03-14T12:35:26.665Z", "SignatureVersion" : "1", "Signature" : "X8d7eTAOZ6wlnrdVVPYanrAlsX0SMPfOzhoTEBnQqYkrNWTqQY91C0f3bxtPdUhUtOowyPAOkTQ4KnZuzphfhVb2p1MyVYMxNKcBFB05/qaCX99+92fjw4x9LeUOwyGwMv5F0Vkfi5qZCcEw69uVrhYLVSTFTrzi/yCtru+yFULMQ6UhbY09GwiP6hjxZMVr8aROQy5lLHglqQzOuSZ4KeD85JjifHdKzlx8jjQ+uj+FLzHXPMAPmPU1JK9kpoHZ1oPshAFgPDpphJe+HwcJ8ezmk+3AEUr3wWli3xF+49y8Z2anASSVp6YI2YP95UT8Rlh3qT3T+V9V8rbSVislxA==", "SigningCertURL" : "https://sns.eu-west-1.amazonaws.com/SimpleNotificationService-bb750dd426d95ee9390147a5624348ee.pem", "UnsubscribeURL" : "https://sns.eu-west-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:eu-west-1:302763885840:preview-emails:d6aad3ef-83d6-4cf3-a470-54e2e75916da"}' % (reference, reference) # noqa
|
2016-05-31 16:55:26 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def ses_soft_bounce_callback(reference):
|
2016-06-01 16:57:57 +01:00
|
|
|
return '{ "Type" : "Notification", "MessageId" : "%s", "TopicArn" : "arn:aws:sns:eu-west-1:123456789012:testing", "Message" : "{\\"notificationType\\":\\"Bounce\\",\\"bounce\\":{\\"bounceType\\":\\"Undetermined\\",\\"bounceSubType\\":\\"General\\"}, \\"mail\\":{\\"messageId\\":\\"%s\\",\\"timestamp\\":\\"2016-03-14T12:35:25.909Z\\",\\"source\\":\\"test@test-domain.com\\",\\"sourceArn\\":\\"arn:aws:ses:eu-west-1:123456789012:identity/testing-notify\\",\\"sendingAccountId\\":\\"123456789012\\",\\"destination\\":[\\"testing@digital.cabinet-office.gov.uk\\"]},\\"delivery\\":{\\"timestamp\\":\\"2016-03-14T12:35:26.567Z\\",\\"processingTimeMillis\\":658,\\"recipients\\":[\\"testing@digital.cabinet-office.gov.uk\\"],\\"smtpResponse\\":\\"250 2.0.0 OK 1457958926 uo5si26480932wjc.221 - gsmtp\\",\\"reportingMTA\\":\\"a6-238.smtp-out.eu-west-1.amazonses.com\\"}}", "Timestamp" : "2016-03-14T12:35:26.665Z", "SignatureVersion" : "1", "Signature" : "X8d7eTAOZ6wlnrdVVPYanrAlsX0SMPfOzhoTEBnQqYkrNWTqQY91C0f3bxtPdUhUtOowyPAOkTQ4KnZuzphfhVb2p1MyVYMxNKcBFB05/qaCX99+92fjw4x9LeUOwyGwMv5F0Vkfi5qZCcEw69uVrhYLVSTFTrzi/yCtru+yFULMQ6UhbY09GwiP6hjxZMVr8aROQy5lLHglqQzOuSZ4KeD85JjifHdKzlx8jjQ+uj+FLzHXPMAPmPU1JK9kpoHZ1oPshAFgPDpphJe+HwcJ8ezmk+3AEUr3wWli3xF+49y8Z2anASSVp6YI2YP95UT8Rlh3qT3T+V9V8rbSVislxA==", "SigningCertURL" : "https://sns.eu-west-1.amazonaws.com/SimpleNotificationService-bb750dd426d95ee9390147a5624348ee.pem", "UnsubscribeURL" : "https://sns.eu-west-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:eu-west-1:302763885840:preview-emails:d6aad3ef-83d6-4cf3-a470-54e2e75916da"}' % (reference, reference) # noqa
|