mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2026-02-10 00:56:19 +01:00
Services Modules migration improvements (#676)
* Added a check to prevent dataloss from missing service modules Migration will raise an exception and refuse to run if a model has data for a field which is missing its target service. * Add setting to allow services to be installed after service migration Previously django would complain about migrations being out of order. By setting `SERVICES_MIGRATED=True` the `authentication.0013_service_modules` migration drops all of its 'optional' dependencies which allows the initial migrations of service modules to run normally. If the setting is missing or set to False, the migration will require all installed and required services migrations to have run before the `authentication.0013_service_modules` migration. * Move setting to somewhere it makes more sense * Modify celerybeat registration to automatically register services
This commit is contained in:
@@ -22,15 +22,8 @@ djcelery.setup_loader()
|
||||
# Celery configuration
|
||||
BROKER_URL = 'redis://localhost:6379/0'
|
||||
CELERYBEAT_SCHEDULER = "djcelery.schedulers.DatabaseScheduler"
|
||||
CELERYBEAT_SCHEDULE = {
|
||||
"""
|
||||
Uncomment this if you are using the Teamspeak3 service
|
||||
'run_ts3_group_update': {
|
||||
'task': 'services.modules.teamspeak3.tasks.Teamspeak3Tasks.run_ts3_group_update',
|
||||
'schedule': crontab(minute='*/30'),
|
||||
},
|
||||
"""
|
||||
}
|
||||
CELERYBEAT_SCHEDULE = dict()
|
||||
|
||||
|
||||
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
||||
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
||||
@@ -157,6 +150,15 @@ DATABASES = {
|
||||
},
|
||||
}
|
||||
|
||||
# If you have run the authentication.0013_service_modules migration
|
||||
# you will need to set this to True in order to install service modules
|
||||
# which were involved in that migration after it has been run.
|
||||
# If you are on a fresh install with no existing database you can safely
|
||||
# set this to True
|
||||
# If you have not run the authentication.0013_service_modules migration
|
||||
# leave this set to False.
|
||||
SERVICES_MIGRATED = False
|
||||
|
||||
# Password validation
|
||||
# https://docs.djangoproject.com/en/1.10/ref/settings/#auth-password-validators
|
||||
|
||||
@@ -699,3 +701,9 @@ if ENABLE_AUTH_IPS4 or ENABLE_BLUE_IPS4:
|
||||
# Ensure corp/alliance IDs are expected types
|
||||
STR_CORP_IDS = [str(id) for id in CORP_IDS]
|
||||
STR_ALLIANCE_IDS = [str(id) for id in ALLIANCE_IDS]
|
||||
|
||||
if 'services.modules.teamspeak3' in INSTALLED_APPS:
|
||||
CELERYBEAT_SCHEDULE['run_ts3_group_update'] = {
|
||||
'task': 'services.modules.teamspeak3.tasks.Teamspeak3Tasks.run_ts3_group_update',
|
||||
'schedule': crontab(minute='*/30'),
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user