pkg

package
v2.9.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 7, 2022 License: GPL-3.0 Imports: 23 Imported by: 4

Documentation

Index

Constants

View Source
const (
	SMART       = "s"       // 使用port-probe探测存活的c段, 递归下降到default
	SUPERSMART  = "ss"      // 使用ip-probe探测存活的b段, 递归下降到s
	SUPERSMARTC = "sb"      // 使用port-probe探测到c段后退出
	SUPERSMARTB = "sc"      // 使用ip-probe探测存活的b段,. 递归下降到sb
	Default     = "default" // 扫描完后退出
)

Variables

View Source
var (
	NameMap = ipcs.NameMap
	PortMap = ipcs.PortMap
	TagMap  = ipcs.TagMap
	//WorkFlowMap    map[string][]*Workflow
	Extractors = make(fingers.Extractors)
)
View Source
var (
	Md5Fingers     map[string]string
	Mmh3Fingers    map[string]string
	AllHttpFingers fingers.Fingers
	TcpFingers     fingers.FingerMapper
	HttpFingers    fingers.FingerMapper
)
View Source
var (
	Win  = utils.IsWin()
	Root = utils.IsRoot()
)
View Source
var ExecuterOptions *protocols.ExecuterOptions
View Source
var Proxy func(*http.Request) (*url.URL, error)
View Source
var ProxyDialTimeout func(network, address string, timeout time.Duration) (net.Conn, error)
View Source
var ProxyUrl *url.URL
View Source
var RandomDir = "/g8kZMwp4oeKsL2in"
View Source
var TemplateMap map[string][]*templates.Template

Functions

func CollectHttpInfo

func CollectHttpInfo(result *Result, resp *http.Response)

func CollectSocketInfo

func CollectSocketInfo(result *Result, socketContent []byte)

func CompileRegexp

func CompileRegexp(s string) *regexp.Regexp

func Decode

func Decode(input string) []byte

func Encode

func Encode(input []byte) string

func FileDecode

func FileDecode(input string) []byte

func FormatCertDomains

func FormatCertDomains(domains []string) []string

func GetFilename

func GetFilename(config *Config, name string) string

func GetStatusCode

func GetStatusCode(content string) (bool, string)

从socket中获取http状态码

func HasPingPriv

func HasPingPriv() bool

func HasStdin

func HasStdin() bool

func HttpConn

func HttpConn(delay int) *http.Client

func IsExist

func IsExist(filename string) bool

func IsJson

func IsJson(content []byte) bool

func LoadConfig

func LoadConfig(typ string) []byte

func LoadFinger

func LoadFinger(t string) fingers.Fingers

加载指纹到全局变量

func LoadHashFinger

func LoadHashFinger(fs fingers.Fingers) (map[string]string, map[string]string)

func LoadNuclei

func LoadNuclei(filename string) map[string][]*templates.Template

func LoadPortConfig

func LoadPortConfig()

func LoadResultFile

func LoadResultFile(file *os.File) interface{}

func LoadTemplates

func LoadTemplates(content []byte) map[string][]*templates.Template

func ParserCmdPayload

func ParserCmdPayload(payloads []string) *protocols.ExecuterOptions

func WriteAlivedResult

func WriteAlivedResult(file *files.File, ips []string)

func WriteSmartResult

func WriteSmartResult(file *files.File, ips []string)

Types

type Config

type Config struct {
	*parsers.GOGOConfig
	// ip
	CIDRs ipcs.CIDRs `json:"-"`

	// port and probe
	//Ports         string   `json:"ports"` // 预设字符串
	PortList      []string `json:"-"` // 处理完的端口列表
	PortProbe     string   `json:"-"` // 启发式扫描预设探针
	PortProbeList []string `json:"-"` // 启发式扫描预设探针
	IpProbe       string   `json:"-"`
	IpProbeList   []uint   `json:"-"`

	// file
	IsListInput bool `json:"-"` // 从标准输入中读
	IsJsonInput bool `json:"-"` // 从标准输入中读
	NoSpray     bool `json:"-"`
	Compress    bool `json:"-"`

	// output
	FilePath       string              `json:"-"`
	Filename       string              `json:"-"`
	SmartBFilename string              `json:"-"`
	SmartCFilename string              `json:"-"`
	AlivedFilename string              `json:"-"`
	File           *File               `json:"-"`
	SmartBFile     *File               `json:"-"`
	SmartCFile     *File               `json:"-"`
	AliveFile      *File               `json:"-"`
	Tee            bool                `json:"-"`
	Outputf        string              `json:"-"`
	FileOutputf    string              `json:"-"`
	Filenamef      string              `json:"-"`
	Results        parsers.GOGOResults `json:"-"` // json反序列化后的内网,保存在内存中
	HostsMap       map[string][]string `json:"-"` // host映射表
	Filters        []string            `json:"-"`
	FilterOr       bool                `json:"-"`
}

func (*Config) Close

func (config *Config) Close()

func (*Config) GetTarget

func (config *Config) GetTarget() string

func (*Config) GetTargetName

func (config *Config) GetTargetName() string

func (*Config) HasAlivedScan

