mirror of
https://github.com/projectdiscovery/nuclei.git
synced 2025-12-22 06:25:26 +00:00
* multi proto request genesis * adds template context dynamic vars * feat: proto level resp variables * remove proto prefix hacky logic * implement template ctx args * remove old var name logic * improve AddTemplateVars func * add multi proto comments+docs * vardump with sorted keys * fix race condition in ctx args * default initialize ctx args * use generic map * index variables with multiple values * fix nil cookies * use synclock map * fix build failure * fix lint error * resolve merge conflicts * multi proto: add unit+ integration tests * fix unit tests * Issue 3339 headless fuzz (#3790) * Basic headless fuzzing * Remove debug statements * Add integration tests * Update template * Fix recognize payload value in matcher * Update tempalte * use req.SetURL() --------- Co-authored-by: Tarun Koyalwar <tarun@projectdiscovery.io> * Auto Generate Syntax Docs + JSONSchema [Fri Jun 9 00:23:32 UTC 2023] 🤖 * Add headless header and status matchers (#3794) * add headless header and status matchers * rename headers as header * add integration test for header+status * fix typo --------- Co-authored-by: Shubham Rasal <shubham@projectdiscovery.io> Co-authored-by: GitHub Action <action@github.com> Co-authored-by: Dogan Can Bakir <65292895+dogancanbakir@users.noreply.github.com>
54 lines
1.3 KiB
Go
54 lines
1.3 KiB
Go
package vardump
|
|
|
|
import (
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/projectdiscovery/nuclei/v2/pkg/types"
|
|
mapsutil "github.com/projectdiscovery/utils/maps"
|
|
)
|
|
|
|
// EnableVarDump enables var dump for debugging optionally
|
|
var EnableVarDump bool
|
|
|
|
// DumpVariables writes the truncated dump of variables to a string
|
|
// in a formatted key-value manner.
|
|
//
|
|
// The values are truncated to return 50 characters from start and end.
|
|
func DumpVariables(data map[string]interface{}) string {
|
|
var counter int
|
|
|
|
buffer := &strings.Builder{}
|
|
buffer.Grow(len(data) * 78) // grow buffer to an approximate size
|
|
|
|
builder := &strings.Builder{}
|
|
// sort keys for deterministic output
|
|
keys := mapsutil.GetSortedKeys(data)
|
|
|
|
for _, k := range keys {
|
|
v := data[k]
|
|
valueString := types.ToString(v)
|
|
|
|
counter++
|
|
if len(valueString) > 50 {
|
|
builder.Grow(56)
|
|
builder.WriteString(valueString[0:25])
|
|
builder.WriteString(" .... ")
|
|
builder.WriteString(valueString[len(valueString)-25:])
|
|
valueString = builder.String()
|
|
builder.Reset()
|
|
}
|
|
valueString = strings.ReplaceAll(strings.ReplaceAll(valueString, "\r", " "), "\n", " ")
|
|
|
|
buffer.WriteString("\t")
|
|
buffer.WriteString(strconv.Itoa(counter))
|
|
buffer.WriteString(". ")
|
|
buffer.WriteString(k)
|
|
buffer.WriteString(" => ")
|
|
buffer.WriteString(valueString)
|
|
buffer.WriteString("\n")
|
|
}
|
|
final := buffer.String()
|
|
return final
|
|
}
|