Skip to content

Commit

Permalink
tags for logs
Browse files Browse the repository at this point in the history
  • Loading branch information
chaudharysaket committed Jul 10, 2024
1 parent d0a6c2e commit 5fb691c
Show file tree
Hide file tree
Showing 3 changed files with 142 additions and 0 deletions.
12 changes: 12 additions & 0 deletions config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ type Configuration struct {
LogEndpoint string
LogLevel string
LogServerHost string
NRTags string
NRDelimiter string
ClientTimeout time.Duration
}

Expand All @@ -53,6 +55,8 @@ func ConfigurationFromEnvironment() *Configuration {
sendFunctionLogsStr, sendFunctionLogsOverride := os.LookupEnv("NEW_RELIC_EXTENSION_SEND_FUNCTION_LOGS")
logServerHostStr, logServerHostOverride := os.LookupEnv("NEW_RELIC_LOG_SERVER_HOST")
collectTraceIDStr, collectTraceIDOverride := os.LookupEnv("NEW_RELIC_COLLECT_TRACE_ID")
NRTags, NRTagsOverride := os.LookupEnv("NR_TAGS")
NRDelimiter, NRDelimiterOverride := os.LookupEnv("NR_ENV_DELIMITER")

extensionEnabled := true
if extensionEnabledOverride && strings.ToLower(enabledStr) == "false" {
Expand Down Expand Up @@ -96,6 +100,14 @@ func ConfigurationFromEnvironment() *Configuration {
ret.LogEndpoint = logEndpoint
}

if NRTagsOverride {
ret.NRTags = NRTags
}

if NRDelimiterOverride {
ret.NRDelimiter = NRDelimiter
}

if ripeMillisOverride {
ripeMillis, err := strconv.ParseUint(ripeMillisStr, 10, 32)
if err == nil {
Expand Down
28 changes: 28 additions & 0 deletions telemetry/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"log"
"net"
"net/http"
"os"
"strings"
"time"

Expand Down Expand Up @@ -283,13 +284,40 @@ func (c *Client) SendFunctionLogs(ctx context.Context, invokedFunctionARN string
return nil
}

// getNewRelicTags adds tags to the logs if NR_TAGS has values
func getNewRelicTags(common map[string]interface{}) {
nrTagsStr := os.Getenv("NR_TAGS")
nrDelimiter := os.Getenv("NR_ENV_DELIMITER")
if nrDelimiter == "" {
nrDelimiter = ";"
}

if nrTagsStr != "" {
tags := strings.Split(nrTagsStr, nrDelimiter)
nrTags := make(map[string]string)
for _, tag := range tags {
fmt.Println(tag)
keyValue := strings.Split(tag, ":")
if len(keyValue) == 2 {
nrTags[keyValue[0]] = keyValue[1]
}
}

for k, v := range nrTags {
common[k] = v
}
}
}

// buildLogPayloads is a helper function that improves readability of the SendFunctionLogs method
func (c *Client) buildLogPayloads(ctx context.Context, invokedFunctionARN string, lines []logserver.LogLine) ([]*bytes.Buffer, requestBuilder, error) {
common := map[string]interface{}{
"plugin": util.Id,
"faas.arn": invokedFunctionARN,
"faas.name": c.functionName,
}

getNewRelicTags(common)

logMessages := make([]FunctionLogMessage, 0, len(lines))
for _, l := range lines {
Expand Down
102 changes: 102 additions & 0 deletions telemetry/client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (
"io"
"net/http"
"net/http/httptest"
"os"
"sync/atomic"
"testing"
"time"
Expand Down Expand Up @@ -462,3 +463,104 @@ func TestGetLogEndpointURL(t *testing.T) {
assert.Equal(t, LogEndpointUS, getLogEndpointURL("us mock license key", ""))
assert.Equal(t, LogEndpointEU, getLogEndpointURL("eu mock license key", ""))
}
func TestGetNewRelicTags(t *testing.T) {
os.Setenv("NR_TAGS", "env:prod;team:myTeam")
os.Setenv("NR_ENV_DELIMITER", ";")

tests := []struct {
name string
common map[string]interface{}
expected map[string]interface{}
envTags string
envDelimiter string
}{
{
name: "Add New Relic tags to common",
common: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
expected: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
"env": "prod",
"team": "myTeam",
},
envTags: "env:prod;team:myTeam",
envDelimiter: ";",
},
{
name: "Add New Relic tags to common if no delimiter is set",
common: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
expected: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
"env": "prod",
"team": "myTeam",
},
envTags: "env:prod;team:myTeam",
},
{
name: "No New Relic tags to common if delimiter is incorrect",
common: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
expected: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
envTags: "env:prod;team:myTeam",
envDelimiter: ",",
},
{
name: "No New Relic tags to add",
common: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
expected: map[string]interface{}{
"plugin": "testPlugin",
"faas.arn": "arn:aws:lambda:us-east-1:123456789012:function:testFunction",
"faas.name": "testFunction",
},
envTags: "",
envDelimiter: "",
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
os.Setenv("NR_TAGS", tt.envTags)
os.Setenv("NR_ENV_DELIMITER", tt.envDelimiter)

common := make(map[string]interface{}, len(tt.common))
for k, v := range tt.common {
common[k] = v
}

getNewRelicTags(common)

for k, v := range tt.expected {
if common[k] != v {
t.Errorf("expected common[%q] to be %v, but got %v", k, v, common[k])
}
}
for k := range common {
if _, ok := tt.expected[k]; !ok {
t.Errorf("unexpected key %q in common map", k)
}
}
})
}
}

0 comments on commit 5fb691c

Please sign in to comment.