spray/cmd/cmd.go

164 lines
3.4 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"
"github.com/chainreactors/files"
2022-09-08 15:57:17 +08:00
"github.com/chainreactors/logs"
"github.com/chainreactors/spray/internal"
2024-02-08 15:26:01 +08:00
"github.com/chainreactors/spray/internal/ihttp"
"github.com/chainreactors/spray/pkg"
2022-09-15 19:27:07 +08:00
"github.com/jessevdk/go-flags"
"os"
"os/signal"
"syscall"
2022-11-10 16:52:00 +08:00
"time"
2022-09-08 15:57:17 +08:00
)
2024-08-06 16:31:22 +08:00
var ver = "v1.0.1"
var DefaultConfig = "config.yaml"
2023-05-04 12:23:24 +08:00
2024-03-07 04:24:00 +08:00
func init() {
logs.Log.SetColorMap(map[logs.Level]func(string) string{
logs.Info: logs.PurpleBold,
logs.Important: logs.GreenBold,
pkg.LogVerbose: logs.Green,
})
}
func Spray() {
var option internal.Option
if files.IsExist(DefaultConfig) {
2024-04-26 18:57:02 +08:00
logs.Log.Debug("config.yaml exist, loading")
err := internal.LoadConfig(DefaultConfig, &option)
if err != nil {
logs.Log.Error(err.Error())
return
}
}
parser := flags.NewParser(&option, flags.Default)
parser.Usage = `
WIKI: https://chainreactors.github.io/wiki/spray
QUICKSTART:
2024-08-06 16:31:22 +08:00
basic:
spray -u http://example.com
basic cidr and port:
spray -i example -p top2,top3
simple brute:
spray -u http://example.com -d wordlist1.txt -d wordlist2.txt
2024-08-06 16:31:22 +08:00
mask-base brute with wordlist:
spray -u http://example.com -w "/aaa/bbb{?l#4}/ccc"
2024-08-06 16:31:22 +08:00
rule-base brute with 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
}
2024-02-12 16:49:44 +08:00
// logs
logs.AddLevel(pkg.LogVerbose, "verbose", "[=] %s {{suffix}}")
if option.Debug {
logs.Log.SetLevel(logs.Debug)
} else if len(option.Verbose) > 0 {
logs.Log.SetLevel(pkg.LogVerbose)
}
if option.InitConfig {
configStr := internal.InitDefaultConfig(&option, 0)
2024-03-07 04:24:00 +08:00
err := os.WriteFile(DefaultConfig, []byte(configStr), 0o744)
2024-02-12 16:49:44 +08:00
if err != nil {
logs.Log.Warn("cannot create config: config.yaml, " + err.Error())
2024-02-12 16:49:44 +08:00
return
}
2024-03-07 04:24:00 +08:00
if files.IsExist(DefaultConfig) {
logs.Log.Warn("override default config: ./config.yaml")
}
logs.Log.Info("init default config: ./config.yaml")
return
}
if option.Config != "" {
err := internal.LoadConfig(option.Config, &option)
if err != nil {
logs.Log.Error(err.Error())
return
}
2024-03-07 04:24:00 +08:00
if files.IsExist(DefaultConfig) {
logs.Log.Warnf("custom config %s, override default config", option.Config)
} else {
logs.Log.Important("load config: " + option.Config)
}
2024-02-12 16:49:44 +08:00
}
2023-05-04 12:23:24 +08:00
if option.Version {
fmt.Println(ver)
return
}
if option.Format != "" {
internal.Format(option.Format, !option.NoColor)
2024-02-12 16:49:44 +08:00
return
}
2024-07-22 16:27:07 +08:00
err = option.Prepare()
2024-02-20 18:25:43 +08:00
if err != nil {
2024-07-17 01:40:30 +08:00
logs.Log.Errorf(err.Error())
return
}
2024-07-22 16:27:07 +08:00
runner, err := option.NewRunner()
if err != nil {
logs.Log.Errorf(err.Error())
return
}
2023-12-28 14:34:19 +08:00
if option.ReadAll || runner.Crawl {
ihttp.DefaultMaxBodySize = -1
2023-12-28 14:34:19 +08:00
}
ctx, canceler := context.WithTimeout(context.Background(), time.Duration(runner.Deadline)*time.Second)
go func() {
2024-07-24 04:21:43 +08:00
exitChan := make(chan os.Signal, 2)
signal.Notify(exitChan, os.Interrupt, syscall.SIGTERM)
go func() {
2024-07-24 04:21:43 +08:00
sigCount := 0
for {
<-exitChan
sigCount++
if sigCount == 1 {
logs.Log.Infof("Exit signal received, saving task and exiting...")
canceler()
} else if sigCount == 2 {
logs.Log.Infof("forcing exit...")
os.Exit(1)
}
}
}()
}()
2024-08-06 03:58:30 +08:00
err = runner.Prepare(ctx)
if err != nil {
logs.Log.Errorf(err.Error())
return
}
2024-08-06 03:58:30 +08:00
2024-07-24 13:41:03 +08:00
time.Sleep(1 * time.Second)
2022-09-08 15:57:17 +08:00
}