Fixed PHP timeout option merging bug

This commit is contained in:
Marc Aymerich 2015-06-05 09:57:06 +00:00
parent b4670610ee
commit c8ceff0358
6 changed files with 26 additions and 19 deletions

View file

@ -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

View file

@ -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)

View file

@ -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),

View file

@ -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:

View file

@ -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)

View file

@ -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():