package Plugins import ( "crypto/tls" "fmt" "io/ioutil" "net" "net/http" "strings" "time" "github.com/shadow1ng/fscan/common" ) func elasticsearchScan(info *common.HostInfo) error { _, err := geturl2(info) return err } func geturl2(info *common.HostInfo) (flag bool, err error) { flag = false url := fmt.Sprintf("%s:%d/_cat", info.Url, common.PORTList["elastic"]) var client = &http.Client{ Timeout: time.Duration(info.WebTimeout) * time.Second, Transport: &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, DisableKeepAlives: false, DialContext: (&net.Dialer{ Timeout: time.Duration(info.WebTimeout) * time.Second, }).DialContext, }, CheckRedirect: func(req *http.Request, via []*http.Request) error { return http.ErrUseLastResponse }, } res, err := http.NewRequest("GET", url, nil) if err == nil { res.Header.Add("User-agent", "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1468.0 Safari/537.36") res.Header.Add("Accept", "*/*") res.Header.Add("Accept-Language", "zh-CN,zh;q=0.9") res.Header.Add("Accept-Encoding", "gzip, deflate") res.Header.Add("Connection", "close") resp, err := client.Do(res) if err == nil { defer resp.Body.Close() body, _ := ioutil.ReadAll(resp.Body) if strings.Contains(string(body), "/_cat/master") { result := fmt.Sprintf("Elastic:%s unauthorized", url) common.LogSuccess(result) flag = true } } } return flag, err }