spray/cmd/cmd.go

132 lines
2.6 KiB
Go
Raw Normal View History

package cmd
2022-09-08 15:57:17 +08:00
import (
2022-11-10 16:52:00 +08:00
"context"
2022-09-15 19:27:07 +08:00
"fmt"
2022-09-08 15:57:17 +08:00
"github.com/chainreactors/logs"
2023-02-08 15:30:40 +08:00
"github.com/chainreactors/parsers"
2023-01-28 15:56:21 +08:00
"github.com/chainreactors/parsers/iutils"
"github.com/chainreactors/spray/internal"
"github.com/chainreactors/spray/pkg"
"github.com/chainreactors/spray/pkg/ihttp"
2022-09-15 19:27:07 +08:00
"github.com/jessevdk/go-flags"
"os"
"os/signal"
"regexp"
"syscall"
2022-11-10 16:52:00 +08:00
"time"
2022-09-08 15:57:17 +08:00
)
2023-05-04 12:23:24 +08:00
var ver = ""
func Spray() {
var option internal.Option
parser := flags.NewParser(&option, flags.Default)
parser.Usage = `
WIKI: https://chainreactors.github.io/wiki/spray
QUICKSTART:
simple example:
spray -u http://example.com -d wordlist1.txt -d wordlist2.txt
mask-base wordlist:
spray -u http://example.com -w "/aaa/bbb{?l#4}/ccc"
rule-base wordlist:
spray -u http://example.com -r rule.txt -d 1.txt
list input spray:
spray -l url.txt -r rule.txt -d 1.txt
resume:
spray --resume stat.json
`
2022-09-15 19:27:07 +08:00
_, err := parser.Parse()
if err != nil {
if err.(*flags.Error).Type != flags.ErrHelp {
fmt.Println(err.Error())
}
return
}
2023-05-04 12:23:24 +08:00
if option.Version {
fmt.Println(ver)
return
}
if option.Format != "" {
internal.Format(option.Format, !option.NoColor)
os.Exit(0)
}
err = pkg.LoadTemplates()
if err != nil {
2023-01-28 15:56:21 +08:00
iutils.Fatal(err.Error())
}
if option.Extracts != nil {
for _, e := range option.Extracts {
2023-01-28 13:15:49 +08:00
if reg, ok := pkg.ExtractRegexps[e]; ok {
pkg.Extractors[e] = reg
} else {
2023-02-08 15:30:40 +08:00
pkg.Extractors[e] = []*parsers.Extractor{
&parsers.Extractor{
Name: e,
CompiledRegexps: []*regexp.Regexp{regexp.MustCompile(e)},
},
}
}
}
}
// 一些全局变量初始化
if option.Debug {
logs.Log.Level = logs.Debug
}
2023-01-12 16:35:34 +08:00
logs.DefaultColorMap[logs.Info] = logs.PurpleBold
logs.DefaultColorMap[logs.Important] = logs.GreenBold
pkg.Distance = uint8(option.SimhashDistance)
ihttp.DefaultMaxBodySize = option.MaxBodyLength * 1024
2023-01-10 01:09:00 +08:00
internal.MaxCrawl = option.CrawlDepth
2022-12-02 19:59:15 +08:00
var runner *internal.Runner
if option.ResumeFrom != "" {
runner, err = option.PrepareRunner()
} else {
runner, err = option.PrepareRunner()
}
if option.ReadAll || runner.Crawl {
ihttp.DefaultMaxBodySize = 0
}
if err != nil {
logs.Log.Errorf(err.Error())
return
}
ctx, canceler := context.WithTimeout(context.Background(), time.Duration(runner.Deadline)*time.Second)
2022-11-10 16:52:00 +08:00
err = runner.Prepare(ctx)
2022-09-08 15:57:17 +08:00
if err != nil {
logs.Log.Errorf(err.Error())
return
}
2022-11-10 16:52:00 +08:00
go func() {
c := make(chan os.Signal, 2)
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
go func() {
<-c
logs.Log.Important("exit signal, save stat and exit")
canceler()
}()
}()
if runner.CheckOnly {
runner.RunWithCheck(ctx)
} else {
runner.Run(ctx)
}
2022-09-08 15:57:17 +08:00
}