From a760a98bccbd38b28ad881b8a8fde0050813c91e Mon Sep 17 00:00:00 2001 From: Alessandro Ros Date: Mon, 13 Nov 2023 14:36:18 +0100 Subject: [PATCH] webrtc: fix crash when reading from path 'publish' (#2688) (#2692) --- internal/core/webrtc_http_server.go | 2 +- internal/core/webrtc_manager_test.go | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/internal/core/webrtc_http_server.go b/internal/core/webrtc_http_server.go index d6fa55ac6fd..4a471ae92d1 100644 --- a/internal/core/webrtc_http_server.go +++ b/internal/core/webrtc_http_server.go @@ -348,7 +348,7 @@ func (s *webRTCHTTPServer) onRequest(ctx *gin.Context) { case len(ctx.Request.URL.Path) >= 2: switch { - case strings.HasSuffix(ctx.Request.URL.Path, "/publish"): + case len(ctx.Request.URL.Path) > len("/publish") && strings.HasSuffix(ctx.Request.URL.Path, "/publish"): s.onPage(ctx, ctx.Request.URL.Path[1:len(ctx.Request.URL.Path)-len("/publish")], true) case ctx.Request.URL.Path[len(ctx.Request.URL.Path)-1] != '/': diff --git a/internal/core/webrtc_manager_test.go b/internal/core/webrtc_manager_test.go index 72ed4f49ee2..12c73794332 100644 --- a/internal/core/webrtc_manager_test.go +++ b/internal/core/webrtc_manager_test.go @@ -21,13 +21,13 @@ import ( func TestWebRTCPages(t *testing.T) { p, ok := newInstance("paths:\n" + - " stream:\n") + " all:\n") require.Equal(t, true, ok) defer p.Close() hc := &http.Client{Transport: &http.Transport{}} - for _, path := range []string{"/stream", "/stream/publish"} { + for _, path := range []string{"/stream", "/stream/publish", "/publish"} { func() { req, err := http.NewRequest(http.MethodGet, "http://localhost:8889"+path, nil) require.NoError(t, err)