Documentation
¶
Index ¶
- Variables
- type Client
- func (c *Client) Check(ip net.IP) (matched bool, value string, itemType string, err error)
- func (c *Client) CheckCDN(ip net.IP) (matched bool, value string, err error)
- func (c *Client) CheckCloud(ip net.IP) (matched bool, value string, err error)
- func (c *Client) CheckDNSResponse(dnsResponse *retryabledns.DNSData) (matched bool, value string, itemType string, err error)
- func (c *Client) CheckDomain(domain string) (*DomainInfo, error)
- func (c *Client) CheckDomainWithFallback(domain string) (matched bool, value string, itemType string, err error)
- func (c *Client) CheckIP(ipStr string) *IpInfo
- func (c *Client) CheckSuffix(fqdns ...string) (isCDN bool, provider string, itemType string, err error)
- func (c *Client) CheckWAF(ip net.IP) (matched bool, value string, err error)
- func (c *Client) CheckWappalyzer(data map[string]struct{}) (isCDN bool, provider string, err error)
- func (c *Client) Checks(ip net.IP) map[string]string
- type DomainInfo
- type InputCompiled
- type IpInfo
Constants ¶
This section is empty.
Variables ¶
var ( DefaultCDNProviders string DefaultWafProviders string DefaultCloudProviders string )
var DefaultResolvers = []string{
"180.76.76.76:53",
"112.124.47.27:53",
"1.1.1.1:53",
"223.5.5.5:53",
"223.6.6.6:53",
"1.0.0.1:53",
"8.8.8.8:53",
"8.8.4.4:53",
}
DefaultResolvers trusted (taken from fastdialer)
Functions ¶
This section is empty.
Types ¶
type Client ¶
Client checks for CDN based IPs which should be excluded during scans since they belong to third party firewalls.
func New ¶
func New() *Client
New creates cdncheck client with default options NewWithOpts should be preferred over this function
func NewWithOpts ¶
NewWithOpts creates cdncheck client with custom options
func (*Client) Check ¶
Check checks if Address belongs to one of CDN, WAF and Cloud . It is generic method for Checkxxx methods
func (*Client) CheckCloud ¶
CheckCloud checks if an Address is contained in the Cloud denylist
func (*Client) CheckDNSResponse ¶
func (c *Client) CheckDNSResponse(dnsResponse *retryabledns.DNSData) (matched bool, value string, itemType string, err error)
CheckDNSResponse is same as CheckDomainWithFallback but takes DNS response as input
func (*Client) CheckDomain ¶
func (c *Client) CheckDomain(domain string) (*DomainInfo, error)
func (*Client) CheckDomainWithFallback ¶
func (c *Client) CheckDomainWithFallback(domain string) (matched bool, value string, itemType string, err error)
Check Domain with fallback checks if Domain belongs to one of CDN, WAF and Cloud . It is generic method for Checkxxx methods Since input is Domain, as a fallback it queries CNAME records and checks if Domain is WAF
func (*Client) CheckSuffix ¶
func (c *Client) CheckSuffix(fqdns ...string) (isCDN bool, provider string, itemType string, err error)
CheckFQDN checks if fqdns are known Cloud ones
func (*Client) CheckWappalyzer ¶
CheckWappalyzer checks if the wappalyzer detection are a part of CDN
type DomainInfo ¶
type InputCompiled ¶
type InputCompiled struct { // CDN contains a list of ranges for CDN cidrs CDN map[string][]string `yaml:"Cdn,omitempty" json:"Cdn,omitempty"` // WAF contains a list of ranges for WAF cidrs WAF map[string][]string `yaml:"Waf,omitempty" json:"Waf,omitempty"` // Cloud contains a list of ranges for Cloud cidrs Cloud map[string][]string `yaml:"Cloud,omitempty" json:"Cloud,omitempty"` // Common contains a list of suffixes for major sources Common map[string][]string `yaml:"common,omitempty" json:"common,omitempty"` }
InputCompiled contains a compiled list of input structure