2020-10-29 11:12:28 +00:00
|
|
|
import uuid
|
|
|
|
|
|
2020-07-09 18:22:29 +01:00
|
|
|
from flask import current_app
|
|
|
|
|
from notifications_utils.statsd_decorators import statsd
|
2020-12-04 15:49:50 +00:00
|
|
|
from sqlalchemy.schema import Sequence
|
2020-07-09 18:22:29 +01:00
|
|
|
|
2020-12-04 15:49:50 +00:00
|
|
|
from app import cbc_proxy_client, db, notify_celery
|
2020-10-29 11:12:28 +00:00
|
|
|
from app.config import QueueNames
|
2021-02-08 11:02:34 +00:00
|
|
|
from app.models import BroadcastEventMessageType, BroadcastProvider
|
|
|
|
|
from app.dao.broadcast_message_dao import dao_get_broadcast_event_by_id, create_broadcast_provider_message
|
2020-07-09 18:22:29 +01:00
|
|
|
|
2020-12-04 16:00:20 +00:00
|
|
|
from app.utils import format_sequential_number
|
|
|
|
|
|
2020-07-09 18:22:29 +01:00
|
|
|
|
2020-08-04 19:21:22 +01:00
|
|
|
@notify_celery.task(name="send-broadcast-event")
|
|
|
|
|
@statsd(namespace="tasks")
|
2020-10-23 17:54:33 +01:00
|
|
|
def send_broadcast_event(broadcast_event_id):
|
2020-11-25 17:39:32 +00:00
|
|
|
if not current_app.config['CBC_PROXY_ENABLED']:
|
|
|
|
|
current_app.logger.info(f'CBC Proxy disabled, not sending broadcast_event {broadcast_event_id}')
|
|
|
|
|
return
|
|
|
|
|
|
2020-12-02 14:10:46 +00:00
|
|
|
broadcast_event = dao_get_broadcast_event_by_id(broadcast_event_id)
|
2020-12-03 17:44:32 +00:00
|
|
|
for provider in broadcast_event.service.get_available_broadcast_providers():
|
|
|
|
|
send_broadcast_provider_message.apply_async(
|
|
|
|
|
kwargs={'broadcast_event_id': broadcast_event_id, 'provider': provider},
|
2021-01-13 17:21:40 +00:00
|
|
|
queue=QueueNames.BROADCASTS
|
2020-12-03 17:44:32 +00:00
|
|
|
)
|
2020-10-29 11:12:28 +00:00
|
|
|
|
|
|
|
|
|
2021-02-08 11:02:34 +00:00
|
|
|
@notify_celery.task(name="send-broadcast-provider-message")
|
2020-10-29 11:12:28 +00:00
|
|
|
@statsd(namespace="tasks")
|
2021-02-08 11:02:34 +00:00
|
|
|
def send_broadcast_provider_message(broadcast_event_id, provider):
|
2020-08-04 19:21:22 +01:00
|
|
|
broadcast_event = dao_get_broadcast_event_by_id(broadcast_event_id)
|
|
|
|
|
|
2021-02-08 11:02:34 +00:00
|
|
|
broadcast_provider_message = create_broadcast_provider_message(broadcast_event, provider)
|
2020-12-04 17:45:23 +00:00
|
|
|
formatted_message_number = None
|
|
|
|
|
if provider == BroadcastProvider.VODAFONE:
|
2020-12-09 11:41:22 +00:00
|
|
|
formatted_message_number = format_sequential_number(broadcast_provider_message.message_number)
|
2020-11-16 18:48:00 +00:00
|
|
|
|
2020-10-23 17:54:33 +01:00
|
|
|
current_app.logger.info(
|
|
|
|
|
f'invoking cbc proxy to send '
|
|
|
|
|
f'broadcast_event {broadcast_event.reference} '
|
|
|
|
|
f'msgType {broadcast_event.message_type}'
|
|
|
|
|
)
|
2020-10-20 11:57:26 +01:00
|
|
|
|
2020-10-23 17:54:33 +01:00
|
|
|
areas = [
|
2020-10-26 15:16:33 +00:00
|
|
|
{"polygon": polygon}
|
|
|
|
|
for polygon in broadcast_event.transmitted_areas["simple_polygons"]
|
2020-10-23 17:54:33 +01:00
|
|
|
]
|
2020-10-23 16:44:11 +01:00
|
|
|
|
2021-01-29 14:14:15 +00:00
|
|
|
channel = "test"
|
|
|
|
|
if broadcast_event.service.broadcast_channel:
|
|
|
|
|
channel = broadcast_event.service.broadcast_channel
|
|
|
|
|
|
2020-11-17 12:35:22 +00:00
|
|
|
cbc_proxy_provider_client = cbc_proxy_client.get_proxy(provider)
|
|
|
|
|
|
2021-02-08 11:02:34 +00:00
|
|
|
if broadcast_event.message_type == BroadcastEventMessageType.ALERT:
|
|
|
|
|
cbc_proxy_provider_client.create_and_send_broadcast(
|
|
|
|
|
identifier=str(broadcast_provider_message.id),
|
|
|
|
|
message_number=formatted_message_number,
|
|
|
|
|
headline="GOV.UK Notify Broadcast",
|
|
|
|
|
description=broadcast_event.transmitted_content['body'],
|
|
|
|
|
areas=areas,
|
|
|
|
|
sent=broadcast_event.sent_at_as_cap_datetime_string,
|
|
|
|
|
expires=broadcast_event.transmitted_finishes_at_as_cap_datetime_string,
|
|
|
|
|
channel=channel
|
2021-02-01 16:37:22 +00:00
|
|
|
)
|
2021-02-08 11:02:34 +00:00
|
|
|
elif broadcast_event.message_type == BroadcastEventMessageType.UPDATE:
|
|
|
|
|
cbc_proxy_provider_client.update_and_send_broadcast(
|
|
|
|
|
identifier=str(broadcast_provider_message.id),
|
|
|
|
|
message_number=formatted_message_number,
|
|
|
|
|
headline="GOV.UK Notify Broadcast",
|
|
|
|
|
description=broadcast_event.transmitted_content['body'],
|
|
|
|
|
areas=areas,
|
|
|
|
|
previous_provider_messages=broadcast_event.get_earlier_provider_messages(provider),
|
|
|
|
|
sent=broadcast_event.sent_at_as_cap_datetime_string,
|
|
|
|
|
expires=broadcast_event.transmitted_finishes_at_as_cap_datetime_string,
|
|
|
|
|
# We think an alert update should always go out on the same channel that created the alert
|
|
|
|
|
# We recognise there is a small risk with this code here that if the services channel was
|
|
|
|
|
# changed between an alert being sent out and then updated, then something might go wrong
|
|
|
|
|
# but we are relying on service channels changing almost never, and not mid incident
|
|
|
|
|
# We may consider in the future, changing this such that we store the channel a broadcast was
|
|
|
|
|
# sent on on the broadcast message itself and pick the value from there instead of the service
|
|
|
|
|
channel=channel
|
|
|
|
|
)
|
|
|
|
|
elif broadcast_event.message_type == BroadcastEventMessageType.CANCEL:
|
|
|
|
|
cbc_proxy_provider_client.cancel_broadcast(
|
|
|
|
|
identifier=str(broadcast_provider_message.id),
|
|
|
|
|
message_number=formatted_message_number,
|
|
|
|
|
previous_provider_messages=broadcast_event.get_earlier_provider_messages(provider),
|
|
|
|
|
sent=broadcast_event.sent_at_as_cap_datetime_string,
|
2020-10-23 17:54:33 +01:00
|
|
|
)
|
2021-02-01 16:37:22 +00:00
|
|
|
|
2020-10-29 11:12:28 +00:00
|
|
|
|
|
|
|
|
@notify_celery.task(name='trigger-link-test')
|
|
|
|
|
def trigger_link_test(provider):
|
|
|
|
|
identifier = str(uuid.uuid4())
|
2020-12-04 16:00:20 +00:00
|
|
|
formatted_seq_number = None
|
2020-12-04 15:49:50 +00:00
|
|
|
if provider == BroadcastProvider.VODAFONE:
|
|
|
|
|
sequence = Sequence('broadcast_provider_message_number_seq')
|
|
|
|
|
sequential_number = db.session.connection().execute(sequence)
|
2020-12-04 16:00:20 +00:00
|
|
|
formatted_seq_number = format_sequential_number(sequential_number)
|
2020-10-29 11:12:28 +00:00
|
|
|
message = f"Sending a link test to CBC proxy for provider {provider} with ID {identifier}"
|
|
|
|
|
current_app.logger.info(message)
|
2020-12-04 16:00:20 +00:00
|
|
|
cbc_proxy_client.get_proxy(provider).send_link_test(identifier, formatted_seq_number)
|