From 4bf18250373b7255e26e95d51a257e5280ad3148 Mon Sep 17 00:00:00 2001 From: Nick Ufer Date: Fri, 29 Oct 2021 11:29:09 +0200 Subject: [PATCH] fix: panic on webhook with nil body (#1890) Closes #1885 --- selfservice/hook/web_hook.go | 5 ++++- selfservice/hook/web_hook_test.go | 6 ++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/selfservice/hook/web_hook.go b/selfservice/hook/web_hook.go index 9871124f1a4c..b3b5da1b5093 100644 --- a/selfservice/hook/web_hook.go +++ b/selfservice/hook/web_hook.go @@ -263,6 +263,9 @@ func (e *WebHook) execute(data *templateContext) error { } } + if body == nil { + body = bytes.NewReader(make([]byte, 0)) + } if err = doHttpCall(conf.method, conf.url, conf.auth, body); err != nil { return fmt.Errorf("failed to call web hook %w", err) } @@ -271,7 +274,7 @@ func (e *WebHook) execute(data *templateContext) error { func createBody(l *logrusx.Logger, templateURI string, data *templateContext) (*bytes.Reader, error) { if len(templateURI) == 0 { - return nil, nil + return bytes.NewReader(make([]byte, 0)), nil } f := fetcher.NewFetcher() diff --git a/selfservice/hook/web_hook_test.go b/selfservice/hook/web_hook_test.go index 185515a06c91..27b3166fdda6 100644 --- a/selfservice/hook/web_hook_test.go +++ b/selfservice/hook/web_hook_test.go @@ -178,6 +178,12 @@ func TestJsonNetSupport(t *testing.T) { require.Len(t, hook.Entries, 1) assert.Contains(t, hook.LastEntry().Message, "support for filepaths without a 'file://' scheme will be dropped") }) + + t.Run("case=return non nil body reader on empty templateURI", func(t *testing.T) { + body, err := createBody(l, "", nil) + assert.NotNil(t, body) + assert.Nil(t, err) + }) } func TestWebHookConfig(t *testing.T) {