Fixed PHP timeout option merging bug
This commit is contained in:
parent
b4670610ee
commit
c8ceff0358
3
TODO.md
3
TODO.md
|
@ -421,3 +421,6 @@ serailzer self.instance on create.
|
||||||
# use namedtuples!
|
# use namedtuples!
|
||||||
|
|
||||||
# Negative transactionsx
|
# Negative transactionsx
|
||||||
|
|
||||||
|
|
||||||
|
# check certificate: websites directive ssl + domains search on miscellaneous
|
||||||
|
|
|
@ -40,7 +40,7 @@ class WebAppOptionInline(admin.TabularInline):
|
||||||
webapp_modeladmin = get_modeladmin(self.parent_model)
|
webapp_modeladmin = get_modeladmin(self.parent_model)
|
||||||
plugin_value = webapp_modeladmin.get_plugin_value(request)
|
plugin_value = webapp_modeladmin.get_plugin_value(request)
|
||||||
plugin = AppType.get(plugin_value)
|
plugin = AppType.get(plugin_value)
|
||||||
kwargs['choices'] = plugin.get_options_choices()
|
kwargs['choices'] = plugin.get_group_options_choices()
|
||||||
# Help text based on select widget
|
# Help text based on select widget
|
||||||
target = 'this.id.replace("name", "value")'
|
target = 'this.id.replace("name", "value")'
|
||||||
kwargs['widget'] = DynamicHelpTextSelect(target, self.OPTIONS_HELP_TEXT)
|
kwargs['widget'] = DynamicHelpTextSelect(target, self.OPTIONS_HELP_TEXT)
|
||||||
|
|
|
@ -163,7 +163,7 @@ class PHPBackend(WebAppServiceMixin, ServiceController):
|
||||||
super(PHPBackend, self).commit()
|
super(PHPBackend, self).commit()
|
||||||
|
|
||||||
def get_fpm_config(self, webapp, context):
|
def get_fpm_config(self, webapp, context):
|
||||||
options = webapp.get_options(merge=self.MERGE)
|
options = webapp.type_instance.get_options()
|
||||||
context.update({
|
context.update({
|
||||||
'init_vars': webapp.type_instance.get_php_init_vars(merge=self.MERGE),
|
'init_vars': webapp.type_instance.get_php_init_vars(merge=self.MERGE),
|
||||||
'max_children': options.get('processes', settings.WEBAPPS_FPM_DEFAULT_MAX_CHILDREN),
|
'max_children': options.get('processes', settings.WEBAPPS_FPM_DEFAULT_MAX_CHILDREN),
|
||||||
|
@ -217,7 +217,7 @@ class PHPBackend(WebAppServiceMixin, ServiceController):
|
||||||
exec %(php_binary_path)s%(php_init_vars)s""") % context
|
exec %(php_binary_path)s%(php_init_vars)s""") % context
|
||||||
|
|
||||||
def get_fcgid_cmd_options(self, webapp, context):
|
def get_fcgid_cmd_options(self, webapp, context):
|
||||||
options = webapp.get_options(merge=self.MERGE)
|
options = webapp.type_instance.get_options()
|
||||||
maps = OrderedDict(
|
maps = OrderedDict(
|
||||||
MaxProcesses=options.get('processes', None),
|
MaxProcesses=options.get('processes', None),
|
||||||
IOTimeout=options.get('timeout', None),
|
IOTimeout=options.get('timeout', None),
|
||||||
|
|
|
@ -55,17 +55,7 @@ class WebApp(models.Model):
|
||||||
a = apptype.clean_data()
|
a = apptype.clean_data()
|
||||||
self.data = apptype.clean_data()
|
self.data = apptype.clean_data()
|
||||||
|
|
||||||
@cached
|
def get_options(self, **kwargs):
|
||||||
def get_options(self, merge=settings.WEBAPPS_MERGE_PHP_WEBAPPS):
|
|
||||||
kwargs = {
|
|
||||||
'webapp_id': self.pk,
|
|
||||||
}
|
|
||||||
if merge:
|
|
||||||
kwargs = {
|
|
||||||
'webapp__account': self.account_id,
|
|
||||||
'webapp__type': self.type,
|
|
||||||
'webapp__data__contains': '"php_version":"%s"' % self.data['php_version'],
|
|
||||||
}
|
|
||||||
options = OrderedDict()
|
options = OrderedDict()
|
||||||
qs = WebAppOption.objects.filter(**kwargs)
|
qs = WebAppOption.objects.filter(**kwargs)
|
||||||
for name, value in qs.values_list('name', 'value').order_by('name'):
|
for name, value in qs.values_list('name', 'value').order_by('name'):
|
||||||
|
@ -102,7 +92,7 @@ class WebApp(models.Model):
|
||||||
class WebAppOption(models.Model):
|
class WebAppOption(models.Model):
|
||||||
webapp = models.ForeignKey(WebApp, verbose_name=_("Web application"),
|
webapp = models.ForeignKey(WebApp, verbose_name=_("Web application"),
|
||||||
related_name='options')
|
related_name='options')
|
||||||
name = models.CharField(_("name"), max_length=128, choices=AppType.get_options_choices())
|
name = models.CharField(_("name"), max_length=128, choices=AppType.get_group_options_choices())
|
||||||
value = models.CharField(_("value"), max_length=256)
|
value = models.CharField(_("value"), max_length=256)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
@ -39,7 +39,7 @@ class AppType(plugins.Plugin):
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
@cached
|
@cached
|
||||||
def get_options(cls):
|
def get_group_options(cls):
|
||||||
""" Get enabled options based on cls.option_groups """
|
""" Get enabled options based on cls.option_groups """
|
||||||
groups = AppOption.get_option_groups()
|
groups = AppOption.get_option_groups()
|
||||||
options = []
|
options = []
|
||||||
|
@ -52,11 +52,11 @@ class AppType(plugins.Plugin):
|
||||||
return options
|
return options
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_options_choices(cls):
|
def get_group_options_choices(cls):
|
||||||
""" Generates grouped choices ready to use in Field.choices """
|
""" Generates grouped choices ready to use in Field.choices """
|
||||||
# generators can not be @cached
|
# generators can not be @cached
|
||||||
yield (None, '-------')
|
yield (None, '-------')
|
||||||
for group, options in cls.get_options():
|
for group, options in cls.get_group_options():
|
||||||
if group is None:
|
if group is None:
|
||||||
for option in options:
|
for option in options:
|
||||||
yield (option.name, option.verbose_name)
|
yield (option.name, option.verbose_name)
|
||||||
|
|
|
@ -59,10 +59,24 @@ class PHPApp(AppType):
|
||||||
def get_detail(self):
|
def get_detail(self):
|
||||||
return self.instance.data.get('php_version', '')
|
return self.instance.data.get('php_version', '')
|
||||||
|
|
||||||
|
@cached
|
||||||
|
def get_options(self, merge=settings.WEBAPPS_MERGE_PHP_WEBAPPS):
|
||||||
|
""" adapter to webapp.get_options that performs merging of PHP options """
|
||||||
|
kwargs = {
|
||||||
|
'webapp_id': self.instance.pk,
|
||||||
|
}
|
||||||
|
if merge:
|
||||||
|
kwargs = {
|
||||||
|
# webapp__type is not used because wordpress != php != symlink...
|
||||||
|
'webapp__account': self.instance.account_id,
|
||||||
|
'webapp__data__contains': '"php_version":"%s"' % self.instance.data['php_version'],
|
||||||
|
}
|
||||||
|
return self.instance.get_options(**kwargs)
|
||||||
|
|
||||||
def get_php_init_vars(self, merge=settings.WEBAPPS_MERGE_PHP_WEBAPPS):
|
def get_php_init_vars(self, merge=settings.WEBAPPS_MERGE_PHP_WEBAPPS):
|
||||||
""" Prepares PHP options for inclusion on php.ini """
|
""" Prepares PHP options for inclusion on php.ini """
|
||||||
init_vars = OrderedDict()
|
init_vars = OrderedDict()
|
||||||
options = self.instance.get_options(merge=merge)
|
options = self.get_options(merge=merge)
|
||||||
php_version_number = float(self.get_php_version_number())
|
php_version_number = float(self.get_php_version_number())
|
||||||
timeout = None
|
timeout = None
|
||||||
for name, value in options.items():
|
for name, value in options.items():
|
||||||
|
|
Loading…
Reference in a new issue