nuclei/v2/pkg/extractors/extractors.go

59 lines
1.4 KiB
Go
Raw Normal View History

2020-04-06 00:05:01 +05:30
package extractors
import "regexp"
// Extractor is used to extract part of response using a regex.
type Extractor struct {
// Type is the type of the matcher
Type string `yaml:"type"`
2020-04-06 00:05:01 +05:30
// Regex are the regex pattern required to be present in the response
Regex []string `yaml:"regex"`
2020-04-06 00:05:01 +05:30
// regexCompiled is the compiled variant
regexCompiled []*regexp.Regexp
2020-04-06 00:05:01 +05:30
// Part is the part of the request to match
//
// By default, matching is performed in request body.
Part string `yaml:"part,omitempty"`
// part is the part of the request to match
part Part
}
// ExtractorType is the type of the extractor specified
type ExtractorType = int
const (
// RegexExtractor extracts responses with regexes
RegexExtractor ExtractorType = iota + 1
)
// ExtractorTypes is an table for conversion of extractor type from string.
var ExtractorTypes = map[string]ExtractorType{
"regex": RegexExtractor,
}
2020-04-06 00:05:01 +05:30
// Part is the part of the request to match
type Part int
const (
// BodyPart matches body of the response.
BodyPart Part = iota + 1
// HeaderPart matches headers of the response.
HeaderPart
// AllPart matches both response body and headers of the response.
AllPart
)
// PartTypes is an table for conversion of part type from string.
var PartTypes = map[string]Part{
"body": BodyPart,
"header": HeaderPart,
"all": AllPart,
}
// GetPart returns the part of the matcher
func (e *Extractor) GetPart() Part {
return e.part
}