Merge pull request #2401 from normanjaeckel/ChangeConfigManagementCommand
Added management command to change config values. Fixed #2400.
This commit is contained in:
commit
346dfd6b57
32
openslides/core/management/commands/changeconfig.py
Normal file
32
openslides/core/management/commands/changeconfig.py
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
from django.core.management.base import BaseCommand, CommandError
|
||||||
|
|
||||||
|
from openslides.core.config import config
|
||||||
|
from openslides.core.exceptions import ConfigError, ConfigNotFound
|
||||||
|
|
||||||
|
|
||||||
|
class Command(BaseCommand):
|
||||||
|
"""
|
||||||
|
Command to change OpenSlides config values.
|
||||||
|
"""
|
||||||
|
help = 'Changes OpenSlides config values.'
|
||||||
|
|
||||||
|
def add_arguments(self, parser):
|
||||||
|
parser.add_argument(
|
||||||
|
'key',
|
||||||
|
help='Config key. See config_variables.py in every app.'
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
'value',
|
||||||
|
help='New config value. For a falsy boolean use "False".'
|
||||||
|
)
|
||||||
|
|
||||||
|
def handle(self, *args, **options):
|
||||||
|
if options['value'].lower() == 'false':
|
||||||
|
options['value'] = False
|
||||||
|
try:
|
||||||
|
config[options['key']] = options['value']
|
||||||
|
except (ConfigError, ConfigNotFound) as e:
|
||||||
|
raise CommandError(str(e))
|
||||||
|
self.stdout.write(
|
||||||
|
self.style.SUCCESS('Config {key} successfully changed to {value}.'.format(
|
||||||
|
key=options['key'], value=config[options['key']])))
|
Loading…
Reference in New Issue
Block a user