mirror of
https://github.com/projectdiscovery/nuclei.git
synced 2025-12-17 13:55:24 +00:00
* setup claude * migrate to using errkit * fix unused imports + lint errors * update settings.json * fix url encoding issue * fix lint error * fix the path fuzzing component * fix lint error
130 lines
3.0 KiB
Go
130 lines
3.0 KiB
Go
package component
|
|
|
|
import (
|
|
"net/http"
|
|
"testing"
|
|
|
|
"github.com/projectdiscovery/retryablehttp-go"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestURLComponent(t *testing.T) {
|
|
req, err := retryablehttp.NewRequest(http.MethodGet, "https://example.com/testpath", nil)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
urlComponent := NewPath()
|
|
_, err = urlComponent.Parse(req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
var keys []string
|
|
var values []string
|
|
_ = urlComponent.Iterate(func(key string, value interface{}) error {
|
|
keys = append(keys, key)
|
|
values = append(values, value.(string))
|
|
return nil
|
|
})
|
|
|
|
require.Equal(t, []string{"1"}, keys, "unexpected keys")
|
|
require.Equal(t, []string{"testpath"}, values, "unexpected values")
|
|
|
|
err = urlComponent.SetValue("1", "newpath")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
rebuilt, err := urlComponent.Rebuild()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
require.Equal(t, "/newpath", rebuilt.Path, "unexpected URL path")
|
|
require.Equal(t, "https://example.com/newpath", rebuilt.String(), "unexpected full URL")
|
|
}
|
|
|
|
func TestURLComponent_NestedPaths(t *testing.T) {
|
|
path := NewPath()
|
|
req, err := retryablehttp.NewRequest(http.MethodGet, "https://example.com/user/753/profile", nil)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
found, err := path.Parse(req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !found {
|
|
t.Fatal("expected path to be found")
|
|
}
|
|
|
|
isSet := false
|
|
|
|
_ = path.Iterate(func(key string, value interface{}) error {
|
|
t.Logf("Key: %s, Value: %s", key, value.(string))
|
|
if !isSet && value.(string) == "753" {
|
|
isSet = true
|
|
if setErr := path.SetValue(key, "753'"); setErr != nil {
|
|
t.Fatal(setErr)
|
|
}
|
|
}
|
|
return nil
|
|
})
|
|
|
|
newReq, err := path.Rebuild()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if newReq.Path != "/user/753'/profile" {
|
|
t.Fatalf("expected path to be '/user/753'/profile', got '%s'", newReq.Path)
|
|
}
|
|
}
|
|
|
|
func TestPathComponent_SQLInjection(t *testing.T) {
|
|
path := NewPath()
|
|
req, err := retryablehttp.NewRequest(http.MethodGet, "https://example.com/user/55/profile", nil)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
found, err := path.Parse(req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !found {
|
|
t.Fatal("expected path to be found")
|
|
}
|
|
|
|
t.Logf("Original path: %s", req.Path)
|
|
|
|
// Let's see what path segments are available for fuzzing
|
|
err = path.Iterate(func(key string, value interface{}) error {
|
|
t.Logf("Key: %s, Value: %s", key, value.(string))
|
|
|
|
// Try fuzzing the "55" segment specifically (which should be key "2")
|
|
if value.(string) == "55" {
|
|
if setErr := path.SetValue(key, "55 OR True"); setErr != nil {
|
|
t.Fatal(setErr)
|
|
}
|
|
}
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
newReq, err := path.Rebuild()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
t.Logf("Modified path: %s", newReq.Path)
|
|
|
|
// Now with PathEncode, spaces are preserved correctly for SQL injection
|
|
if newReq.Path != "/user/55 OR True/profile" {
|
|
t.Fatalf("expected path to be '/user/55 OR True/profile', got '%s'", newReq.Path)
|
|
}
|
|
|
|
// Let's also test what the actual URL looks like
|
|
t.Logf("Full URL: %s", newReq.String())
|
|
}
|