Skip to content
Open
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 15 additions & 1 deletion adapters/syslog/syslog.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"log/syslog"
"net"
"os"
"strings"
"text/template"
"time"

Expand All @@ -29,6 +30,16 @@ func getopt(name, dfault string) string {
return value
}

func tplGetEnvVar(env []string, key string) string {
key_equals := fmt.Sprintf("%s%s", key, "=")
Copy link
Contributor

@gaul gaul Sep 20, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

key_equals := key + "="

for _, value := range env {
if strings.HasPrefix(value, key_equals) {
return strings.Split(value, "=")[1]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

return value[strings.Index(value, "=")+1:]

}
}
return ""
}

func NewSyslogAdapter(route *router.Route) (router.LogAdapter, error) {
transport, found := router.AdapterTransports.Lookup(route.AdapterTransport("udp"))
if !found {
Expand Down Expand Up @@ -67,7 +78,10 @@ func NewSyslogAdapter(route *router.Route) (router.LogAdapter, error) {
default:
return nil, errors.New("unsupported syslog format: " + format)
}
tmpl, err := template.New("syslog").Parse(tmplStr)

funcMap := template.FuncMap{
"getEnvVar": tplGetEnvVar}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would call the function getenv more in the line of other default template functions and the normal os.Getenv go function.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't really understand your comment here. What I'm trying to do is create a new template function so you can get environment variables from the slice .Container.Config.Env , as you can see in the first code bit in my first comment.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, I understand. I just though it would be nice if the naming was more 'go-like'. Doesn't really matter much.
Cheers

tmpl, err := template.New("syslog").Funcs(funcMap).Parse(tmplStr)
if err != nil {
return nil, err
}
Expand Down