2021-02-27 15:24:22 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2022-10-03 10:12:20 +00:00
|
|
|
"io"
|
2021-02-27 15:24:22 +00:00
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
|
|
|
|
|
|
|
"github.com/julienschmidt/httprouter"
|
2021-09-03 14:25:50 +00:00
|
|
|
|
2021-11-04 21:31:41 +00:00
|
|
|
"github.com/projectdiscovery/nuclei/v2/pkg/testutils"
|
2021-02-27 15:24:22 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var workflowTestcases = map[string]testutils.TestCase{
|
2022-10-03 10:12:20 +00:00
|
|
|
"workflow/basic.yaml": &workflowBasic{},
|
|
|
|
"workflow/condition-matched.yaml": &workflowConditionMatched{},
|
|
|
|
"workflow/condition-unmatched.yaml": &workflowConditionUnmatch{},
|
|
|
|
"workflow/matcher-name.yaml": &workflowMatcherName{},
|
|
|
|
"workflow/http-value-share-workflow.yaml": &workflowHttpKeyValueShare{},
|
|
|
|
"workflow/dns-value-share-workflow.yaml": &workflowDnsKeyValueShare{},
|
2021-02-27 15:24:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type workflowBasic struct{}
|
|
|
|
|
2021-09-03 14:25:50 +00:00
|
|
|
// Execute executes a test case and returns an error if occurred
|
2021-02-27 15:24:22 +00:00
|
|
|
func (h *workflowBasic) Execute(filePath string) error {
|
|
|
|
router := httprouter.New()
|
2021-08-31 09:55:52 +00:00
|
|
|
router.GET("/", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
2021-02-27 15:24:22 +00:00
|
|
|
fmt.Fprintf(w, "This is test matcher text")
|
2021-08-31 09:55:52 +00:00
|
|
|
})
|
2021-02-27 15:24:22 +00:00
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
2021-03-05 06:38:31 +00:00
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, ts.URL, debug)
|
2021-02-27 15:24:22 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-12-15 14:03:57 +00:00
|
|
|
|
|
|
|
return expectResultsCount(results, 2)
|
2021-02-27 15:24:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type workflowConditionMatched struct{}
|
|
|
|
|
2021-09-03 14:25:50 +00:00
|
|
|
// Execute executes a test case and returns an error if occurred
|
2021-02-27 15:24:22 +00:00
|
|
|
func (h *workflowConditionMatched) Execute(filePath string) error {
|
|
|
|
router := httprouter.New()
|
2021-08-31 09:55:52 +00:00
|
|
|
router.GET("/", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
2021-02-27 15:24:22 +00:00
|
|
|
fmt.Fprintf(w, "This is test matcher text")
|
2021-08-31 09:55:52 +00:00
|
|
|
})
|
2021-02-27 15:24:22 +00:00
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
2021-03-05 06:38:31 +00:00
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, ts.URL, debug)
|
2021-02-27 15:24:22 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-12-15 14:03:57 +00:00
|
|
|
|
|
|
|
return expectResultsCount(results, 1)
|
2021-02-27 15:24:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type workflowConditionUnmatch struct{}
|
|
|
|
|
2021-09-03 14:25:50 +00:00
|
|
|
// Execute executes a test case and returns an error if occurred
|
2021-02-27 15:24:22 +00:00
|
|
|
func (h *workflowConditionUnmatch) Execute(filePath string) error {
|
|
|
|
router := httprouter.New()
|
2021-08-31 09:55:52 +00:00
|
|
|
router.GET("/", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
2021-02-27 15:24:22 +00:00
|
|
|
fmt.Fprintf(w, "This is test matcher text")
|
2021-08-31 09:55:52 +00:00
|
|
|
})
|
2021-02-27 15:24:22 +00:00
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
2021-03-05 06:38:31 +00:00
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, ts.URL, debug)
|
2021-02-27 15:24:22 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-12-15 14:03:57 +00:00
|
|
|
|
|
|
|
return expectResultsCount(results, 0)
|
2021-02-27 15:24:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type workflowMatcherName struct{}
|
|
|
|
|
2021-08-31 09:55:52 +00:00
|
|
|
// Execute executes a test case and returns an error if occurred
|
2021-02-27 15:24:22 +00:00
|
|
|
func (h *workflowMatcherName) Execute(filePath string) error {
|
|
|
|
router := httprouter.New()
|
2021-08-31 09:55:52 +00:00
|
|
|
router.GET("/", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
2021-02-27 15:24:22 +00:00
|
|
|
fmt.Fprintf(w, "This is test matcher text")
|
2021-08-31 09:55:52 +00:00
|
|
|
})
|
2021-02-27 15:24:22 +00:00
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
2021-03-05 06:38:31 +00:00
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, ts.URL, debug)
|
2021-02-27 15:24:22 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-12-15 14:03:57 +00:00
|
|
|
|
|
|
|
return expectResultsCount(results, 1)
|
2021-02-27 15:24:22 +00:00
|
|
|
}
|
2022-10-03 10:12:20 +00:00
|
|
|
|
|
|
|
type workflowHttpKeyValueShare struct{}
|
|
|
|
|
|
|
|
// Execute executes a test case and returns an error if occurred
|
|
|
|
func (h *workflowHttpKeyValueShare) Execute(filePath string) error {
|
|
|
|
router := httprouter.New()
|
|
|
|
router.GET("/path1", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
|
|
|
fmt.Fprintf(w, "href=\"test-value\"")
|
|
|
|
})
|
|
|
|
router.GET("/path2", func(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
|
|
|
|
body, _ := io.ReadAll(r.Body)
|
|
|
|
fmt.Fprintf(w, "%s", body)
|
|
|
|
})
|
|
|
|
ts := httptest.NewServer(router)
|
|
|
|
defer ts.Close()
|
|
|
|
|
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, ts.URL, debug)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return expectResultsCount(results, 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
type workflowDnsKeyValueShare struct{}
|
|
|
|
|
|
|
|
// Execute executes a test case and returns an error if occurred
|
|
|
|
func (h *workflowDnsKeyValueShare) Execute(filePath string) error {
|
|
|
|
results, err := testutils.RunNucleiWorkflowAndGetResults(filePath, "http://scanme.sh", debug)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// no results - ensure that the variable sharing works
|
|
|
|
return expectResultsCount(results, 1)
|
|
|
|
}
|