2015-12-04 14:40:16 +00:00
|
|
|
from __future__ import unicode_literals
|
2017-05-22 17:02:03 +01:00
|
|
|
|
2016-03-29 22:50:40 +01:00
|
|
|
from flask import url_for
|
|
|
|
|
from app.utils import BrowsableItem
|
2016-11-30 17:01:44 +00:00
|
|
|
from app.notify_client import _attach_current_user, NotifyAdminAPIClient
|
2015-12-04 14:40:16 +00:00
|
|
|
|
|
|
|
|
|
2016-11-30 17:01:44 +00:00
|
|
|
class ServiceAPIClient(NotifyAdminAPIClient):
|
2016-01-15 15:15:35 +00:00
|
|
|
# Fudge assert in the super __init__ so
|
|
|
|
|
# we can set those variables later.
|
|
|
|
|
def __init__(self):
|
2017-07-26 10:23:39 +01:00
|
|
|
super().__init__("a" * 73, "b")
|
2016-01-15 15:15:35 +00:00
|
|
|
|
|
|
|
|
def init_app(self, application):
|
2016-01-20 09:46:48 +00:00
|
|
|
self.base_url = application.config['API_HOST_NAME']
|
2017-07-26 12:03:14 +01:00
|
|
|
self.service_id = application.config['ADMIN_CLIENT_USER_NAME']
|
|
|
|
|
self.api_key = application.config['ADMIN_CLIENT_SECRET']
|
2016-01-15 15:15:35 +00:00
|
|
|
|
2016-11-16 11:44:29 +00:00
|
|
|
def create_service(self, service_name, message_limit, restricted, user_id, email_from):
|
2016-01-14 14:55:07 +00:00
|
|
|
"""
|
|
|
|
|
Create a service and return the json.
|
|
|
|
|
"""
|
|
|
|
|
data = {
|
|
|
|
|
"name": service_name,
|
2016-11-16 11:44:29 +00:00
|
|
|
"active": True,
|
2016-04-12 14:19:51 +01:00
|
|
|
"message_limit": message_limit,
|
2016-02-19 16:38:08 +00:00
|
|
|
"user_id": user_id,
|
2016-03-31 15:17:05 +01:00
|
|
|
"restricted": restricted,
|
|
|
|
|
"email_from": email_from
|
2016-01-14 14:55:07 +00:00
|
|
|
}
|
2016-08-11 14:20:43 +01:00
|
|
|
data = _attach_current_user(data)
|
2016-03-13 09:37:17 +00:00
|
|
|
return self.post("/service", data)['data']['id']
|
2016-01-14 14:55:07 +00:00
|
|
|
|
2016-07-20 11:46:29 +01:00
|
|
|
def get_service(self, service_id):
|
2016-07-25 15:26:43 +01:00
|
|
|
return self._get_service(service_id, detailed=False, today_only=False)
|
2016-07-20 11:46:29 +01:00
|
|
|
|
|
|
|
|
def get_detailed_service(self, service_id):
|
2016-07-25 15:26:43 +01:00
|
|
|
return self._get_service(service_id, detailed=True, today_only=False)
|
2016-07-20 11:46:29 +01:00
|
|
|
|
2016-07-25 14:16:34 +01:00
|
|
|
def get_detailed_service_for_today(self, service_id):
|
2016-07-25 15:26:43 +01:00
|
|
|
return self._get_service(service_id, detailed=True, today_only=True)
|
2016-07-25 14:16:34 +01:00
|
|
|
|
|
|
|
|
def _get_service(self, service_id, detailed, today_only):
|
2016-01-19 10:23:08 +00:00
|
|
|
"""
|
|
|
|
|
Retrieve a service.
|
2016-07-25 14:16:34 +01:00
|
|
|
|
|
|
|
|
:param detailed - return additional details, including notification statistics
|
|
|
|
|
:param today_only - return statistics only for today. No effect if detailed not passed in
|
2016-01-19 10:23:08 +00:00
|
|
|
"""
|
2016-07-25 15:26:43 +01:00
|
|
|
params = {}
|
|
|
|
|
if detailed:
|
|
|
|
|
params['detailed'] = detailed
|
|
|
|
|
if today_only:
|
|
|
|
|
params['today_only'] = today_only
|
|
|
|
|
|
2016-01-19 10:23:08 +00:00
|
|
|
return self.get(
|
2016-07-19 13:53:27 +01:00
|
|
|
'/service/{0}'.format(service_id),
|
|
|
|
|
params=params)
|
2016-01-19 10:23:08 +00:00
|
|
|
|
2016-11-09 14:33:35 +00:00
|
|
|
def get_services(self, params_dict=None):
|
2016-01-19 10:23:08 +00:00
|
|
|
"""
|
|
|
|
|
Retrieve a list of services.
|
|
|
|
|
"""
|
2016-11-09 14:33:35 +00:00
|
|
|
return self.get('/service', params=params_dict)
|
|
|
|
|
|
|
|
|
|
def get_active_services(self, params_dict=None):
|
|
|
|
|
"""
|
|
|
|
|
Retrieve a list of active services.
|
|
|
|
|
"""
|
|
|
|
|
params_dict['only_active'] = True
|
|
|
|
|
return self.get_services(params_dict)
|
2016-01-19 10:23:08 +00:00
|
|
|
|
2016-08-11 12:32:38 +01:00
|
|
|
def update_service(
|
|
|
|
|
self,
|
|
|
|
|
service_id,
|
|
|
|
|
**kwargs
|
|
|
|
|
):
|
2016-01-14 14:55:07 +00:00
|
|
|
"""
|
|
|
|
|
Update a service.
|
|
|
|
|
"""
|
2016-08-11 14:20:43 +01:00
|
|
|
data = _attach_current_user(kwargs)
|
|
|
|
|
disallowed_attributes = set(data.keys()) - {
|
2016-08-11 13:55:42 +01:00
|
|
|
'name',
|
|
|
|
|
'message_limit',
|
|
|
|
|
'active',
|
|
|
|
|
'restricted',
|
|
|
|
|
'email_from',
|
|
|
|
|
'reply_to_email_address',
|
2016-08-23 10:15:22 +01:00
|
|
|
'research_mode',
|
2016-08-11 14:20:43 +01:00
|
|
|
'sms_sender',
|
2016-08-12 12:37:18 +01:00
|
|
|
'created_by',
|
|
|
|
|
'branding',
|
2017-03-02 15:56:28 +00:00
|
|
|
'organisation',
|
2017-04-19 16:11:28 +01:00
|
|
|
'letter_contact_block',
|
2017-04-24 14:46:19 +01:00
|
|
|
'dvla_organisation',
|
2017-06-02 16:25:24 +01:00
|
|
|
'permissions'
|
2016-08-11 13:55:42 +01:00
|
|
|
}
|
|
|
|
|
if disallowed_attributes:
|
|
|
|
|
raise TypeError('Not allowed to update service attributes: {}'.format(
|
|
|
|
|
", ".join(disallowed_attributes)
|
|
|
|
|
))
|
|
|
|
|
|
2016-01-14 14:55:07 +00:00
|
|
|
endpoint = "/service/{0}".format(service_id)
|
2016-03-08 10:40:07 +00:00
|
|
|
return self.post(endpoint, data)
|
2016-01-14 14:55:07 +00:00
|
|
|
|
2016-06-01 16:07:43 +01:00
|
|
|
def update_service_with_properties(self, service_id, properties):
|
2016-08-11 12:32:38 +01:00
|
|
|
return self.update_service(service_id, **properties)
|
2016-06-01 16:07:43 +01:00
|
|
|
|
2017-01-31 09:54:51 +00:00
|
|
|
def archive_service(self, service_id):
|
|
|
|
|
return self.post('/service/{}/archive'.format(service_id), data=None)
|
2016-11-02 16:53:40 +00:00
|
|
|
|
2017-01-31 15:56:06 +00:00
|
|
|
def suspend_service(self, service_id):
|
|
|
|
|
return self.post('/service/{}/suspend'.format(service_id), data=None)
|
|
|
|
|
|
|
|
|
|
def resume_service(self, service_id):
|
|
|
|
|
return self.post('/service/{}/resume'.format(service_id), data=None)
|
|
|
|
|
|
2016-03-23 10:46:31 +00:00
|
|
|
def remove_user_from_service(self, service_id, user_id):
|
|
|
|
|
"""
|
|
|
|
|
Remove a user from a service
|
|
|
|
|
"""
|
|
|
|
|
endpoint = '/service/{service_id}/users/{user_id}'.format(
|
|
|
|
|
service_id=service_id,
|
|
|
|
|
user_id=user_id)
|
2016-04-15 11:08:19 +01:00
|
|
|
data = _attach_current_user({})
|
|
|
|
|
return self.delete(endpoint, data)
|
2016-03-23 10:46:31 +00:00
|
|
|
|
2017-01-18 15:11:34 +00:00
|
|
|
def create_service_template(self, name, type_, content, service_id, subject=None, process_type='normal'):
|
2016-01-14 14:55:07 +00:00
|
|
|
"""
|
|
|
|
|
Create a service template.
|
|
|
|
|
"""
|
|
|
|
|
data = {
|
|
|
|
|
"name": name,
|
|
|
|
|
"template_type": type_,
|
|
|
|
|
"content": content,
|
2017-01-18 15:11:34 +00:00
|
|
|
"service": service_id,
|
|
|
|
|
"process_type": process_type
|
2016-01-14 14:55:07 +00:00
|
|
|
}
|
2016-02-22 14:14:03 +00:00
|
|
|
if subject:
|
|
|
|
|
data.update({
|
|
|
|
|
'subject': subject
|
|
|
|
|
})
|
2016-08-11 14:20:43 +01:00
|
|
|
data = _attach_current_user(data)
|
2016-01-14 14:55:07 +00:00
|
|
|
endpoint = "/service/{0}/template".format(service_id)
|
|
|
|
|
return self.post(endpoint, data)
|
|
|
|
|
|
2017-01-18 15:11:34 +00:00
|
|
|
def update_service_template(self, id_, name, type_, content, service_id, subject=None, process_type=None):
|
2016-01-20 09:46:48 +00:00
|
|
|
"""
|
|
|
|
|
Update a service template.
|
|
|
|
|
"""
|
|
|
|
|
data = {
|
|
|
|
|
'id': id_,
|
|
|
|
|
'name': name,
|
|
|
|
|
'template_type': type_,
|
|
|
|
|
'content': content,
|
|
|
|
|
'service': service_id
|
|
|
|
|
}
|
2016-02-22 14:14:03 +00:00
|
|
|
if subject:
|
|
|
|
|
data.update({
|
|
|
|
|
'subject': subject
|
|
|
|
|
})
|
2017-01-18 15:11:34 +00:00
|
|
|
if process_type:
|
|
|
|
|
data.update({
|
|
|
|
|
'process_type': process_type
|
|
|
|
|
})
|
2016-08-11 14:20:43 +01:00
|
|
|
data = _attach_current_user(data)
|
2016-01-20 09:46:48 +00:00
|
|
|
endpoint = "/service/{0}/template/{1}".format(service_id, id_)
|
2016-02-22 14:14:03 +00:00
|
|
|
return self.post(endpoint, data)
|
2016-01-20 09:46:48 +00:00
|
|
|
|
2017-06-26 14:41:00 +01:00
|
|
|
def redact_service_template(self, service_id, id_):
|
|
|
|
|
return self.post(
|
|
|
|
|
"/service/{}/template/{}".format(service_id, id_),
|
2017-06-27 18:03:25 +01:00
|
|
|
_attach_current_user(
|
|
|
|
|
{'redact_personalisation': True}
|
|
|
|
|
),
|
2017-06-26 14:41:00 +01:00
|
|
|
)
|
|
|
|
|
|
2016-05-11 11:20:45 +01:00
|
|
|
def get_service_template(self, service_id, template_id, version=None, *params):
|
2016-01-19 10:23:08 +00:00
|
|
|
"""
|
|
|
|
|
Retrieve a service template.
|
|
|
|
|
"""
|
|
|
|
|
endpoint = '/service/{service_id}/template/{template_id}'.format(
|
|
|
|
|
service_id=service_id,
|
|
|
|
|
template_id=template_id)
|
2016-05-11 11:20:45 +01:00
|
|
|
if version:
|
|
|
|
|
endpoint = '{base}/version/{version}'.format(base=endpoint, version=version)
|
|
|
|
|
return self.get(endpoint, *params)
|
|
|
|
|
|
|
|
|
|
def get_service_template_versions(self, service_id, template_id, *params):
|
|
|
|
|
"""
|
|
|
|
|
Retrieve a list of versions for a template
|
|
|
|
|
"""
|
2016-05-13 17:30:33 +01:00
|
|
|
endpoint = '/service/{service_id}/template/{template_id}/versions'.format(
|
2016-05-11 11:20:45 +01:00
|
|
|
service_id=service_id,
|
|
|
|
|
template_id=template_id
|
|
|
|
|
)
|
2016-01-19 10:23:08 +00:00
|
|
|
return self.get(endpoint, *params)
|
|
|
|
|
|
|
|
|
|
def get_service_templates(self, service_id, *params):
|
|
|
|
|
"""
|
|
|
|
|
Retrieve all templates for service.
|
|
|
|
|
"""
|
|
|
|
|
endpoint = '/service/{service_id}/template'.format(
|
|
|
|
|
service_id=service_id)
|
|
|
|
|
return self.get(endpoint, *params)
|
|
|
|
|
|
2016-01-14 14:55:07 +00:00
|
|
|
def delete_service_template(self, service_id, template_id):
|
|
|
|
|
"""
|
2016-05-23 13:59:33 +01:00
|
|
|
Set a service template's archived flag to True
|
2016-01-14 14:55:07 +00:00
|
|
|
"""
|
|
|
|
|
endpoint = "/service/{0}/template/{1}".format(service_id, template_id)
|
2016-05-23 13:59:33 +01:00
|
|
|
data = {
|
|
|
|
|
'archived': True
|
|
|
|
|
}
|
2016-08-11 14:20:43 +01:00
|
|
|
data = _attach_current_user(data)
|
2016-05-23 13:59:33 +01:00
|
|
|
return self.post(endpoint, data=data)
|
2016-03-29 22:50:40 +01:00
|
|
|
|
2017-08-09 16:52:10 +01:00
|
|
|
def is_service_name_unique(self, name, email_from):
|
|
|
|
|
"""
|
|
|
|
|
Check that the service name or email from are unique across all services.
|
|
|
|
|
"""
|
|
|
|
|
endpoint = "/service/unique"
|
|
|
|
|
params = {"name": name, "email_from": email_from}
|
|
|
|
|
return self.get(url=endpoint, params=params)["result"]
|
2016-03-29 22:50:40 +01:00
|
|
|
|
2016-04-21 17:34:01 +01:00
|
|
|
# Temp access of service history data. Includes service and api key history
|
|
|
|
|
def get_service_history(self, service_id):
|
|
|
|
|
return self.get('/service/{0}/history'.format(service_id))
|
|
|
|
|
|
2017-01-30 17:27:09 +00:00
|
|
|
def get_monthly_notification_stats(self, service_id, year):
|
|
|
|
|
return self.get(url='/service/{}/notifications/monthly?year={}'.format(service_id, year))
|
2016-07-29 10:28:18 +01:00
|
|
|
|
2016-09-20 12:30:00 +01:00
|
|
|
def get_whitelist(self, service_id):
|
|
|
|
|
return self.get(url='/service/{}/whitelist'.format(service_id))
|
|
|
|
|
|
|
|
|
|
def update_whitelist(self, service_id, data):
|
|
|
|
|
return self.put(url='/service/{}/whitelist'.format(service_id), data=data)
|
|
|
|
|
|
2017-05-24 13:19:31 +01:00
|
|
|
def get_inbound_sms(self, service_id, user_number=''):
|
2017-05-22 17:02:03 +01:00
|
|
|
return self.get(
|
2017-05-24 13:19:31 +01:00
|
|
|
'/service/{}/inbound-sms?user_number={}'.format(
|
|
|
|
|
service_id,
|
|
|
|
|
user_number,
|
|
|
|
|
)
|
2017-05-22 17:02:03 +01:00
|
|
|
)['data']
|
|
|
|
|
|
2017-05-24 13:19:31 +01:00
|
|
|
def get_inbound_sms_by_id(self, service_id, notification_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
'/service/{}/inbound-sms/{}'.format(
|
|
|
|
|
service_id,
|
|
|
|
|
notification_id,
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
2017-05-22 17:02:03 +01:00
|
|
|
def get_inbound_sms_summary(self, service_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
'/service/{}/inbound-sms/summary'.format(service_id)
|
|
|
|
|
)
|
|
|
|
|
|
2017-06-20 13:29:20 +01:00
|
|
|
def create_service_inbound_api(self, service_id, url, bearer_token, user_id):
|
|
|
|
|
data = {
|
|
|
|
|
"url": url,
|
|
|
|
|
"bearer_token": bearer_token,
|
|
|
|
|
"updated_by_id": user_id
|
|
|
|
|
}
|
|
|
|
|
return self.post("/service/{}/inbound-api".format(service_id), data)
|
|
|
|
|
|
2017-06-20 13:06:46 +01:00
|
|
|
def update_service_inbound_api(self, service_id, url, bearer_token, user_id, inbound_api_id):
|
2017-06-15 16:20:07 +01:00
|
|
|
data = {
|
2017-06-20 13:06:46 +01:00
|
|
|
"url": url,
|
2017-06-15 16:20:07 +01:00
|
|
|
"updated_by_id": user_id
|
|
|
|
|
}
|
2017-06-21 17:34:22 +01:00
|
|
|
if bearer_token:
|
|
|
|
|
data['bearer_token'] = bearer_token
|
2017-06-20 13:29:20 +01:00
|
|
|
return self.post("/service/{}/inbound-api/{}".format(service_id, inbound_api_id), data)
|
2017-06-20 13:06:46 +01:00
|
|
|
|
|
|
|
|
def get_service_inbound_api(self, service_id, inbound_sms_api_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
"/service/{}/inbound-api/{}".format(
|
|
|
|
|
service_id, inbound_sms_api_id
|
|
|
|
|
)
|
|
|
|
|
)['data']
|
2017-06-15 16:20:07 +01:00
|
|
|
|
2017-09-25 15:14:13 +01:00
|
|
|
def get_reply_to_email_addresses(self, service_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
"/service/{}/email-reply-to".format(
|
|
|
|
|
service_id
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def get_reply_to_email_address(self, service_id, reply_to_email_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
"/service/{}/email-reply-to/{}".format(
|
|
|
|
|
service_id,
|
|
|
|
|
reply_to_email_id
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def add_reply_to_email_address(self, service_id, email_address, is_default=False):
|
|
|
|
|
return self.post(
|
|
|
|
|
"/service/{}/email-reply-to".format(service_id),
|
|
|
|
|
data={
|
|
|
|
|
"email_address": email_address,
|
|
|
|
|
"is_default": is_default
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def update_reply_to_email_address(self, service_id, reply_to_email_id, email_address, is_default=False):
|
|
|
|
|
return self.post(
|
|
|
|
|
"/service/{}/email-reply-to/{}".format(
|
|
|
|
|
service_id,
|
|
|
|
|
reply_to_email_id,
|
|
|
|
|
),
|
|
|
|
|
data={
|
|
|
|
|
"email_address": email_address,
|
|
|
|
|
"is_default": is_default
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
2017-10-05 15:47:12 +01:00
|
|
|
def get_letter_contacts(self, service_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
"/service/{}/letter-contact".format(
|
|
|
|
|
service_id
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def get_letter_contact(self, service_id, letter_contact_id):
|
|
|
|
|
return self.get(
|
|
|
|
|
"/service/{}/letter-contact/{}".format(
|
|
|
|
|
service_id,
|
|
|
|
|
letter_contact_id
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def add_letter_contact(self, service_id, contact_block, is_default=False):
|
|
|
|
|
return self.post(
|
|
|
|
|
"/service/{}/letter-contact".format(service_id),
|
|
|
|
|
data={
|
|
|
|
|
"contact_block": contact_block,
|
|
|
|
|
"is_default": is_default
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def update_letter_contact(self, service_id, letter_contact_id, contact_block, is_default=False):
|
|
|
|
|
return self.post(
|
|
|
|
|
"/service/{}/letter-contact/{}".format(
|
|
|
|
|
service_id,
|
|
|
|
|
letter_contact_id,
|
|
|
|
|
),
|
|
|
|
|
data={
|
|
|
|
|
"contact_block": contact_block,
|
|
|
|
|
"is_default": is_default
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
2016-03-29 22:50:40 +01:00
|
|
|
|
|
|
|
|
class ServicesBrowsableItem(BrowsableItem):
|
|
|
|
|
@property
|
|
|
|
|
def title(self):
|
|
|
|
|
return self._item['name']
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def link(self):
|
|
|
|
|
return url_for('main.service_dashboard', service_id=self._item['id'])
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def destructive(self):
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def hint(self):
|
|
|
|
|
return None
|