Skip to content

Commit

Permalink
dirty locking...works for now...
Browse files Browse the repository at this point in the history
  • Loading branch information
bc-sb committed Nov 7, 2022
1 parent df1d189 commit 274e7a8
Show file tree
Hide file tree
Showing 13 changed files with 24 additions and 5 deletions.
4 changes: 0 additions & 4 deletions outputs/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -139,8 +139,6 @@ func NewClient(outputType string, defaultEndpointURL string, mutualTLSEnabled bo

// Post sends event (payload) to Output.
func (c *Client) Post(payload interface{}) error {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
// defer + recover to catch panic if output doesn't respond
defer func() {
if err := recover(); err != nil {
Expand Down Expand Up @@ -290,7 +288,5 @@ func (c *Client) BasicAuth(username, password string) {

// AddHeader adds an HTTP Header to the Client.
func (c *Client) AddHeader(key, value string) {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.HeaderList = append(c.HeaderList, Header{Key: key, Value: value})
}
2 changes: 2 additions & 0 deletions outputs/cliq.go
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,8 @@ func newCliqPayload(falcopayload types.FalcoPayload, config *types.Configuration
func (c *Client) CliqPost(falcopayload types.FalcoPayload) {
c.Stats.Cliq.Add(Total, 1)

c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader(ContentTypeHeaderKey, "application/json")
err := c.Post(newCliqPayload(falcopayload, c.Config))
if err != nil {
Expand Down
2 changes: 2 additions & 0 deletions outputs/fission.go
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,8 @@ func (c *Client) FissionCall(falcopayload types.FalcoPayload) {
}
log.Printf("[INFO] : %s - Function Response : %v\n", Fission, string(rawbody))
} else {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader(FissionEventIDKey, uuid.New().String())
c.ContentType = FissionContentType

Expand Down
2 changes: 2 additions & 0 deletions outputs/gcpcloudrun.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ func (c *Client) CloudRunFunctionPost(falcopayload types.FalcoPayload) {
c.Stats.GCPCloudRun.Add(Total, 1)

if c.Config.GCP.CloudRun.JWT != "" {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader(AuthorizationHeaderKey, "Bearer "+c.Config.GCP.CloudRun.JWT)
}

Expand Down
2 changes: 2 additions & 0 deletions outputs/gotify.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,8 @@ func (c *Client) GotifyPost(falcopayload types.FalcoPayload) {
c.Stats.Gotify.Add(Total, 1)

if c.Config.Gotify.Token != "" {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader("X-Gotify-Key", c.Config.Gotify.Token)
}

Expand Down
3 changes: 2 additions & 1 deletion outputs/grafana.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,8 @@ func newGrafanaPayload(falcopayload types.FalcoPayload, config *types.Configurat
func (c *Client) GrafanaPost(falcopayload types.FalcoPayload) {
c.Stats.Grafana.Add(Total, 1)
c.ContentType = GrafanaContentType

c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader("Authorization", "Bearer "+c.Config.Grafana.APIKey)

err := c.Post(newGrafanaPayload(falcopayload, c.Config))
Expand Down
2 changes: 2 additions & 0 deletions outputs/influxdb.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ func newInfluxdbPayload(falcopayload types.FalcoPayload, config *types.Configura
func (c *Client) InfluxdbPost(falcopayload types.FalcoPayload) {
c.Stats.Influxdb.Add(Total, 1)

c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader("Accept", "application/json")

if c.Config.Influxdb.Token != "" {
Expand Down
2 changes: 2 additions & 0 deletions outputs/kubeless.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ func (c *Client) KubelessCall(falcopayload types.FalcoPayload) {
}
log.Printf("[INFO] : Kubeless - Function Response : %v\n", string(rawbody))
} else {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader(KubelessEventIDKey, uuid.New().String())
c.AddHeader(KubelessEventTypeKey, KubelessEventTypeValue)
c.AddHeader(KubelessEventNamespaceKey, c.Config.Kubeless.Namespace)
Expand Down
2 changes: 2 additions & 0 deletions outputs/loki.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ func (c *Client) LokiPost(falcopayload types.FalcoPayload) {
c.Stats.Loki.Add(Total, 1)
c.ContentType = LokiContentType
if c.Config.Loki.Tenant != "" {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader("X-Scope-OrgID", c.Config.Loki.Tenant)
}

Expand Down
2 changes: 2 additions & 0 deletions outputs/nodered.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ import (
func (c *Client) NodeRedPost(falcopayload types.FalcoPayload) {
c.Stats.NodeRed.Add(Total, 1)

c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
if c.Config.NodeRed.User != "" && c.Config.NodeRed.Password != "" {
c.AddHeader("Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte(c.Config.NodeRed.User+":"+c.Config.NodeRed.Password)))
}
Expand Down
2 changes: 2 additions & 0 deletions outputs/opsgenie.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,8 @@ func newOpsgeniePayload(falcopayload types.FalcoPayload, config *types.Configura
// OpsgeniePost posts event to OpsGenie
func (c *Client) OpsgeniePost(falcopayload types.FalcoPayload) {
c.Stats.Opsgenie.Add(Total, 1)
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader(AuthorizationHeaderKey, "GenieKey "+c.Config.Opsgenie.APIKey)

err := c.Post(newOpsgeniePayload(falcopayload, c.Config))
Expand Down
2 changes: 2 additions & 0 deletions outputs/spyderbat.go
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,8 @@ func NewSpyderbatClient(config *types.Configuration, stats *types.Statistics, pr
func (c *Client) SpyderbatPost(falcopayload types.FalcoPayload) {
c.Stats.Spyderbat.Add(Total, 1)

c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
c.AddHeader("Authorization", "Bearer "+c.Config.Spyderbat.APIKey)
c.AddHeader("Content-Encoding", "gzip")

Expand Down
2 changes: 2 additions & 0 deletions outputs/webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ func (c *Client) WebhookPost(falcopayload types.FalcoPayload) {
c.Stats.Webhook.Add(Total, 1)

if len(c.Config.Webhook.CustomHeaders) != 0 {
c.httpClientLock.Lock()
defer c.httpClientLock.Unlock()
for i, j := range c.Config.Webhook.CustomHeaders {
c.AddHeader(i, j)
}
Expand Down

0 comments on commit 274e7a8

Please sign in to comment.