2019-09-05 17:36:02 +01:00
|
|
|
|
from flask import current_app
|
|
|
|
|
|
from notifications_utils.s3 import S3ObjectNotFound, s3download as utils_s3download
|
2018-04-25 12:19:12 +01:00
|
|
|
|
from sqlalchemy.orm.exc import NoResultFound
|
|
|
|
|
|
|
2018-11-30 16:35:00 +00:00
|
|
|
|
from app import create_random_identifier
|
2017-07-19 13:50:29 +01:00
|
|
|
|
from app.config import QueueNames
|
2018-10-31 14:30:46 +00:00
|
|
|
|
from app.dao.notifications_dao import _update_notification_status
|
2017-11-25 11:31:36 +00:00
|
|
|
|
from app.dao.service_email_reply_to_dao import dao_get_reply_to_by_id
|
|
|
|
|
|
from app.dao.service_sms_sender_dao import dao_get_service_sms_senders_by_id
|
2017-06-13 17:33:04 +01:00
|
|
|
|
from app.notifications.validators import (
|
2019-09-05 17:36:02 +01:00
|
|
|
|
check_service_has_permission,
|
2017-06-13 17:33:04 +01:00
|
|
|
|
check_service_over_daily_message_limit,
|
|
|
|
|
|
validate_and_format_recipient,
|
2017-11-28 11:05:56 +00:00
|
|
|
|
validate_template
|
|
|
|
|
|
)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
from app.notifications.process_notifications import (
|
|
|
|
|
|
persist_notification,
|
2017-11-29 16:47:23 +00:00
|
|
|
|
send_notification_to_queue
|
2017-10-30 13:36:49 +00:00
|
|
|
|
)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
from app.models import (
|
|
|
|
|
|
KEY_TYPE_NORMAL,
|
2018-03-01 10:17:59 +00:00
|
|
|
|
PRIORITY,
|
2017-06-13 17:33:04 +01:00
|
|
|
|
SMS_TYPE,
|
2017-11-28 11:05:56 +00:00
|
|
|
|
EMAIL_TYPE,
|
2018-10-31 14:30:46 +00:00
|
|
|
|
LETTER_TYPE,
|
|
|
|
|
|
NOTIFICATION_DELIVERED,
|
2019-09-05 17:36:02 +01:00
|
|
|
|
UPLOAD_LETTERS,
|
2017-11-28 11:05:56 +00:00
|
|
|
|
)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
from app.dao.services_dao import dao_fetch_service_by_id
|
2019-09-05 17:36:02 +01:00
|
|
|
|
from app.dao.templates_dao import dao_get_template_by_id_and_service_id, get_precompiled_letter_template
|
2017-06-16 16:30:03 +01:00
|
|
|
|
from app.dao.users_dao import get_user_by_id
|
2019-09-05 17:36:02 +01:00
|
|
|
|
from app.letters.utils import (
|
|
|
|
|
|
get_letter_pdf_filename,
|
|
|
|
|
|
get_page_count,
|
|
|
|
|
|
move_uploaded_pdf_to_letters_bucket,
|
|
|
|
|
|
)
|
2017-06-16 16:30:03 +01:00
|
|
|
|
from app.v2.errors import BadRequestError
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_created_by(service, created_by_id):
|
|
|
|
|
|
user = get_user_by_id(created_by_id)
|
|
|
|
|
|
if service not in user.services:
|
|
|
|
|
|
message = 'Can’t create notification - {} is not part of the "{}" service'.format(
|
|
|
|
|
|
user.name,
|
|
|
|
|
|
service.name
|
|
|
|
|
|
)
|
|
|
|
|
|
raise BadRequestError(message=message)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
|
|
|
|
|
|
|
2018-11-30 16:35:00 +00:00
|
|
|
|
def create_one_off_reference(template_type):
|
2018-12-03 11:33:59 +00:00
|
|
|
|
if template_type == LETTER_TYPE:
|
|
|
|
|
|
return create_random_identifier()
|
|
|
|
|
|
return None
|
2018-11-30 16:35:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
2017-06-13 17:33:04 +01:00
|
|
|
|
def send_one_off_notification(service_id, post_data):
|
|
|
|
|
|
service = dao_fetch_service_by_id(service_id)
|
|
|
|
|
|
template = dao_get_template_by_id_and_service_id(
|
|
|
|
|
|
template_id=post_data['template_id'],
|
|
|
|
|
|
service_id=service_id
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
personalisation = post_data.get('personalisation', None)
|
|
|
|
|
|
|
2017-06-15 13:40:38 +01:00
|
|
|
|
validate_template(template.id, personalisation, service, template.template_type)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
|
|
|
|
|
|
check_service_over_daily_message_limit(KEY_TYPE_NORMAL, service)
|
|
|
|
|
|
|
|
|
|
|
|
validate_and_format_recipient(
|
|
|
|
|
|
send_to=post_data['to'],
|
|
|
|
|
|
key_type=KEY_TYPE_NORMAL,
|
|
|
|
|
|
service=service,
|
2018-01-17 15:20:04 +00:00
|
|
|
|
notification_type=template.template_type,
|
|
|
|
|
|
allow_whitelisted_recipients=False,
|
2017-06-13 17:33:04 +01:00
|
|
|
|
)
|
|
|
|
|
|
|
2017-06-16 16:30:03 +01:00
|
|
|
|
validate_created_by(service, post_data['created_by'])
|
|
|
|
|
|
|
2017-11-25 11:31:36 +00:00
|
|
|
|
sender_id = post_data.get('sender_id', None)
|
2017-12-15 17:13:55 +00:00
|
|
|
|
reply_to = get_reply_to_text(
|
|
|
|
|
|
notification_type=template.template_type,
|
|
|
|
|
|
sender_id=sender_id,
|
|
|
|
|
|
service=service,
|
|
|
|
|
|
template=template
|
|
|
|
|
|
)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
notification = persist_notification(
|
|
|
|
|
|
template_id=template.id,
|
|
|
|
|
|
template_version=template.version,
|
2019-01-14 17:45:56 +00:00
|
|
|
|
template_postage=template.postage,
|
2017-06-13 17:33:04 +01:00
|
|
|
|
recipient=post_data['to'],
|
|
|
|
|
|
service=service,
|
|
|
|
|
|
personalisation=personalisation,
|
|
|
|
|
|
notification_type=template.template_type,
|
|
|
|
|
|
api_key_id=None,
|
2017-06-16 16:30:03 +01:00
|
|
|
|
key_type=KEY_TYPE_NORMAL,
|
2017-11-25 11:31:36 +00:00
|
|
|
|
created_by_id=post_data['created_by'],
|
2018-11-30 16:35:00 +00:00
|
|
|
|
reply_to_text=reply_to,
|
|
|
|
|
|
reference=create_one_off_reference(template.template_type),
|
2017-06-13 17:33:04 +01:00
|
|
|
|
)
|
|
|
|
|
|
|
2018-03-01 10:17:59 +00:00
|
|
|
|
queue_name = QueueNames.PRIORITY if template.process_type == PRIORITY else None
|
2018-10-31 14:30:46 +00:00
|
|
|
|
|
|
|
|
|
|
if template.template_type == LETTER_TYPE and service.research_mode:
|
|
|
|
|
|
_update_notification_status(
|
|
|
|
|
|
notification,
|
|
|
|
|
|
NOTIFICATION_DELIVERED,
|
|
|
|
|
|
)
|
|
|
|
|
|
else:
|
|
|
|
|
|
send_notification_to_queue(
|
|
|
|
|
|
notification=notification,
|
|
|
|
|
|
research_mode=service.research_mode,
|
|
|
|
|
|
queue=queue_name,
|
|
|
|
|
|
)
|
2017-06-13 17:33:04 +01:00
|
|
|
|
|
|
|
|
|
|
return {'id': str(notification.id)}
|
2017-11-25 11:31:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
2017-12-15 17:13:55 +00:00
|
|
|
|
def get_reply_to_text(notification_type, sender_id, service, template):
|
2017-11-25 11:31:36 +00:00
|
|
|
|
reply_to = None
|
2017-12-15 17:13:55 +00:00
|
|
|
|
if sender_id:
|
2018-04-25 14:23:00 +01:00
|
|
|
|
try:
|
|
|
|
|
|
if notification_type == EMAIL_TYPE:
|
2018-04-25 12:19:12 +01:00
|
|
|
|
message = 'Reply to email address not found'
|
2018-04-25 14:23:00 +01:00
|
|
|
|
reply_to = dao_get_reply_to_by_id(service.id, sender_id).email_address
|
|
|
|
|
|
elif notification_type == SMS_TYPE:
|
|
|
|
|
|
message = 'SMS sender not found'
|
|
|
|
|
|
reply_to = dao_get_service_sms_senders_by_id(service.id, sender_id).get_reply_to_text()
|
|
|
|
|
|
except NoResultFound:
|
|
|
|
|
|
raise BadRequestError(message=message)
|
2017-12-15 17:13:55 +00:00
|
|
|
|
else:
|
|
|
|
|
|
reply_to = template.get_reply_to_text()
|
2017-11-25 11:31:36 +00:00
|
|
|
|
return reply_to
|
2019-09-05 17:36:02 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def send_pdf_letter_notification(service_id, post_data):
|
|
|
|
|
|
service = dao_fetch_service_by_id(service_id)
|
|
|
|
|
|
|
|
|
|
|
|
check_service_has_permission(LETTER_TYPE, service.permissions)
|
|
|
|
|
|
check_service_has_permission(UPLOAD_LETTERS, service.permissions)
|
|
|
|
|
|
check_service_over_daily_message_limit(KEY_TYPE_NORMAL, service)
|
|
|
|
|
|
validate_created_by(service, post_data['created_by'])
|
|
|
|
|
|
|
|
|
|
|
|
template = get_precompiled_letter_template(service.id)
|
|
|
|
|
|
file_location = 'service-{}/{}.pdf'.format(service.id, post_data['file_id'])
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
letter = utils_s3download(current_app.config['TRANSIENT_UPLOADED_LETTERS'], file_location)
|
|
|
|
|
|
except S3ObjectNotFound as e:
|
|
|
|
|
|
current_app.logger.exception('Letter {}.pdf not in transient {} bucket'.format(
|
|
|
|
|
|
post_data['file_id'], current_app.config['TRANSIENT_UPLOADED_LETTERS'])
|
|
|
|
|
|
)
|
|
|
|
|
|
raise e
|
|
|
|
|
|
|
|
|
|
|
|
# Getting the page count won't raise an error since admin has already checked the PDF is valid
|
|
|
|
|
|
billable_units = get_page_count(letter.read())
|
|
|
|
|
|
|
|
|
|
|
|
personalisation = {
|
|
|
|
|
|
'address_line_1': post_data['filename']
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# TODO: stop hard-coding postage as 'second' once we get postage from the admin
|
|
|
|
|
|
notification = persist_notification(
|
|
|
|
|
|
notification_id=post_data['file_id'],
|
|
|
|
|
|
template_id=template.id,
|
|
|
|
|
|
template_version=template.version,
|
|
|
|
|
|
template_postage=template.postage,
|
|
|
|
|
|
recipient=post_data['filename'],
|
|
|
|
|
|
service=service,
|
|
|
|
|
|
personalisation=personalisation,
|
|
|
|
|
|
notification_type=LETTER_TYPE,
|
|
|
|
|
|
api_key_id=None,
|
|
|
|
|
|
key_type=KEY_TYPE_NORMAL,
|
|
|
|
|
|
reference=create_one_off_reference(LETTER_TYPE),
|
|
|
|
|
|
client_reference=post_data['filename'],
|
|
|
|
|
|
created_by_id=post_data['created_by'],
|
|
|
|
|
|
billable_units=billable_units,
|
|
|
|
|
|
postage='second',
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
upload_filename = get_letter_pdf_filename(
|
|
|
|
|
|
notification.reference,
|
|
|
|
|
|
notification.service.crown,
|
|
|
|
|
|
is_scan_letter=False,
|
|
|
|
|
|
postage=notification.postage
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
move_uploaded_pdf_to_letters_bucket(file_location, upload_filename)
|
|
|
|
|
|
|
|
|
|
|
|
return {'id': str(notification.id)}
|