zgrab2/zgrab2/processing.go

125 lines
2.6 KiB
Go
Raw Normal View History

package zgrab2
2017-07-14 20:44:36 +00:00
import (
2017-08-04 20:20:32 +00:00
"bufio"
2017-07-14 20:44:36 +00:00
"encoding/json"
"io"
2017-08-04 20:20:32 +00:00
"net"
2017-07-14 20:44:36 +00:00
"sync"
log "github.com/sirupsen/logrus"
2017-07-14 20:44:36 +00:00
)
type Grab struct {
2017-08-04 20:20:32 +00:00
IP *string `json:"ip,omitempty"`
Domain string `json:"domain,omitempty"`
Data map[string]protocolResponse `json:"data,omitempty"`
2017-07-14 20:44:36 +00:00
}
2017-08-04 20:20:32 +00:00
type grabTarget struct {
IP net.IP
Domain string
}
2017-07-14 20:44:36 +00:00
// not good name, should change
type protocolResponse struct {
Result interface{} `json:"result,omitempty"`
Error *error `json:"error,omitempty"`
ErrorComponent string `json:"error_component,omitempty"`
2017-07-14 20:44:36 +00:00
}
// GrabWorker calls handler for each action
2017-08-04 20:20:32 +00:00
func RunGrabWorker(input grabTarget) []byte {
protocolResult := make(map[string]protocolResponse)
for _, action := range lookups {
name, res := makeHandler(action)
protocolResult[name] = res
if res.Error != nil && !config.Mult.ContinueOnError {
break
2017-07-14 20:44:36 +00:00
}
}
2017-08-04 20:20:32 +00:00
var ipstr *string
if input.IP.String() == "<nil>" {
ipstr = nil
} else {
s := input.IP.String()
ipstr = &s
}
a := Grab{IP: ipstr, Domain: input.Domain, Data: protocolResult}
result, err := json.Marshal(a)
if err != nil {
log.Fatal(err)
}
2017-07-14 20:44:36 +00:00
return result
}
// Process sets up an output encoder, input reader, and starts grab workers
func Process(out io.Writer, mon Monitor) {
workers := config.Senders
2017-08-04 20:20:32 +00:00
processQueue := make(chan grabTarget, workers*4)
2017-07-14 20:44:36 +00:00
outputQueue := make(chan []byte, workers*4) //what is the magic 4?
//Create wait groups
var workerDone sync.WaitGroup
var outputDone sync.WaitGroup
workerDone.Add(int(workers))
outputDone.Add(1)
// Start the output encoder
go func() {
for result := range outputQueue {
if _, err := out.Write(result); err != nil {
log.Fatal(err.Error())
2017-07-14 20:44:36 +00:00
}
if _, err := out.Write([]byte("\n")); err != nil {
log.Fatal(err.Error())
2017-07-14 20:44:36 +00:00
}
}
outputDone.Done()
}()
//Start all the workers
for i := 0; i < workers; i++ {
2017-07-14 20:44:36 +00:00
go func() {
for obj := range processQueue {
//divide up, run, consolidate
result := RunGrabWorker(obj)
2017-07-14 20:44:36 +00:00
outputQueue <- result
}
workerDone.Done()
}()
}
// Read the input, send to workers
2017-08-04 20:20:32 +00:00
input := bufio.NewReader(config.inputFile)
2017-07-14 20:44:36 +00:00
for {
2017-08-04 20:20:32 +00:00
obj, err := input.ReadBytes('\n')
if err == io.EOF {
break
} else if err != nil {
log.Error(err)
}
st := string(obj)
ipnet, domain, err := ParseInput(st[:len(st)-1]) //remove newline
if err != nil {
log.Error(err)
} else {
if domain == "" {
for _, ip := range ipnet {
processQueue <- grabTarget{IP: ip}
}
} else {
processQueue <- grabTarget{Domain: domain}
}
2017-07-14 20:44:36 +00:00
}
}
close(processQueue)
workerDone.Wait()
close(outputQueue)
outputDone.Wait()
}