mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Merge pull request #2296 from SchrodingersGat/requires-restart
Requires restart
This commit is contained in:
commit
1deb0f2c1b
@ -12,11 +12,31 @@ class SettingsAdmin(ImportExportModelAdmin):
|
|||||||
|
|
||||||
list_display = ('key', 'value')
|
list_display = ('key', 'value')
|
||||||
|
|
||||||
|
def get_readonly_fields(self, request, obj=None):
|
||||||
|
"""
|
||||||
|
Prevent the 'key' field being edited once the setting is created
|
||||||
|
"""
|
||||||
|
|
||||||
|
if obj:
|
||||||
|
return ['key']
|
||||||
|
else:
|
||||||
|
return []
|
||||||
|
|
||||||
|
|
||||||
class UserSettingsAdmin(ImportExportModelAdmin):
|
class UserSettingsAdmin(ImportExportModelAdmin):
|
||||||
|
|
||||||
list_display = ('key', 'value', 'user', )
|
list_display = ('key', 'value', 'user', )
|
||||||
|
|
||||||
|
def get_readonly_fields(self, request, obj=None):
|
||||||
|
"""
|
||||||
|
Prevent the 'key' field being edited once the setting is created
|
||||||
|
"""
|
||||||
|
|
||||||
|
if obj:
|
||||||
|
return ['key']
|
||||||
|
else:
|
||||||
|
return []
|
||||||
|
|
||||||
|
|
||||||
class NotificationEntryAdmin(admin.ModelAdmin):
|
class NotificationEntryAdmin(admin.ModelAdmin):
|
||||||
|
|
||||||
|
@ -1,10 +1,30 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
import logging
|
||||||
|
|
||||||
from django.apps import AppConfig
|
from django.apps import AppConfig
|
||||||
|
|
||||||
|
|
||||||
|
logger = logging.getLogger('inventree')
|
||||||
|
|
||||||
|
|
||||||
class CommonConfig(AppConfig):
|
class CommonConfig(AppConfig):
|
||||||
name = 'common'
|
name = 'common'
|
||||||
|
|
||||||
def ready(self):
|
def ready(self):
|
||||||
|
|
||||||
|
self.clear_restart_flag()
|
||||||
|
|
||||||
|
def clear_restart_flag(self):
|
||||||
|
"""
|
||||||
|
Clear the SERVER_RESTART_REQUIRED setting
|
||||||
|
"""
|
||||||
|
|
||||||
|
try:
|
||||||
|
import common.models
|
||||||
|
|
||||||
|
if common.models.InvenTreeSetting.get_setting('SERVER_RESTART_REQUIRED'):
|
||||||
|
logger.info("Clearing SERVER_RESTART_REQUIRED flag")
|
||||||
|
common.models.InvenTreeSetting.set_setting('SERVER_RESTART_REQUIRED', False, None)
|
||||||
|
except:
|
||||||
pass
|
pass
|
||||||
|
@ -63,13 +63,15 @@ class BaseInvenTreeSetting(models.Model):
|
|||||||
Enforce validation and clean before saving
|
Enforce validation and clean before saving
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
self.key = str(self.key).upper()
|
||||||
|
|
||||||
self.clean()
|
self.clean()
|
||||||
self.validate_unique()
|
self.validate_unique()
|
||||||
|
|
||||||
super().save()
|
super().save()
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def allValues(cls, user=None):
|
def allValues(cls, user=None, exclude_hidden=False):
|
||||||
"""
|
"""
|
||||||
Return a dict of "all" defined global settings.
|
Return a dict of "all" defined global settings.
|
||||||
|
|
||||||
@ -94,9 +96,15 @@ class BaseInvenTreeSetting(models.Model):
|
|||||||
for key in cls.GLOBAL_SETTINGS.keys():
|
for key in cls.GLOBAL_SETTINGS.keys():
|
||||||
|
|
||||||
if key.upper() not in settings:
|
if key.upper() not in settings:
|
||||||
|
|
||||||
settings[key.upper()] = cls.get_setting_default(key)
|
settings[key.upper()] = cls.get_setting_default(key)
|
||||||
|
|
||||||
|
if exclude_hidden:
|
||||||
|
hidden = cls.GLOBAL_SETTINGS[key].get('hidden', False)
|
||||||
|
|
||||||
|
if hidden:
|
||||||
|
# Remove hidden items
|
||||||
|
del settings[key.upper()]
|
||||||
|
|
||||||
for key, value in settings.items():
|
for key, value in settings.items():
|
||||||
validator = cls.get_setting_validator(key)
|
validator = cls.get_setting_validator(key)
|
||||||
|
|
||||||
@ -545,6 +553,17 @@ class InvenTreeSetting(BaseInvenTreeSetting):
|
|||||||
even if that key does not exist.
|
even if that key does not exist.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
def save(self, *args, **kwargs):
|
||||||
|
"""
|
||||||
|
When saving a global setting, check to see if it requires a server restart.
|
||||||
|
If so, set the "SERVER_RESTART_REQUIRED" setting to True
|
||||||
|
"""
|
||||||
|
|
||||||
|
super().save()
|
||||||
|
|
||||||
|
if self.requires_restart():
|
||||||
|
InvenTreeSetting.set_setting('SERVER_REQUIRES_RESTART', True, None)
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Dict of all global settings values:
|
Dict of all global settings values:
|
||||||
|
|
||||||
@ -563,6 +582,14 @@ class InvenTreeSetting(BaseInvenTreeSetting):
|
|||||||
|
|
||||||
GLOBAL_SETTINGS = {
|
GLOBAL_SETTINGS = {
|
||||||
|
|
||||||
|
'SERVER_RESTART_REQUIRED': {
|
||||||
|
'name': _('Restart required'),
|
||||||
|
'description': _('A setting has been changed which requires a server restart'),
|
||||||
|
'default': False,
|
||||||
|
'validator': bool,
|
||||||
|
'hidden': True,
|
||||||
|
},
|
||||||
|
|
||||||
'INVENTREE_INSTANCE': {
|
'INVENTREE_INSTANCE': {
|
||||||
'name': _('InvenTree Instance Name'),
|
'name': _('InvenTree Instance Name'),
|
||||||
'default': 'InvenTree server',
|
'default': 'InvenTree server',
|
||||||
@ -936,6 +963,18 @@ class InvenTreeSetting(BaseInvenTreeSetting):
|
|||||||
|
|
||||||
return self.__class__.get_setting(self.key)
|
return self.__class__.get_setting(self.key)
|
||||||
|
|
||||||
|
def requires_restart(self):
|
||||||
|
"""
|
||||||
|
Return True if this setting requires a server restart after changing
|
||||||
|
"""
|
||||||
|
|
||||||
|
options = InvenTreeSetting.GLOBAL_SETTINGS.get(self.key, None)
|
||||||
|
|
||||||
|
if options:
|
||||||
|
return options.get('requires_restart', False)
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
class InvenTreeUserSetting(BaseInvenTreeSetting):
|
class InvenTreeUserSetting(BaseInvenTreeSetting):
|
||||||
"""
|
"""
|
||||||
|
@ -251,6 +251,15 @@ def global_settings(*args, **kwargs):
|
|||||||
return InvenTreeSetting.allValues()
|
return InvenTreeSetting.allValues()
|
||||||
|
|
||||||
|
|
||||||
|
@register.simple_tag()
|
||||||
|
def visible_global_settings(*args, **kwargs):
|
||||||
|
"""
|
||||||
|
Return any global settings which are not marked as 'hidden'
|
||||||
|
"""
|
||||||
|
|
||||||
|
return InvenTreeSetting.allValues(exclude_hidden=True)
|
||||||
|
|
||||||
|
|
||||||
@register.simple_tag()
|
@register.simple_tag()
|
||||||
def progress_bar(val, max, *args, **kwargs):
|
def progress_bar(val, max, *args, **kwargs):
|
||||||
"""
|
"""
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
{% settings_value 'BARCODE_ENABLE' as barcodes %}
|
{% settings_value 'BARCODE_ENABLE' as barcodes %}
|
||||||
{% settings_value 'REPORT_ENABLE_TEST_REPORT' as test_report_enabled %}
|
{% settings_value 'REPORT_ENABLE_TEST_REPORT' as test_report_enabled %}
|
||||||
{% settings_value "REPORT_ENABLE" as report_enabled %}
|
{% settings_value "REPORT_ENABLE" as report_enabled %}
|
||||||
|
{% settings_value "SERVER_RESTART_REQUIRED" as server_restart_required %}
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
@ -86,6 +87,21 @@
|
|||||||
</div>
|
</div>
|
||||||
<main class='col ps-md-2 pt-2 pe-2'>
|
<main class='col ps-md-2 pt-2 pe-2'>
|
||||||
|
|
||||||
|
{% if server_restart_required %}
|
||||||
|
<div class='notification-area' id='restart-required'>
|
||||||
|
<div id='alert-restart-server' class='alert alert-danger' role='alert'>
|
||||||
|
<span class='fas fa-server'></span>
|
||||||
|
<b>{% trans "Server Restart Required" %}</b>
|
||||||
|
<small>
|
||||||
|
<br>
|
||||||
|
{% trans "A configuration option has been changed which requires a server restart" %}.
|
||||||
|
<br>
|
||||||
|
{% trans "Contact your system administrator for further information" %}
|
||||||
|
</small>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
{% block alerts %}
|
{% block alerts %}
|
||||||
<div class='notification-area' id='alerts'>
|
<div class='notification-area' id='alerts'>
|
||||||
<!-- Div for displayed alerts -->
|
<!-- Div for displayed alerts -->
|
||||||
|
@ -13,7 +13,7 @@ const user_settings = {
|
|||||||
{% endfor %}
|
{% endfor %}
|
||||||
};
|
};
|
||||||
|
|
||||||
{% global_settings as GLOBAL_SETTINGS %}
|
{% visible_global_settings as GLOBAL_SETTINGS %}
|
||||||
const global_settings = {
|
const global_settings = {
|
||||||
{% for key, value in GLOBAL_SETTINGS.items %}
|
{% for key, value in GLOBAL_SETTINGS.items %}
|
||||||
{{ key }}: {% primitive_to_javascript value %},
|
{{ key }}: {% primitive_to_javascript value %},
|
||||||
|
Loading…
Reference in New Issue
Block a user