This repository has been archived by the owner on Sep 6, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
69 lines (53 loc) · 1.44 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package main
import (
"log"
"os"
"strconv"
"github.com/hibiken/asynq"
"github.com/joho/godotenv"
"github.com/vert3xo/mcscan/tasks"
"github.com/zan8in/masscan"
)
func main() {
err := godotenv.Load()
if err != nil {
log.Fatalf("failed to load .env file: %v", err)
}
redisAddr := os.Getenv("REDIS_SOCKET")
client := asynq.NewClient(asynq.RedisClientOpt{Addr: redisAddr})
defer client.Close()
rate, _ := strconv.Atoi(os.Getenv("SCAN_RATE"))
scanner, err := masscan.NewScanner(
masscan.SetParamRate(rate),
masscan.SetParamTargets(os.Getenv("SCAN_RANGE")),
masscan.SetParamExclude("255.255.255.255"),
masscan.SetParamPorts("25565"),
masscan.SetParamWait(5),
masscan.EnableDebug(),
)
if err != nil {
log.Fatalf("failed to create a scanner: %v", err)
}
if err = scanner.RunAsync(); err != nil {
log.Fatalf("failed to start the scanner: %v", err)
}
stdout := scanner.GetStdout()
go func() {
for stdout.Scan() {
res := masscan.ParseResult(stdout.Bytes())
port, _ := strconv.Atoi(res.Port)
task, err := tasks.NewGetPingResponseTask(res.IP, port)
if err != nil {
log.Fatalf("could not create task: %v", err)
}
info, err := client.Enqueue(task)
if err != nil {
log.Fatalf("could not enqueue task: %v", err)
}
log.Printf("enqueued task: id=%s queue=%s", info.ID, info.Queue)
}
}()
if err = scanner.Wait(); err != nil {
log.Fatalf("failed to wait for the scan to finish: %v", err)
}
}