mirror of
https://github.com/aler9/gortsplib
synced 2025-10-05 15:16:51 +08:00

(https://github.com/bluenviron/mediamtx/issues/3116) This fixes authentication issues with some TP-LINK cameras.
95 lines
1.7 KiB
Go
95 lines
1.7 KiB
Go
package auth
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/bluenviron/gortsplib/v4/pkg/base"
|
|
)
|
|
|
|
func mustParseURL(s string) *base.URL {
|
|
u, err := base.ParseURL(s)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return u
|
|
}
|
|
|
|
func TestCombined(t *testing.T) {
|
|
for _, c1 := range []struct {
|
|
name string
|
|
methods []ValidateMethod
|
|
}{
|
|
{
|
|
"basic",
|
|
[]ValidateMethod{ValidateMethodBasic},
|
|
},
|
|
{
|
|
"digest md5",
|
|
[]ValidateMethod{ValidateMethodDigestMD5},
|
|
},
|
|
{
|
|
"digest sha256",
|
|
[]ValidateMethod{ValidateMethodSHA256},
|
|
},
|
|
{
|
|
"all",
|
|
nil,
|
|
},
|
|
} {
|
|
for _, conf := range []string{
|
|
"nofail",
|
|
"wronguser",
|
|
"wrongpass",
|
|
"wrongurl",
|
|
} {
|
|
if conf == "wrongurl" && c1.name == "basic" {
|
|
continue
|
|
}
|
|
|
|
t.Run(c1.name+"_"+conf, func(t *testing.T) {
|
|
nonce, err := GenerateNonce()
|
|
require.NoError(t, err)
|
|
|
|
se, err := NewSender(
|
|
GenerateWWWAuthenticate(c1.methods, "IPCAM", nonce),
|
|
func() string {
|
|
if conf == "wronguser" {
|
|
return "test1user"
|
|
}
|
|
return "testuser"
|
|
}(),
|
|
func() string {
|
|
if conf == "wrongpass" {
|
|
return "test1pass"
|
|
}
|
|
return "testpass"
|
|
}())
|
|
require.NoError(t, err)
|
|
|
|
req := &base.Request{
|
|
Method: base.Announce,
|
|
URL: mustParseURL(func() string {
|
|
if conf == "wrongurl" {
|
|
return "rtsp://myhost/my1path"
|
|
}
|
|
return "rtsp://myhost/mypath"
|
|
}()),
|
|
}
|
|
se.AddAuthorization(req)
|
|
|
|
req.URL = mustParseURL("rtsp://myhost/mypath")
|
|
|
|
err = Validate(req, "testuser", "testpass", c1.methods, "IPCAM", nonce)
|
|
|
|
if conf != "nofail" {
|
|
require.Error(t, err)
|
|
} else {
|
|
require.NoError(t, err)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
}
|