2017-05-31 14:49:14 +01:00
|
|
|
from flask import (
|
|
|
|
|
Blueprint,
|
|
|
|
|
jsonify,
|
|
|
|
|
request
|
|
|
|
|
)
|
2017-06-02 12:57:28 +01:00
|
|
|
from notifications_utils.recipients import validate_and_format_phone_number
|
2017-05-31 14:49:14 +01:00
|
|
|
|
|
|
|
|
from app.dao.inbound_sms_dao import dao_get_inbound_sms_for_service, dao_count_inbound_sms_for_service
|
|
|
|
|
from app.errors import register_errors
|
|
|
|
|
|
|
|
|
|
inbound_sms = Blueprint(
|
|
|
|
|
'inbound_sms',
|
|
|
|
|
__name__,
|
|
|
|
|
url_prefix='/service/<service_id>/inbound-sms'
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
register_errors(inbound_sms)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@inbound_sms.route('')
|
|
|
|
|
def get_inbound_sms_for_service(service_id):
|
|
|
|
|
limit = request.args.get('limit')
|
|
|
|
|
user_number = request.args.get('user_number')
|
|
|
|
|
|
|
|
|
|
if user_number:
|
2017-06-02 12:57:28 +01:00
|
|
|
# we use this to normalise to an international phone number
|
2017-06-02 13:34:02 +01:00
|
|
|
user_number = validate_and_format_phone_number(user_number, international=True)
|
2017-05-31 14:49:14 +01:00
|
|
|
|
|
|
|
|
results = dao_get_inbound_sms_for_service(service_id, limit, user_number)
|
|
|
|
|
|
|
|
|
|
return jsonify(data=[row.serialize() for row in results])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@inbound_sms.route('/summary')
|
|
|
|
|
def get_inbound_sms_summary_for_service(service_id):
|
|
|
|
|
count = dao_count_inbound_sms_for_service(service_id)
|
|
|
|
|
most_recent = dao_get_inbound_sms_for_service(service_id, limit=1)
|
|
|
|
|
|
|
|
|
|
return jsonify(
|
|
|
|
|
count=count,
|
|
|
|
|
most_recent=most_recent[0].created_at.isoformat() if most_recent else None
|
|
|
|
|
)
|