func (config *Config) HasAlivedScan() bool

func (*Config) InitFile

func (config *Config) InitFile() error

func (*Config) InitIP

func (config *Config) InitIP() error

func (*Config) IsBSmart

func (config *Config) IsBSmart() bool

func (*Config) IsCSmart added in v2.8.10

func (config *Config) IsCSmart() bool

func (*Config) IsScan

func (config *Config) IsScan() bool

func (*Config) IsSmart

func (config *Config) IsSmart() bool

func (*Config) ToJson

func (config *Config) ToJson(json_type string) string

func (*Config) Validate

func (config *Config) Validate() error

type IPMapResult

type IPMapResult map[string]*parsers.GOGOResult

func (IPMapResult) Get added in v2.9.0

func (imap IPMapResult) Get(port string) *parsers.GOGOResult

type PortFinger

type PortFinger struct {
	Name  string   `json:"name"`
	Ports []string `json:"ports"`
	Type  []string `json:"type"`
}

type Result

type Result struct {
	*parsers.GOGOResult
	HttpHosts   []string `json:"-"`
	CurrentHost string   `json:"-"`

	Open bool `json:"-"`
	//FrameworksMap map[string]bool `json:"-"`
	SmartProbe bool              `json:"-"`
	TcpConn    *net.Conn         `json:"-"`
	HttpConn   *http.Client      `json:"-"`
	Httpresp   *parsers.Response `json:"-"`
	Error      string            `json:"-"`
	ErrStat    int               `json:"-"`
	Content    string            `json:"-"`
}

func NewResult

func NewResult(ip, port string) *Result

func ToResult added in v2.9.0

func ToResult(result *parsers.GOGOResult) *Result

func (*Result) AddExtract

func (result *Result) AddExtract(extract *fingers.Extracted)

func (*Result) AddExtracts

func (result *Result) AddExtracts(extracts []*fingers.Extracted)

func (*Result) AddFramework

func (result *Result) AddFramework(f *parsers.Framework)

func (*Result) AddFrameworks

func (result *Result) AddFrameworks(fs []*parsers.Framework)

func (*Result) AddNTLMInfo

func (result *Result) AddNTLMInfo(m map[string]string, t string)

func (*Result) AddVuln

func (result *Result) AddVuln(vuln *parsers.Vuln)

func (*Result) AddVulns

func (result *Result) AddVulns(vulns []*parsers.Vuln)

func (*Result) GetHostBaseURL

func (result *Result) GetHostBaseURL() string

func (*Result) GetHostURL

func (result *Result) GetHostURL() string

func (*Result) GetHttpConn

func (result *Result) GetHttpConn(delay int) *http.Client

func (*Result) GuessFramework

func (result *Result) GuessFramework()

func (*Result) IsHttps

func (result *Result) IsHttps() bool

type ResultsData

type ResultsData struct {
	*parsers.GOGOData
}

func LoadResult

func LoadResult(content []byte) (*ResultsData, error)

func (*ResultsData) GetConfig added in v2.9.0

func (rd *ResultsData) GetConfig() *Config

func (*ResultsData) ToCobaltStrike

func (rd *ResultsData) ToCobaltStrike() string

func (*ResultsData) ToExtracteds added in v2.9.0

func (rd *ResultsData) ToExtracteds() string

func (*ResultsData) ToFormat

func (rd *ResultsData) ToFormat(isColor bool) string

type SmartData

type SmartData struct {
	Config Config   `json:"config"`
	Data   []string `json:"data"`
	IP     string   `json:"ip"`
}

type Socket

type Socket struct {
	Conn    net.Conn
	Count   int
	Timeout time.Duration
}

func NewSocket

func NewSocket(network, target string, delay int) (*Socket, error)

func (*Socket) Close

func (s *Socket) Close()

func (*Socket) Read

func (s *Socket) Read(timeout int) ([]byte, error)

func (*Socket) Request

func (s *Socket) Request(data []byte, max int) ([]byte, error)

type Workflow

type Workflow struct {
	Name        string   `json:"name"`
	Description string   `json:"description"`
	IP          string   `json:"ip"`
	IPlist      []string `json:"iplist"`
	Ports       string   `json:"ports"`
	Mod         string   `json:"mod"`
	Ping        bool     `json:"ping"`
	NoScan      bool     `json:"no-scan"`
	IpProbe     string   `json:"ipprobe"`
	SmartProbe  string   `json:"portprobe"`
	Exploit     string   `json:"exploit"`
	Verbose     int      `json:"verbose"`
	File        string   `json:"file"`
	Path        string   `json:"path"`
	Tags        []string `json:"tags"`
}

func ParseWorkflowsFromInput

func ParseWorkflowsFromInput(content []byte) []*Workflow

func (*Workflow) PrepareConfig

func (w *Workflow) PrepareConfig(rconfig Config) *Config

type WorkflowMap

type WorkflowMap map[string][]*Workflow

func LoadWorkFlow

func LoadWorkFlow() WorkflowMap

func (WorkflowMap) Choice

func (m WorkflowMap) Choice(name string) []*Workflow

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL