diff --git a/apis/fluentbit/v1alpha2/clusterfluentbitconfig_types.go b/apis/fluentbit/v1alpha2/clusterfluentbitconfig_types.go index 736e159a7..54c1d3f9f 100644 --- a/apis/fluentbit/v1alpha2/clusterfluentbitconfig_types.go +++ b/apis/fluentbit/v1alpha2/clusterfluentbitconfig_types.go @@ -18,6 +18,7 @@ package v1alpha2 import ( "bytes" + "crypto/md5" "fmt" "sort" @@ -537,3 +538,24 @@ func (cfg ClusterFluentBitConfig) RenderLuaScript( return scripts, nil } + +func (cfg ClusterFluentBitConfig) RenderNamespacedLuaScript( + cl plugins.ConfigMapLoader, nsfiltersLists []FilterList) ([]Script, error) { + scripts := make([]Script, 0) + for _, nsfilters := range nsfiltersLists { + for _, f := range nsfilters.Items { + for _, p := range f.Spec.FilterItems { + if p.Lua != nil && p.Lua.Script.Key != "" { + script, err := cl.LoadConfigMap(p.Lua.Script, f.ObjectMeta.Namespace) + if err != nil { + return nil, err + } + namespacedScriptName := fmt.Sprintf("%x-%s", md5.Sum([]byte(f.ObjectMeta.Namespace)), p.Lua.Script.Key) + scripts = append(scripts, Script{Name: namespacedScriptName, Content: script}) + } + } + } + } + sort.Sort(ByName(scripts)) + return scripts, nil +} diff --git a/apis/fluentbit/v1alpha2/plugins/filter/lua_types.go b/apis/fluentbit/v1alpha2/plugins/filter/lua_types.go index 5aee10c60..7025b1a15 100644 --- a/apis/fluentbit/v1alpha2/plugins/filter/lua_types.go +++ b/apis/fluentbit/v1alpha2/plugins/filter/lua_types.go @@ -1,6 +1,8 @@ package filter import ( + "crypto/md5" + "fmt" "regexp" "strconv" "strings" @@ -93,3 +95,7 @@ func (l *Lua) Params(_ plugins.SecretLoader) (*params.KVs, error) { return kvs, nil } + +func (l *Lua) MakeNamespaced(ns string) { + l.Script.Key = fmt.Sprintf("%x-%s", md5.Sum([]byte(ns)), l.Script.Key) +} diff --git a/controllers/fluentbitconfig_controller.go b/controllers/fluentbitconfig_controller.go index 2f4fff39b..1fa149e56 100644 --- a/controllers/fluentbitconfig_controller.go +++ b/controllers/fluentbitconfig_controller.go @@ -154,12 +154,26 @@ func (r *FluentBitConfigReconciler) Reconcile(ctx context.Context, req ctrl.Requ if err != nil { return ctrl.Result{}, err } + var ns string if cfg.Spec.Namespace != nil { ns = fmt.Sprintf(*cfg.Spec.Namespace) } else { ns = os.Getenv("NAMESPACE") } + cl := plugins.NewConfigMapLoader(r.Client, ns) + // load scripts for namespaced filters + nsScripts, err := cfg.RenderNamespacedLuaScript(cl, nsFilterLists) + if err != nil { + return ctrl.Result{}, err + } + // load scripts for cluster filters + scripts, err := cfg.RenderLuaScript(cl, filters, ns) + if err != nil { + return ctrl.Result{}, err + } + scripts = append(scripts, nsScripts...) + // Inject config data into Secret sl := plugins.NewSecretLoader(r.Client, ns) mainAppCfg, err := cfg.RenderMainConfigWithTargetFormat( @@ -179,12 +193,6 @@ func (r *FluentBitConfigReconciler) Reconcile(ctx context.Context, req ctrl.Requ return ctrl.Result{}, err } - cl := plugins.NewConfigMapLoader(r.Client, ns) - scripts, err := cfg.RenderLuaScript(cl, filters, ns) - if err != nil { - return ctrl.Result{}, err - } - // Create or update the corresponding Secret sec := &corev1.Secret{ ObjectMeta: metav1.ObjectMeta{