Merge pull request #4 from Ice3man543/development

Added Hackertarget API Data Source
master
Nizamul Rana 2018-04-03 17:30:10 +05:30 committed by GitHub
commit f07594d588
2 changed files with 69 additions and 1 deletions

View File

@ -0,0 +1,58 @@
//
// hackertaget.go : A golang based Hackertarget subdomains search client
// Written By : @ice3man (Nizamul Rana)
//
// Distributed Under MIT License
// Copyrights (C) 2018 Ice3man
//
package hackertarget
import (
"io/ioutil"
"strings"
"bufio"
"fmt"
"subfinder/libsubfinder/helper"
)
//
// Query : Queries awesome Hackertarget subdomain search service
// @param state : current application state, holds all information found
//
// @return subdomain : String array containing subdomains found
// @return err : nil if successfull and error if failed
//
func Query(state *helper.State) (subdomains []string, err error) {
// Make a http request to CRT.SH server and request output in JSON
// format.
// I Think 5 minutes would be more than enough for CRT.SH :-)
resp, err := helper.GetHTTPResponse("https://api.hackertarget.com/hostsearch/?q="+state.Domain, 3000)
if err != nil {
return subdomains, err
}
// Get the response body
resp_body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return subdomains, err
}
scanner := bufio.NewScanner(strings.NewReader(string(resp_body)))
for scanner.Scan() {
subdomain := strings.Split(scanner.Text(), ",")[0]
subdomains = append(subdomains, subdomain)
if state.Verbose == true {
if state.Color == true {
fmt.Printf("\n[\033[31;1;4mHACKERTARGET\033[0m] %s", subdomain)
} else {
fmt.Printf("\n[HACKERTARGET] %s", subdomain)
}
}
}
return subdomains, nil
}

View File

@ -16,9 +16,10 @@ import (
"subfinder/libsubfinder/helper"
// Load different Data sources
// Load different Passive data sources
"subfinder/libsubfinder/sources/certspotter"
"subfinder/libsubfinder/sources/crtsh"
"subfinder/libsubfinder/sources/hackertarget"
"subfinder/libsubfinder/sources/threatcrowd"
"subfinder/libsubfinder/sources/virustotal"
"subfinder/libsubfinder/sources/netcraft"
@ -93,6 +94,15 @@ func main() {
finalPassiveSubdomains = append(finalPassiveSubdomains, subdomain)
}
fmt.Printf("\n\n[-] Trying Hackertarget API")
hackertargetResults, err := hackertarget.Query(state)
if err != nil {
fmt.Println(err)
}
for _, subdomain := range hackertargetResults {
finalPassiveSubdomains = append(finalPassiveSubdomains, subdomain)
}
fmt.Printf("\n\n[-] Trying Virustotal Domain Query")
virustotalResults, err := virustotal.Query(state)
if err != nil {