mirror of
https://github.com/GSA/notifications-api.git
synced 2025-12-23 00:41:35 -05:00
Update ServiceWhitelist to conform to new data model
This commit is contained in:
@@ -138,6 +138,11 @@ class Service(db.Model, Versioned):
|
|||||||
default=BRANDING_GOVUK
|
default=BRANDING_GOVUK
|
||||||
)
|
)
|
||||||
|
|
||||||
|
MOBILE_TYPE = 'mobile'
|
||||||
|
EMAIL_TYPE = 'email'
|
||||||
|
|
||||||
|
WHITELIST_RECIPIENT_TYPE = [MOBILE_TYPE, EMAIL_TYPE]
|
||||||
|
whitelist_recipient_types = db.Enum(*WHITELIST_RECIPIENT_TYPE, name='recipient_type')
|
||||||
|
|
||||||
class ServiceWhitelist(db.Model):
|
class ServiceWhitelist(db.Model):
|
||||||
__tablename__ = 'service_whitelist'
|
__tablename__ = 'service_whitelist'
|
||||||
@@ -145,25 +150,34 @@ class ServiceWhitelist(db.Model):
|
|||||||
id = db.Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
|
id = db.Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
|
||||||
service_id = db.Column(UUID(as_uuid=True), db.ForeignKey('services.id'), index=True, nullable=False)
|
service_id = db.Column(UUID(as_uuid=True), db.ForeignKey('services.id'), index=True, nullable=False)
|
||||||
service = db.relationship('Service', backref='whitelist')
|
service = db.relationship('Service', backref='whitelist')
|
||||||
email_address = db.Column(db.String(255), nullable=True)
|
recipient_type = db.Column(whitelist_recipient_types, nullable=False)
|
||||||
mobile_number = db.Column(db.String, nullable=True)
|
recipient = db.Column(db.String(255), nullable=False)
|
||||||
created_at = db.Column(db.DateTime, default=datetime.datetime.utcnow)
|
created_at = db.Column(db.DateTime, default=datetime.datetime.utcnow)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def from_string(cls, service_id, contact):
|
def from_string(cls, service_id, recipient_type, recipient):
|
||||||
instance = cls(service_id=service_id)
|
instance = cls(service_id=service_id, recipient_type=recipient_type)
|
||||||
try:
|
|
||||||
validate_email_address(contact)
|
|
||||||
instance.email_address = contact
|
|
||||||
except InvalidEmailError:
|
|
||||||
try:
|
|
||||||
validate_phone_number(contact)
|
|
||||||
instance.mobile_number = contact
|
|
||||||
except InvalidPhoneError:
|
|
||||||
raise ValueError('Invalid whitelist: "{}"'.format(contact))
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
if recipient_type == MOBILE_TYPE:
|
||||||
|
validate_phone_number(recipient)
|
||||||
|
instance.recipient = recipient
|
||||||
|
elif recipient_type == EMAIL_TYPE:
|
||||||
|
validate_email_address(recipient)
|
||||||
|
instance.recipient = recipient
|
||||||
|
else:
|
||||||
|
raise ValueError('Invalid recipient type')
|
||||||
|
except InvalidPhoneError:
|
||||||
|
raise ValueError('Invalid whitelist: "{}"'.format(recipient))
|
||||||
|
except InvalidEmailError:
|
||||||
|
raise ValueError('Invalid whitelist: "{}"'.format(recipient))
|
||||||
|
else:
|
||||||
return instance
|
return instance
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return 'Recipient {} of type: {}'.format(self.recipient,
|
||||||
|
self.recipient_type)
|
||||||
|
|
||||||
|
|
||||||
class ApiKey(db.Model, Versioned):
|
class ApiKey(db.Model, Versioned):
|
||||||
__tablename__ = 'api_keys'
|
__tablename__ = 'api_keys'
|
||||||
@@ -329,7 +343,6 @@ class ProviderDetails(db.Model):
|
|||||||
priority = db.Column(db.Integer, nullable=False)
|
priority = db.Column(db.Integer, nullable=False)
|
||||||
notification_type = db.Column(notification_types, nullable=False)
|
notification_type = db.Column(notification_types, nullable=False)
|
||||||
active = db.Column(db.Boolean, default=False)
|
active = db.Column(db.Boolean, default=False)
|
||||||
blah = db.Column
|
|
||||||
|
|
||||||
|
|
||||||
JOB_STATUS_PENDING = 'pending'
|
JOB_STATUS_PENDING = 'pending'
|
||||||
|
|||||||
@@ -3,7 +3,10 @@ from datetime import datetime
|
|||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
from app import DATETIME_FORMAT
|
from app import DATETIME_FORMAT
|
||||||
from app.models import Notification, ServiceWhitelist
|
from app.models import (
|
||||||
|
Notification,
|
||||||
|
ServiceWhitelist,
|
||||||
|
MOBILE_TYPE, EMAIL_TYPE)
|
||||||
|
|
||||||
|
|
||||||
def test_should_build_notification_from_minimal_set_of_api_derived_params(notify_api):
|
def test_should_build_notification_from_minimal_set_of_api_derived_params(notify_api):
|
||||||
@@ -79,27 +82,25 @@ def test_should_build_notification_from_full_set_of_api_derived_params(notify_ap
|
|||||||
'+44 7700 900678'
|
'+44 7700 900678'
|
||||||
])
|
])
|
||||||
def test_should_build_service_whitelist_from_mobile_number(mobile_number):
|
def test_should_build_service_whitelist_from_mobile_number(mobile_number):
|
||||||
service_whitelist = ServiceWhitelist.from_string('service_id', mobile_number)
|
service_whitelist = ServiceWhitelist.from_string('service_id', MOBILE_TYPE, mobile_number)
|
||||||
|
|
||||||
assert service_whitelist.mobile_number == mobile_number
|
assert service_whitelist.recipient == mobile_number
|
||||||
assert service_whitelist.email_address is None
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('email_address', [
|
@pytest.mark.parametrize('email_address', [
|
||||||
'test@example.com'
|
'test@example.com'
|
||||||
])
|
])
|
||||||
def test_should_build_service_whitelist_from_email_address(email_address):
|
def test_should_build_service_whitelist_from_email_address(email_address):
|
||||||
service_whitelist = ServiceWhitelist.from_string('service_id', email_address)
|
service_whitelist = ServiceWhitelist.from_string('service_id', EMAIL_TYPE, email_address)
|
||||||
|
|
||||||
assert service_whitelist.email_address == email_address
|
assert service_whitelist.recipient == email_address
|
||||||
assert service_whitelist.mobile_number is None
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('contact', [
|
@pytest.mark.parametrize('contact, recipient_type', [
|
||||||
'',
|
('', None),
|
||||||
'07700dsadsad',
|
('07700dsadsad', MOBILE_TYPE),
|
||||||
'gmail.com'
|
('gmail.com', EMAIL_TYPE)
|
||||||
])
|
])
|
||||||
def test_should_not_build_service_whitelist_from_invalid_contact(contact):
|
def test_should_not_build_service_whitelist_from_invalid_contact(recipient_type, contact):
|
||||||
with pytest.raises(ValueError):
|
with pytest.raises(ValueError):
|
||||||
ServiceWhitelist.from_string('service_id', contact)
|
ServiceWhitelist.from_string('service_id', recipient_type, contact)
|
||||||
|
|||||||
Reference in New Issue
Block a user