From 3e57fe4d6bfdb01fb276793f07bd1366010bd0d4 Mon Sep 17 00:00:00 2001 From: Szilard Parrag Date: Fri, 19 Jan 2024 10:49:08 +0100 Subject: [PATCH] fix(syslog-ng): add port to OpenObserve output Signed-off-by: Szilard Parrag --- ...banzaicloud.io_syslogngclusteroutputs.yaml | 2 + ...ogging.banzaicloud.io_syslogngoutputs.yaml | 2 + ...banzaicloud.io_syslogngclusteroutputs.yaml | 2 + ...ogging.banzaicloud.io_syslogngoutputs.yaml | 2 + .../plugins/syslogng-outputs/openobserve.md | 8 +- go.work.sum | 4 + .../config/output_tests/openobserve_test.go | 84 ++++++++++++++++++- .../model/syslogng/output/openobserve.go | 11 ++- 8 files changed, 110 insertions(+), 5 deletions(-) diff --git a/charts/logging-operator/crds/logging.banzaicloud.io_syslogngclusteroutputs.yaml b/charts/logging-operator/crds/logging.banzaicloud.io_syslogngclusteroutputs.yaml index fec0e65e9..0bae70fce 100644 --- a/charts/logging-operator/crds/logging.banzaicloud.io_syslogngclusteroutputs.yaml +++ b/charts/logging-operator/crds/logging.banzaicloud.io_syslogngclusteroutputs.yaml @@ -1329,6 +1329,8 @@ spec: type: object persist_name: type: string + port: + type: integer record: type: string response-action: diff --git a/charts/logging-operator/crds/logging.banzaicloud.io_syslogngoutputs.yaml b/charts/logging-operator/crds/logging.banzaicloud.io_syslogngoutputs.yaml index 3bdcb6873..759c74775 100644 --- a/charts/logging-operator/crds/logging.banzaicloud.io_syslogngoutputs.yaml +++ b/charts/logging-operator/crds/logging.banzaicloud.io_syslogngoutputs.yaml @@ -1325,6 +1325,8 @@ spec: type: object persist_name: type: string + port: + type: integer record: type: string response-action: diff --git a/config/crd/bases/logging.banzaicloud.io_syslogngclusteroutputs.yaml b/config/crd/bases/logging.banzaicloud.io_syslogngclusteroutputs.yaml index fec0e65e9..0bae70fce 100644 --- a/config/crd/bases/logging.banzaicloud.io_syslogngclusteroutputs.yaml +++ b/config/crd/bases/logging.banzaicloud.io_syslogngclusteroutputs.yaml @@ -1329,6 +1329,8 @@ spec: type: object persist_name: type: string + port: + type: integer record: type: string response-action: diff --git a/config/crd/bases/logging.banzaicloud.io_syslogngoutputs.yaml b/config/crd/bases/logging.banzaicloud.io_syslogngoutputs.yaml index 3bdcb6873..759c74775 100644 --- a/config/crd/bases/logging.banzaicloud.io_syslogngoutputs.yaml +++ b/config/crd/bases/logging.banzaicloud.io_syslogngoutputs.yaml @@ -1325,6 +1325,8 @@ spec: type: object persist_name: type: string + port: + type: integer record: type: string response-action: diff --git a/docs/configuration/plugins/syslogng-outputs/openobserve.md b/docs/configuration/plugins/syslogng-outputs/openobserve.md index 02c4e8d20..7d3e9879c 100644 --- a/docs/configuration/plugins/syslogng-outputs/openobserve.md +++ b/docs/configuration/plugins/syslogng-outputs/openobserve.md @@ -17,7 +17,7 @@ metadata: spec: openobserve: url: "https://some-openobserve-endpoint" - port: 5040 + port: 5080 organization: "default" stream: "default" user: "username" @@ -41,6 +41,12 @@ More information at https://axoflow.com/docs/axosyslog-core/chapter-destinations Name of the organization in Openobserve. +### port (int, optional) {#openobserveoutput-port} + +The port number of the OpenObserve server. Specify it here instead of appending it to the URL. + +Default: 5080 + ### record (string, optional) {#openobserveoutput-record} Arguments to the `$format-json()` template function. Default: --scope rfc5424 --exclude DATE --key ISODATE @timestamp=${ISODATE}" diff --git a/go.work.sum b/go.work.sum index 869e2f968..068286f3c 100644 --- a/go.work.sum +++ b/go.work.sum @@ -92,6 +92,7 @@ github.com/moby/sys/sequential v0.5.0/go.mod h1:tH2cOOs5V9MlPiXcQzRC+eEyab644PWK github.com/moby/sys/signal v0.7.0/go.mod h1:GQ6ObYZfqacOwTtlXvcmh9A26dVRul/hbOZn88Kg8Tg= github.com/moby/sys/symlink v0.2.0/go.mod h1:7uZVF2dqJjG/NsClqul95CqKOBRQyYSNnJ6BMgR/gFs= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= +github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f h1:y5//uYreIhSUg3J1GEMiLbxo1LJaP8RfCpH6pymGZus= github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw= github.com/nelsam/hel/v2 v2.3.3/go.mod h1:1ZTGfU2PFTOd5mx22i5O0Lc2GY933lQ2wb/ggy+rL3w= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= @@ -108,6 +109,7 @@ github.com/posener/complete v1.2.3/go.mod h1:WZIdtGGp+qx0sLrYKtIRAruyNpv6hFCicSg github.com/pquerna/cachecontrol v0.1.0/go.mod h1:NrUG3Z7Rdu85UNR3vm7SOsl1nFIeSiQnrHV5K9mBcUI= github.com/rcrowley/go-metrics v0.0.0-20200313005456-10cdbea86bc0/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs= +github.com/russross/blackfriday v1.6.0 h1:KqfZb0pUVN2lYqZUYRddxF4OR8ZMURnJIG5Y3VRLtww= github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY= github.com/soheilhy/cmux v0.1.5/go.mod h1:T7TcVDs9LWfQgPlPsdngu6I6QIoyIFZDDC6sNE1GqG0= github.com/stefanberger/go-pkcs11uri v0.0.0-20201008174630-78d3cae3a980/go.mod h1:AO3tvPzVZ/ayst6UlUKUv6rcPQInYe3IknH3jYhAKu8= @@ -149,6 +151,7 @@ golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= golang.org/x/net v0.14.0/go.mod h1:PpSgVXXLK0OxS0F31C1/tv6XNguvCrnXIDrFMspZIUI= golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= +golang.org/x/sync v0.5.0 h1:60k92dhOjHxJkrqnwsfl8KuaHbn/5dl0lUPUklKo3qE= golang.org/x/sync v0.5.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= @@ -162,6 +165,7 @@ golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= +google.golang.org/genproto v0.0.0-20230526161137-0005af68ea54 h1:9NWlQfY2ePejTmfwUH1OWwmznFa+0kKcHGPDvcPza9M= google.golang.org/genproto v0.0.0-20230526161137-0005af68ea54/go.mod h1:zqTuNwFlFRsw5zIts5VnzLQxSRqh+CGOTVMlYbY0Eyk= google.golang.org/genproto/googleapis/api v0.0.0-20230525234035-dd9d682886f9/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig= google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= diff --git a/pkg/sdk/logging/model/syslogng/config/output_tests/openobserve_test.go b/pkg/sdk/logging/model/syslogng/config/output_tests/openobserve_test.go index 51ce25129..77100f212 100644 --- a/pkg/sdk/logging/model/syslogng/config/output_tests/openobserve_test.go +++ b/pkg/sdk/logging/model/syslogng/config/output_tests/openobserve_test.go @@ -44,7 +44,7 @@ source "main_input" { }; destination "output_default_test-openobserve-out" { - openobserve-log(url("http://localhost:5080/") user("root@example.com") password("V2tsn88GhdNTKxaS") persist_name("output_default_test-openobserve-out") organization("default") stream("default")); + openobserve-log(url("http://localhost") user("root@example.com") password("V2tsn88GhdNTKxaS") persist_name("output_default_test-openobserve-out") port(5080) organization("default") stream("default")); }; `) @@ -81,7 +81,87 @@ destination "output_default_test-openobserve-out" { Spec: v1beta1.SyslogNGOutputSpec{ Openobserve: &output.OpenobserveOutput{ HTTPOutput: output.HTTPOutput{ - URL: "http://localhost:5080/", + URL: "http://localhost", + User: "root@example.com", + Password: secret.Secret{ + ValueFrom: &secret.ValueFrom{ + SecretKeyRef: &corev1.SecretKeySelector{ + LocalObjectReference: corev1.LocalObjectReference{ + Name: "openobserve", + }, + Key: "password", + }, + }}, + }, + }, + }, + }, + }, + } + + var buf strings.Builder + err := config.RenderConfigInto(testCaseInput, &buf) + config.CheckError(t, false, err) + require.Equal(t, expectedConfig, buf.String()) + +} + +func TestOpenobserveOutputWithOtherPort(t *testing.T) { + expectedConfig := config.Untab(`@version: current + +@include "scl.conf" + +source "main_input" { + channel { + source { + network(flags("no-parse") port(601) transport("tcp")); + }; + parser { + json-parser(prefix("json.")); + }; + }; +}; + +destination "output_default_test-openobserve-out" { + openobserve-log(url("http://localhost") user("root@example.com") password("V2tsn88GhdNTKxaS") persist_name("output_default_test-openobserve-out") port(5081) organization("default") stream("default")); +}; +`) + + testCaseInput := config.Input{ + Namespace: "config-test", + Name: "test", + SyslogNGSpec: &v1beta1.SyslogNGSpec{}, + ClusterOutputs: []v1beta1.SyslogNGClusterOutput{}, + ClusterFlows: []v1beta1.SyslogNGClusterFlow{}, + Flows: []v1beta1.SyslogNGFlow{}, + SourcePort: 601, + SecretLoaderFactory: &config.TestSecretLoaderFactory{ + Reader: config.SecretReader{ + Secrets: []corev1.Secret{ + { + ObjectMeta: metav1.ObjectMeta{ + Namespace: "default", + Name: "openobserve", + }, + Data: map[string][]byte{ + "password": []byte("V2tsn88GhdNTKxaS"), + }, + }, + }, + }, + MountPath: "/etc/syslog-ng/secret", + }, + Outputs: []v1beta1.SyslogNGOutput{ + { + ObjectMeta: metav1.ObjectMeta{ + Namespace: "default", + Name: "test-openobserve-out", + }, + Spec: v1beta1.SyslogNGOutputSpec{ + Openobserve: &output.OpenobserveOutput{ + Port: 5081, + HTTPOutput: output.HTTPOutput{ + URL: "http://localhost", User: "root@example.com", Password: secret.Secret{ ValueFrom: &secret.ValueFrom{ diff --git a/pkg/sdk/logging/model/syslogng/output/openobserve.go b/pkg/sdk/logging/model/syslogng/output/openobserve.go index 09aac09fb..d98d23367 100644 --- a/pkg/sdk/logging/model/syslogng/output/openobserve.go +++ b/pkg/sdk/logging/model/syslogng/output/openobserve.go @@ -30,7 +30,7 @@ metadata: spec: openobserve: url: "https://some-openobserve-endpoint" - port: 5040 + port: 5080 organization: "default" stream: "default" user: "username" @@ -53,7 +53,10 @@ type _metaOpenobserve interface{} //nolint:deadcode,unused // +kubebuilder:object:generate=true type OpenobserveOutput struct { HTTPOutput `json:",inline"` - // Name of the organization in Openobserve. + // The port number of the OpenObserve server. (default: 5080) + // Specify it here instead of appending it to the URL. + Port int `json:"port,omitempty"` + // Name of the organization in OpenObserve. Organization string `json:"organization,omitempty"` // Name of the stream in Openobserve. Stream string `json:"stream,omitempty"` @@ -63,6 +66,10 @@ type OpenobserveOutput struct { } func (o *OpenobserveOutput) BeforeRender() { + if o.Port == 0 { + o.Port = 5080 + } + if o.Organization == "" { o.Organization = "default" }