Ai
1 Star 0 Fork 0

MATWRK/subfinder

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
crtsh.go 2.61 KB
一键复制 编辑 原始数据 按行查看 历史
Ice3man543 提交于 2020-02-14 00:36 +08:00 . Added psql based access to crtsh
package crtsh
import (
"context"
"database/sql"
"fmt"
"io/ioutil"
"strings"
// postgres driver
_ "github.com/lib/pq"
"github.com/projectdiscovery/subfinder/pkg/subscraping"
)
// Source is the passive scraping agent
type Source struct{}
// Run function returns all subdomains found with the service
func (s *Source) Run(ctx context.Context, domain string, session *subscraping.Session) <-chan subscraping.Result {
results := make(chan subscraping.Result)
go func() {
found := s.getSubdomainsFromSQL(ctx, domain, session, results)
if found {
close(results)
return
}
_ = s.getSubdomainsFromHTTP(ctx, domain, session, results)
close(results)
}()
return results
}
func (s *Source) getSubdomainsFromSQL(ctx context.Context, domain string, session *subscraping.Session, results chan subscraping.Result) bool {
db, err := sql.Open("postgres", "host=crt.sh user=guest dbname=certwatch sslmode=disable")
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
return false
}
pattern := "%." + domain
rows, err := db.Query(`SELECT DISTINCT ci.NAME_VALUE as domain
FROM certificate_identity ci
WHERE reverse(lower(ci.NAME_VALUE)) LIKE reverse(lower($1))
ORDER BY ci.NAME_VALUE`, pattern)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
return false
}
var data string
// Parse all the rows getting subdomains
for rows.Next() {
err := rows.Scan(&data)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
return false
}
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Subdomain, Value: data}
}
return true
}
func (s *Source) getSubdomainsFromHTTP(ctx context.Context, domain string, session *subscraping.Session, results chan subscraping.Result) bool {
resp, err := session.NormalGetWithContext(ctx, fmt.Sprintf("https://crt.sh/?q=%%25.%s&output=json", domain))
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
return false
}
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Error, Error: err}
resp.Body.Close()
return false
}
resp.Body.Close()
// Also replace all newlines
src := strings.Replace(string(body), "\\n", " ", -1)
for _, subdomain := range session.Extractor.FindAllString(src, -1) {
results <- subscraping.Result{Source: s.Name(), Type: subscraping.Subdomain, Value: subdomain}
}
return true
}
// Name returns the name of the source
func (s *Source) Name() string {
return "crtsh"
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/mrturn_1/subfinder.git
git@gitee.com:mrturn_1/subfinder.git
mrturn_1
subfinder
subfinder
v2.3.2

搜索帮助