2017-07-11 15:41:44 +01:00
|
|
|
import json
|
2021-03-10 13:55:06 +00:00
|
|
|
from datetime import timedelta
|
2022-11-01 11:42:14 -04:00
|
|
|
from os import getenv
|
2022-06-13 13:45:07 -07:00
|
|
|
|
2017-07-19 13:50:29 +01:00
|
|
|
from celery.schedules import crontab
|
|
|
|
|
from kombu import Exchange, Queue
|
|
|
|
|
|
2022-10-31 15:37:12 -04:00
|
|
|
from app.cloudfoundry_config import cloud_config
|
2016-12-08 12:12:45 +00:00
|
|
|
|
2016-09-07 09:35:31 +01:00
|
|
|
|
2017-07-19 13:50:29 +01:00
|
|
|
class QueueNames(object):
|
|
|
|
|
PERIODIC = 'periodic-tasks'
|
|
|
|
|
PRIORITY = 'priority-tasks'
|
|
|
|
|
DATABASE = 'database-tasks'
|
2017-07-20 15:48:21 +01:00
|
|
|
SEND_SMS = 'send-sms-tasks'
|
|
|
|
|
SEND_EMAIL = 'send-email-tasks'
|
2017-07-19 13:50:29 +01:00
|
|
|
RESEARCH_MODE = 'research-mode-tasks'
|
2019-08-15 15:21:00 +01:00
|
|
|
REPORTING = 'reporting-tasks'
|
2017-07-19 13:50:29 +01:00
|
|
|
JOBS = 'job-tasks'
|
|
|
|
|
RETRY = 'retry-tasks'
|
|
|
|
|
NOTIFY = 'notify-internal-tasks'
|
|
|
|
|
PROCESS_FTP = 'process-ftp-tasks'
|
2017-12-14 16:00:51 +00:00
|
|
|
CREATE_LETTERS_PDF = 'create-letters-pdf-tasks'
|
2017-12-13 10:57:08 +00:00
|
|
|
CALLBACKS = 'service-callbacks'
|
2021-02-04 11:53:22 +00:00
|
|
|
CALLBACKS_RETRY = 'service-callbacks-retry'
|
2017-12-18 16:12:17 +00:00
|
|
|
LETTERS = 'letter-tasks'
|
2020-03-16 16:13:30 +00:00
|
|
|
SMS_CALLBACKS = 'sms-callbacks'
|
2018-03-19 13:13:38 +00:00
|
|
|
ANTIVIRUS = 'antivirus-tasks'
|
2019-12-04 15:59:51 +00:00
|
|
|
SANITISE_LETTERS = 'sanitise-letter-tasks'
|
2020-03-25 12:39:15 +00:00
|
|
|
SAVE_API_EMAIL = 'save-api-email-tasks'
|
2020-10-29 11:12:46 +00:00
|
|
|
SAVE_API_SMS = 'save-api-sms-tasks'
|
2017-07-19 13:50:29 +01:00
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def all_queues():
|
|
|
|
|
return [
|
|
|
|
|
QueueNames.PRIORITY,
|
|
|
|
|
QueueNames.PERIODIC,
|
|
|
|
|
QueueNames.DATABASE,
|
2017-07-20 15:48:21 +01:00
|
|
|
QueueNames.SEND_SMS,
|
|
|
|
|
QueueNames.SEND_EMAIL,
|
2017-07-19 13:50:29 +01:00
|
|
|
QueueNames.RESEARCH_MODE,
|
2019-08-15 15:21:00 +01:00
|
|
|
QueueNames.REPORTING,
|
2017-07-19 13:50:29 +01:00
|
|
|
QueueNames.JOBS,
|
|
|
|
|
QueueNames.RETRY,
|
|
|
|
|
QueueNames.NOTIFY,
|
2017-12-08 17:27:05 +00:00
|
|
|
QueueNames.CREATE_LETTERS_PDF,
|
2017-12-13 10:57:08 +00:00
|
|
|
QueueNames.CALLBACKS,
|
2021-02-04 11:53:22 +00:00
|
|
|
QueueNames.CALLBACKS_RETRY,
|
2017-12-18 16:12:17 +00:00
|
|
|
QueueNames.LETTERS,
|
2020-03-16 16:13:30 +00:00
|
|
|
QueueNames.SMS_CALLBACKS,
|
2020-10-29 11:12:46 +00:00
|
|
|
QueueNames.SAVE_API_EMAIL,
|
2021-01-13 16:19:50 +00:00
|
|
|
QueueNames.SAVE_API_SMS,
|
2017-07-19 13:50:29 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
2017-08-22 15:49:56 +01:00
|
|
|
class TaskNames(object):
|
2017-10-13 16:46:17 +01:00
|
|
|
PROCESS_INCOMPLETE_JOBS = 'process-incomplete-jobs'
|
2017-12-19 14:18:05 +00:00
|
|
|
ZIP_AND_SEND_LETTER_PDFS = 'zip-and-send-letter-pdfs'
|
2018-03-19 13:13:38 +00:00
|
|
|
SCAN_FILE = 'scan-file'
|
2019-12-04 15:59:51 +00:00
|
|
|
SANITISE_LETTER = 'sanitise-and-upload-letter'
|
2020-05-05 11:17:22 +01:00
|
|
|
CREATE_PDF_FOR_TEMPLATED_LETTER = 'create-pdf-for-templated-letter'
|
2021-10-11 18:04:42 +01:00
|
|
|
RECREATE_PDF_FOR_PRECOMPILED_LETTER = 'recreate-pdf-for-precompiled-letter'
|
2017-08-22 15:49:56 +01:00
|
|
|
|
|
|
|
|
|
2016-12-08 12:12:45 +00:00
|
|
|
class Config(object):
|
2022-10-31 13:25:59 -04:00
|
|
|
NOTIFY_APP_NAME = 'api'
|
2022-11-01 11:42:14 -04:00
|
|
|
NOTIFY_ENVIRONMENT = getenv('NOTIFY_ENVIRONMENT', 'development')
|
2016-09-07 09:35:31 +01:00
|
|
|
# URL of admin app
|
2022-11-01 11:42:14 -04:00
|
|
|
ADMIN_BASE_URL = getenv('ADMIN_BASE_URL', 'http://localhost:6012')
|
2016-12-08 12:12:45 +00:00
|
|
|
# URL of api app (on AWS this is the internal api endpoint)
|
2022-11-01 11:42:14 -04:00
|
|
|
API_HOST_NAME = getenv('API_HOST_NAME', 'http://localhost:6011')
|
2016-12-08 12:12:45 +00:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# Credentials
|
2021-07-26 16:45:10 +01:00
|
|
|
# secrets that internal apps, such as the admin app or document download, must use to authenticate with the API
|
2022-10-31 15:37:12 -04:00
|
|
|
# ADMIN_CLIENT_ID is called ADMIN_CLIENT_USER_NAME in api repo, they should match
|
2022-11-01 11:42:14 -04:00
|
|
|
ADMIN_CLIENT_ID = getenv('ADMIN_CLIENT_ID', 'notify-admin')
|
2021-08-05 17:24:56 +01:00
|
|
|
INTERNAL_CLIENT_API_KEYS = json.loads(
|
2022-11-01 11:42:14 -04:00
|
|
|
getenv(
|
2022-10-31 13:25:59 -04:00
|
|
|
'INTERNAL_CLIENT_API_KEYS',
|
2022-11-01 11:42:14 -04:00
|
|
|
('{"%s":["%s"]}' % (ADMIN_CLIENT_ID, getenv('ADMIN_CLIENT_SECRET')))
|
2022-10-31 13:25:59 -04:00
|
|
|
)
|
|
|
|
|
)
|
2022-11-17 17:04:51 -05:00
|
|
|
ALLOW_EXPIRED_API_TOKEN = False
|
2016-09-07 09:35:31 +01:00
|
|
|
# encyption secret/salt
|
2022-11-01 11:42:14 -04:00
|
|
|
SECRET_KEY = getenv('SECRET_KEY')
|
|
|
|
|
DANGEROUS_SALT = getenv('DANGEROUS_SALT')
|
|
|
|
|
ROUTE_SECRET_KEY_1 = getenv('ROUTE_SECRET_KEY_1', 'dev-route-secret-key-1')
|
|
|
|
|
ROUTE_SECRET_KEY_2 = getenv('ROUTE_SECRET_KEY_2', 'dev-route-secret-key-2')
|
2016-09-07 09:35:31 +01:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# DB settings
|
2022-11-01 11:34:00 -04:00
|
|
|
SQLALCHEMY_DATABASE_URI = cloud_config.database_url
|
2022-10-31 13:25:59 -04:00
|
|
|
SQLALCHEMY_RECORD_QUERIES = False
|
|
|
|
|
SQLALCHEMY_TRACK_MODIFICATIONS = False
|
2022-11-01 11:42:14 -04:00
|
|
|
SQLALCHEMY_POOL_SIZE = int(getenv('SQLALCHEMY_POOL_SIZE', 5))
|
2022-10-31 13:25:59 -04:00
|
|
|
SQLALCHEMY_POOL_TIMEOUT = 30
|
|
|
|
|
SQLALCHEMY_POOL_RECYCLE = 300
|
|
|
|
|
SQLALCHEMY_STATEMENT_TIMEOUT = 1200
|
|
|
|
|
PAGE_SIZE = 50
|
|
|
|
|
API_PAGE_SIZE = 250
|
2022-10-31 15:37:12 -04:00
|
|
|
REDIS_URL = cloud_config.redis_url
|
2022-11-01 11:42:14 -04:00
|
|
|
REDIS_ENABLED = getenv('REDIS_ENABLED', '0') == '1'
|
2022-10-31 13:25:59 -04:00
|
|
|
EXPIRE_CACHE_TEN_MINUTES = 600
|
|
|
|
|
EXPIRE_CACHE_EIGHT_DAYS = 8 * 24 * 60 * 60
|
2022-08-19 14:32:11 +00:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# AWS Settings
|
2022-11-01 11:42:14 -04:00
|
|
|
AWS_REGION = getenv('AWS_REGION')
|
|
|
|
|
AWS_PINPOINT_REGION = getenv("AWS_PINPOINT_REGION")
|
|
|
|
|
AWS_US_TOLL_FREE_NUMBER = getenv("AWS_US_TOLL_FREE_NUMBER")
|
2022-10-07 17:25:31 -07:00
|
|
|
# Whether to ignore POSTs from SNS for replies to SMS we sent
|
|
|
|
|
RECEIVE_INBOUND_SMS = False
|
2022-11-01 11:42:14 -04:00
|
|
|
NOTIFY_EMAIL_DOMAIN = getenv('NOTIFY_EMAIL_DOMAIN', 'notify.sandbox.10x.gsa.gov')
|
2022-10-31 13:25:59 -04:00
|
|
|
SES_STUB_URL = None # TODO: set to a URL in env and remove this to use a stubbed SES service
|
2022-09-20 20:11:09 -07:00
|
|
|
# AWS SNS topics for delivery receipts
|
2022-10-04 17:42:04 -07:00
|
|
|
VALIDATE_SNS_TOPICS = True
|
2022-10-03 09:05:34 -07:00
|
|
|
VALID_SNS_TOPICS = ['notify_test_bounce', 'notify_test_success', 'notify_test_complaint', 'notify_test_sms_inbound']
|
2016-09-07 09:35:31 +01:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# these should always add up to 100%
|
|
|
|
|
SMS_PROVIDER_RESTING_POINTS = {
|
2022-11-29 16:35:53 -05:00
|
|
|
'sns': 100,
|
2022-10-31 13:25:59 -04:00
|
|
|
}
|
2016-12-08 12:12:45 +00:00
|
|
|
|
2018-04-25 14:22:23 +01:00
|
|
|
# Zendesk
|
2022-11-01 11:42:14 -04:00
|
|
|
ZENDESK_API_KEY = getenv('ZENDESK_API_KEY')
|
2018-01-17 14:36:02 +00:00
|
|
|
|
2016-12-08 12:12:45 +00:00
|
|
|
# Logging
|
|
|
|
|
DEBUG = False
|
2016-11-28 09:39:56 +00:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# Monitoring
|
2019-01-16 14:11:03 +00:00
|
|
|
CRONITOR_ENABLED = False
|
2022-11-01 11:42:14 -04:00
|
|
|
CRONITOR_KEYS = json.loads(getenv('CRONITOR_KEYS', '{}'))
|
|
|
|
|
STATSD_HOST = getenv('STATSD_HOST')
|
2022-10-31 13:25:59 -04:00
|
|
|
STATSD_PORT = 8125
|
|
|
|
|
STATSD_ENABLED = bool(STATSD_HOST)
|
2019-01-16 14:11:03 +00:00
|
|
|
|
2019-02-25 14:26:47 +00:00
|
|
|
# Antivirus
|
2022-11-01 11:42:14 -04:00
|
|
|
ANTIVIRUS_ENABLED = getenv('ANTIVIRUS_ENABLED', '1') == '1'
|
2016-09-07 09:35:31 +01:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
SENDING_NOTIFICATIONS_TIMEOUT_PERIOD = 259200 # 3 days
|
2016-09-07 09:35:31 +01:00
|
|
|
INVITATION_EXPIRATION_DAYS = 2
|
2016-10-11 14:30:40 +01:00
|
|
|
TEST_MESSAGE_FILENAME = 'Test message'
|
2017-06-01 13:56:47 +01:00
|
|
|
ONE_OFF_MESSAGE_FILENAME = 'Report'
|
2021-03-24 15:35:16 +00:00
|
|
|
MAX_VERIFY_CODE_COUNT = 5
|
2021-10-04 10:18:58 +01:00
|
|
|
MAX_FAILED_LOGIN_COUNT = 10
|
2022-10-31 13:25:59 -04:00
|
|
|
API_RATE_LIMIT_ENABLED = True
|
2016-01-27 17:42:05 +00:00
|
|
|
|
2019-07-29 17:23:22 +01:00
|
|
|
# be careful increasing this size without being sure that we won't see slowness in pysftp
|
|
|
|
|
MAX_LETTER_PDF_ZIP_FILESIZE = 40 * 1024 * 1024 # 40mb
|
2019-03-18 13:13:05 +00:00
|
|
|
MAX_LETTER_PDF_COUNT_PER_ZIP = 500
|
2017-12-19 14:18:05 +00:00
|
|
|
|
2016-06-02 11:12:01 +01:00
|
|
|
NOTIFY_SERVICE_ID = 'd6aa2c68-a2d9-4437-ab19-3ae8eb202553'
|
2017-03-02 18:03:53 +00:00
|
|
|
NOTIFY_USER_ID = '6af522d0-2915-4e52-83a3-3690455a5fe6'
|
2016-06-02 11:12:01 +01:00
|
|
|
INVITATION_EMAIL_TEMPLATE_ID = '4f46df42-f795-4cc4-83bb-65ca312f49cc'
|
|
|
|
|
SMS_CODE_TEMPLATE_ID = '36fb0730-6259-4da1-8a80-c8de22ad4246'
|
2017-11-03 14:38:30 +00:00
|
|
|
EMAIL_2FA_TEMPLATE_ID = '299726d2-dba6-42b8-8209-30e1d66ea164'
|
|
|
|
|
NEW_USER_EMAIL_VERIFICATION_TEMPLATE_ID = 'ece42649-22a8-4d06-b87f-d52d5d3f0a27'
|
2022-10-05 01:12:35 +00:00
|
|
|
PASSWORD_RESET_TEMPLATE_ID = '474e9242-823b-4f99-813d-ed392e7f1201' # nosec B105 - this is not a password
|
2016-07-07 17:23:07 +01:00
|
|
|
ALREADY_REGISTERED_EMAIL_TEMPLATE_ID = '0880fbb1-a0c6-46f0-9a8e-36c986381ceb'
|
2016-10-12 13:06:39 +01:00
|
|
|
CHANGE_EMAIL_CONFIRMATION_TEMPLATE_ID = 'eb4d9930-87ab-4aef-9bce-786762687884'
|
2017-05-12 14:06:29 +01:00
|
|
|
SERVICE_NOW_LIVE_TEMPLATE_ID = '618185c6-3636-49cd-b7d2-6f6f5eb3bdde'
|
2018-02-16 14:42:03 +00:00
|
|
|
ORGANISATION_INVITATION_EMAIL_TEMPLATE_ID = '203566f0-d835-47c5-aa06-932439c86573'
|
2019-02-26 16:25:04 +00:00
|
|
|
TEAM_MEMBER_EDIT_EMAIL_TEMPLATE_ID = 'c73f1d71-4049-46d5-a647-d013bdeca3f0'
|
|
|
|
|
TEAM_MEMBER_EDIT_MOBILE_TEMPLATE_ID = '8a31520f-4751-4789-8ea1-fe54496725eb'
|
2022-06-13 13:45:07 -07:00
|
|
|
REPLY_TO_EMAIL_ADDRESS_VERIFICATION_TEMPLATE_ID = 'a42f1d17-9404-46d5-a647-d013bdfca3e1'
|
2019-07-09 11:59:33 +01:00
|
|
|
MOU_SIGNER_RECEIPT_TEMPLATE_ID = '4fd2e43c-309b-4e50-8fb8-1955852d9d71'
|
2022-06-13 13:45:07 -07:00
|
|
|
MOU_SIGNED_ON_BEHALF_SIGNER_RECEIPT_TEMPLATE_ID = 'c20206d5-bf03-4002-9a90-37d5032d9e84'
|
|
|
|
|
MOU_SIGNED_ON_BEHALF_ON_BEHALF_RECEIPT_TEMPLATE_ID = '522b6657-5ca5-4368-a294-6b527703bd0b'
|
2022-10-03 09:05:34 -07:00
|
|
|
NOTIFY_INTERNATIONAL_SMS_SENDER = '18446120782'
|
2021-02-17 17:47:00 +00:00
|
|
|
LETTERS_VOLUME_EMAIL_TEMPLATE_ID = '11fad854-fd38-4a7c-bd17-805fb13dfc12'
|
2022-04-08 17:39:55 +01:00
|
|
|
NHS_EMAIL_BRANDING_ID = 'a7dc4e56-660b-4db7-8cff-12c37b12b5ea'
|
2021-02-22 17:21:13 +00:00
|
|
|
# we only need real email in Live environment (production)
|
2022-11-01 11:42:14 -04:00
|
|
|
DVLA_EMAIL_ADDRESSES = json.loads(getenv('DVLA_EMAIL_ADDRESSES', '[]'))
|
2016-06-02 11:12:01 +01:00
|
|
|
|
2021-10-26 16:36:25 +01:00
|
|
|
CELERY = {
|
2022-09-28 16:27:37 -04:00
|
|
|
'broker_url': REDIS_URL,
|
2021-10-26 16:36:25 +01:00
|
|
|
'broker_transport_options': {
|
|
|
|
|
'visibility_timeout': 310,
|
2021-07-19 16:17:33 +01:00
|
|
|
},
|
2022-11-10 12:33:25 -05:00
|
|
|
'timezone': getenv("TIMEZONE", 'America/New_York'),
|
2021-10-26 16:36:25 +01:00
|
|
|
'imports': [
|
|
|
|
|
'app.celery.tasks',
|
|
|
|
|
'app.celery.scheduled_tasks',
|
|
|
|
|
'app.celery.reporting_tasks',
|
|
|
|
|
'app.celery.nightly_tasks',
|
|
|
|
|
],
|
|
|
|
|
# this is overriden by the -Q command, but locally, we should read from all queues
|
|
|
|
|
'task_queues': [
|
2022-06-13 13:45:07 -07:00
|
|
|
Queue(queue, Exchange('default'), routing_key=queue) for queue in QueueNames.all_queues()
|
2021-10-26 16:36:25 +01:00
|
|
|
],
|
|
|
|
|
'beat_schedule': {
|
|
|
|
|
# app/celery/scheduled_tasks.py
|
|
|
|
|
'run-scheduled-jobs': {
|
|
|
|
|
'task': 'run-scheduled-jobs',
|
|
|
|
|
'schedule': crontab(minute='0,15,30,45'),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'delete-verify-codes': {
|
|
|
|
|
'task': 'delete-verify-codes',
|
|
|
|
|
'schedule': timedelta(minutes=63),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'delete-invitations': {
|
|
|
|
|
'task': 'delete-invitations',
|
|
|
|
|
'schedule': timedelta(minutes=66),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'check-job-status': {
|
|
|
|
|
'task': 'check-job-status',
|
|
|
|
|
'schedule': crontab(),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'tend-providers-back-to-middle': {
|
|
|
|
|
'task': 'tend-providers-back-to-middle',
|
|
|
|
|
'schedule': crontab(minute='*/5'),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'check-for-missing-rows-in-completed-jobs': {
|
|
|
|
|
'task': 'check-for-missing-rows-in-completed-jobs',
|
|
|
|
|
'schedule': crontab(minute='*/10'),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'replay-created-notifications': {
|
|
|
|
|
'task': 'replay-created-notifications',
|
|
|
|
|
'schedule': crontab(minute='0, 15, 30, 45'),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
# app/celery/nightly_tasks.py
|
|
|
|
|
'timeout-sending-notifications': {
|
|
|
|
|
'task': 'timeout-sending-notifications',
|
|
|
|
|
'schedule': crontab(hour=0, minute=5),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'create-nightly-billing': {
|
|
|
|
|
'task': 'create-nightly-billing',
|
|
|
|
|
'schedule': crontab(hour=0, minute=15),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.REPORTING}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'create-nightly-notification-status': {
|
|
|
|
|
'task': 'create-nightly-notification-status',
|
2022-06-13 13:45:07 -07:00
|
|
|
'schedule': crontab(hour=0, minute=30), # after 'timeout-sending-notifications'
|
|
|
|
|
'options': {'queue': QueueNames.REPORTING}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'delete-notifications-older-than-retention': {
|
|
|
|
|
'task': 'delete-notifications-older-than-retention',
|
2022-06-13 13:45:07 -07:00
|
|
|
'schedule': crontab(hour=3, minute=0), # after 'create-nightly-notification-status'
|
|
|
|
|
'options': {'queue': QueueNames.REPORTING}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'delete-inbound-sms': {
|
|
|
|
|
'task': 'delete-inbound-sms',
|
|
|
|
|
'schedule': crontab(hour=1, minute=40),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'save-daily-notification-processing-time': {
|
|
|
|
|
'task': 'save-daily-notification-processing-time',
|
|
|
|
|
'schedule': crontab(hour=2, minute=0),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'remove_sms_email_jobs': {
|
|
|
|
|
'task': 'remove_sms_email_jobs',
|
|
|
|
|
'schedule': crontab(hour=4, minute=0),
|
|
|
|
|
'options': {'queue': QueueNames.PERIODIC},
|
|
|
|
|
},
|
|
|
|
|
'remove_letter_jobs': {
|
|
|
|
|
'task': 'remove_letter_jobs',
|
|
|
|
|
'schedule': crontab(hour=4, minute=20),
|
|
|
|
|
# since we mark jobs as archived
|
|
|
|
|
'options': {'queue': QueueNames.PERIODIC},
|
|
|
|
|
},
|
|
|
|
|
'check-if-letters-still-in-created': {
|
|
|
|
|
'task': 'check-if-letters-still-in-created',
|
|
|
|
|
'schedule': crontab(day_of_week='mon-fri', hour=7, minute=0),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'check-if-letters-still-pending-virus-check': {
|
|
|
|
|
'task': 'check-if-letters-still-pending-virus-check',
|
|
|
|
|
'schedule': crontab(day_of_week='mon-fri', hour='9,15', minute=0),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'check-for-services-with-high-failure-rates-or-sending-to-tv-numbers': {
|
|
|
|
|
'task': 'check-for-services-with-high-failure-rates-or-sending-to-tv-numbers',
|
|
|
|
|
'schedule': crontab(day_of_week='mon-fri', hour=10, minute=30),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'raise-alert-if-letter-notifications-still-sending': {
|
|
|
|
|
'task': 'raise-alert-if-letter-notifications-still-sending',
|
2022-02-28 11:22:14 +00:00
|
|
|
'schedule': crontab(hour=17, minute=00),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
# The collate-letter-pdf does assume it is called in an hour that BST does not make a
|
|
|
|
|
# difference to the truncate date which translates to the filename to process
|
|
|
|
|
'collate-letter-pdfs-to-be-sent': {
|
|
|
|
|
'task': 'collate-letter-pdfs-to-be-sent',
|
|
|
|
|
'schedule': crontab(hour=17, minute=50),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'raise-alert-if-no-letter-ack-file': {
|
|
|
|
|
'task': 'raise-alert-if-no-letter-ack-file',
|
|
|
|
|
'schedule': crontab(hour=23, minute=00),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
|
|
|
|
'trigger-link-tests': {
|
|
|
|
|
'task': 'trigger-link-tests',
|
|
|
|
|
'schedule': timedelta(minutes=15),
|
2022-06-13 13:45:07 -07:00
|
|
|
'options': {'queue': QueueNames.PERIODIC}
|
2021-10-26 16:36:25 +01:00
|
|
|
},
|
2022-06-13 13:45:07 -07:00
|
|
|
}
|
2017-07-19 13:50:29 +01:00
|
|
|
}
|
2017-12-28 12:04:19 +00:00
|
|
|
|
2021-10-26 16:36:25 +01:00
|
|
|
# we can set celeryd_prefetch_multiplier to be 1 for celery apps which handle only long running tasks
|
2022-11-01 11:42:14 -04:00
|
|
|
if getenv('CELERYD_PREFETCH_MULTIPLIER'):
|
|
|
|
|
CELERY['worker_prefetch_multiplier'] = getenv('CELERYD_PREFETCH_MULTIPLIER')
|
2017-07-19 13:50:29 +01:00
|
|
|
|
2016-09-07 09:35:31 +01:00
|
|
|
FROM_NUMBER = 'development'
|
2016-02-09 13:31:45 +00:00
|
|
|
|
2017-02-03 13:34:09 +00:00
|
|
|
SIMULATED_EMAIL_ADDRESSES = (
|
|
|
|
|
'simulate-delivered@notifications.service.gov.uk',
|
|
|
|
|
'simulate-delivered-2@notifications.service.gov.uk',
|
|
|
|
|
'simulate-delivered-3@notifications.service.gov.uk',
|
|
|
|
|
)
|
2023-01-04 16:35:18 -05:00
|
|
|
SIMULATED_SMS_NUMBERS = ('+12028675000', '+12028675111', '+12028675222')
|
2016-09-13 17:00:28 +01:00
|
|
|
|
2017-06-06 14:49:05 +01:00
|
|
|
FREE_SMS_TIER_FRAGMENT_COUNT = 250000
|
|
|
|
|
|
2022-11-01 11:42:14 -04:00
|
|
|
HIGH_VOLUME_SERVICE = json.loads(getenv('HIGH_VOLUME_SERVICE', '[]'))
|
2020-03-27 08:02:51 +00:00
|
|
|
|
2022-11-01 11:42:14 -04:00
|
|
|
TEMPLATE_PREVIEW_API_HOST = getenv('TEMPLATE_PREVIEW_API_HOST', 'http://localhost:6013')
|
|
|
|
|
TEMPLATE_PREVIEW_API_KEY = getenv('TEMPLATE_PREVIEW_API_KEY', 'my-secret-key')
|
2017-12-06 13:51:52 +00:00
|
|
|
|
2022-11-01 11:42:14 -04:00
|
|
|
DOCUMENT_DOWNLOAD_API_HOST = getenv('DOCUMENT_DOWNLOAD_API_HOST', 'http://localhost:7000')
|
|
|
|
|
DOCUMENT_DOWNLOAD_API_KEY = getenv('DOCUMENT_DOWNLOAD_API_KEY', 'auth-token')
|
2018-04-04 17:31:02 +01:00
|
|
|
|
2016-09-07 09:35:31 +01:00
|
|
|
|
2022-10-31 15:37:12 -04:00
|
|
|
def _default_s3_credentials(bucket_name):
|
|
|
|
|
return {
|
|
|
|
|
'bucket': bucket_name,
|
2022-11-01 11:42:14 -04:00
|
|
|
'access_key_id': getenv('AWS_ACCESS_KEY_ID'),
|
|
|
|
|
'secret_access_key': getenv('AWS_SECRET_ACCESS_KEY'),
|
|
|
|
|
'region': getenv('AWS_REGION')
|
2022-10-31 15:37:12 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2015-12-10 10:56:59 +00:00
|
|
|
class Development(Config):
|
2018-02-21 18:12:03 +00:00
|
|
|
DEBUG = True
|
2017-11-15 16:00:13 +00:00
|
|
|
SQLALCHEMY_ECHO = False
|
2022-10-31 13:25:59 -04:00
|
|
|
DVLA_EMAIL_ADDRESSES = ['success@simulator.amazonses.com']
|
2018-02-21 18:12:03 +00:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# Buckets
|
2022-10-31 15:37:12 -04:00
|
|
|
CSV_UPLOAD_BUCKET = _default_s3_credentials('local-notifications-csv-upload')
|
|
|
|
|
CONTACT_LIST_BUCKET = _default_s3_credentials('local-contact-list')
|
2021-07-26 16:45:10 +01:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
# credential overrides
|
2022-12-09 16:33:10 -05:00
|
|
|
DANGEROUS_SALT = 'development-notify-salt'
|
2022-10-31 13:25:59 -04:00
|
|
|
SECRET_KEY = 'dev-notify-secret-key' # nosec B105 - this is only used in development
|
2022-10-31 15:37:12 -04:00
|
|
|
INTERNAL_CLIENT_API_KEYS = {Config.ADMIN_CLIENT_ID: ['dev-notify-secret-key']}
|
2022-11-17 17:04:51 -05:00
|
|
|
ALLOW_EXPIRED_API_TOKEN = getenv('ALLOW_EXPIRED_API_TOKEN', '0') == '1'
|
2016-08-31 11:40:31 +01:00
|
|
|
|
|
|
|
|
|
2018-02-21 18:42:24 +00:00
|
|
|
class Test(Development):
|
2016-09-07 09:35:31 +01:00
|
|
|
FROM_NUMBER = 'testing'
|
2017-06-19 13:49:20 +01:00
|
|
|
TESTING = True
|
2022-10-31 13:25:59 -04:00
|
|
|
ANTIVIRUS_ENABLED = True
|
|
|
|
|
DVLA_EMAIL_ADDRESSES = ['success@simulator.amazonses.com', 'success+2@simulator.amazonses.com']
|
|
|
|
|
|
2020-06-26 14:10:12 +01:00
|
|
|
HIGH_VOLUME_SERVICE = [
|
|
|
|
|
'941b6f9a-50d7-4742-8d50-f365ca74bf27',
|
|
|
|
|
'63f95b86-2d19-4497-b8b2-ccf25457df4e',
|
|
|
|
|
'7e5950cb-9954-41f5-8376-962b8c8555cf',
|
|
|
|
|
'10d1b9c9-0072-4fa9-ae1c-595e333841da',
|
|
|
|
|
]
|
2020-03-27 08:02:51 +00:00
|
|
|
|
2022-10-31 15:37:12 -04:00
|
|
|
CSV_UPLOAD_BUCKET = _default_s3_credentials('test-notifications-csv-upload')
|
|
|
|
|
CONTACT_LIST_BUCKET = _default_s3_credentials('test-contact-list')
|
2018-02-21 18:42:24 +00:00
|
|
|
|
2022-07-01 11:45:49 -07:00
|
|
|
# this is overriden in CI
|
2022-11-01 11:42:14 -04:00
|
|
|
SQLALCHEMY_DATABASE_URI = getenv('SQLALCHEMY_DATABASE_TEST_URI')
|
2017-05-25 10:50:55 +01:00
|
|
|
|
2021-10-26 16:36:25 +01:00
|
|
|
CELERY = {
|
|
|
|
|
**Config.CELERY,
|
2022-06-13 13:45:07 -07:00
|
|
|
'broker_url': 'you-forgot-to-mock-celery-in-your-tests://'
|
2021-10-26 16:36:25 +01:00
|
|
|
}
|
2017-06-09 16:20:02 +01:00
|
|
|
|
2017-12-12 14:53:38 +00:00
|
|
|
TEMPLATE_PREVIEW_API_HOST = 'http://localhost:9999'
|
2017-09-26 10:59:09 +01:00
|
|
|
|
2016-07-04 16:54:03 +01:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
class Production(Config):
|
2022-07-25 15:19:05 -07:00
|
|
|
# buckets
|
2022-10-31 15:37:12 -04:00
|
|
|
CSV_UPLOAD_BUCKET = cloud_config.s3_credentials(
|
2022-11-07 12:10:49 -05:00
|
|
|
f"notify-api-csv-upload-bucket-{Config.NOTIFY_ENVIRONMENT}")
|
2022-10-31 15:37:12 -04:00
|
|
|
CONTACT_LIST_BUCKET = cloud_config.s3_credentials(
|
2022-11-07 12:10:49 -05:00
|
|
|
f"notify-api-contact-list-bucket-{Config.NOTIFY_ENVIRONMENT}")
|
2022-08-19 14:32:11 +00:00
|
|
|
|
2022-07-25 15:19:05 -07:00
|
|
|
FROM_NUMBER = 'US Notify'
|
2019-01-16 14:11:03 +00:00
|
|
|
CRONITOR_ENABLED = True
|
2022-08-19 14:32:11 +00:00
|
|
|
|
2022-06-29 08:47:36 -07:00
|
|
|
|
2022-10-31 13:25:59 -04:00
|
|
|
class Staging(Production):
|
2016-12-08 12:12:45 +00:00
|
|
|
pass
|
|
|
|
|
|
2022-11-02 12:02:21 -04:00
|
|
|
|
2022-11-02 09:09:16 -04:00
|
|
|
class Demo(Production):
|
|
|
|
|
pass
|
2016-12-08 12:12:45 +00:00
|
|
|
|
2022-11-02 12:02:21 -04:00
|
|
|
|
2016-03-17 11:47:44 +00:00
|
|
|
configs = {
|
2016-08-31 11:42:05 +01:00
|
|
|
'development': Development,
|
|
|
|
|
'test': Test,
|
|
|
|
|
'staging': Staging,
|
2022-11-02 09:09:16 -04:00
|
|
|
'demo': Demo,
|
2022-11-04 11:48:01 -04:00
|
|
|
'sandbox': Staging,
|
2022-10-31 13:25:59 -04:00
|
|
|
'production': Production
|
2016-03-17 11:47:44 +00:00
|
|
|
}
|