From c461f3e4dcbf394d564e7eb273ada48ecfdec09c Mon Sep 17 00:00:00 2001 From: Hiroshi Hatake Date: Tue, 17 Dec 2024 18:16:34 +0900 Subject: [PATCH] plugin: Detect config format and use a proper loader Signed-off-by: Hiroshi Hatake --- src/flb_plugin.c | 53 ++++++++++++++++++++++++++---------------------- 1 file changed, 29 insertions(+), 24 deletions(-) diff --git a/src/flb_plugin.c b/src/flb_plugin.c index 7e259f67711..66c86083634 100644 --- a/src/flb_plugin.c +++ b/src/flb_plugin.c @@ -422,36 +422,41 @@ int flb_plugin_load_config_file(const char *file, struct flb_config *config) return -1; } - /* - * pass to the config_format loader also in case some Yaml have been included in - * the service section through the option 'plugins_file' - */ - ret = flb_plugin_load_config_format(cf, config); - if (ret == -1) { - return -1; - } - - /* (classic mode) read all 'plugins' sections */ - mk_list_foreach(head, &cf->sections) { - section = mk_list_entry(head, struct flb_cf_section, _head); - if (strcasecmp(section->name, "plugins") != 0) { - continue; - } - - cfl_list_foreach(head_e, §ion->properties->list) { - entry = cfl_list_entry(head_e, struct cfl_kvpair, _head); - if (strcasecmp(entry->key, "path") != 0) { + if (cf->format == FLB_CF_FLUENTBIT) { + /* (classic mode) read all 'plugins' sections */ + mk_list_foreach(head, &cf->sections) { + section = mk_list_entry(head, struct flb_cf_section, _head); + if (strcasecmp(section->name, "plugins") != 0) { continue; } - /* Load plugin with router function */ - ret = flb_plugin_load_router(entry->val->data.as_string, config); - if (ret == -1) { - flb_cf_destroy(cf); - return -1; + cfl_list_foreach(head_e, §ion->properties->list) { + entry = cfl_list_entry(head_e, struct cfl_kvpair, _head); + if (strcasecmp(entry->key, "path") != 0) { + continue; + } + + /* Load plugin with router function */ + ret = flb_plugin_load_router(entry->val->data.as_string, config); + if (ret == -1) { + flb_cf_destroy(cf); + return -1; + } } } } +#ifdef FLB_HAVE_LIBYAML + else if (cf->format == FLB_CF_YAML) { + /* + * pass to the config_format loader also in case some Yaml have been included in + * the service section through the option 'plugins_file' + */ + ret = flb_plugin_load_config_format(cf, config); + if (ret == -1) { + return -1; + } + } +#endif flb_cf_destroy(cf); return 0;