wappalyzer

package module
v0.2.11 Latest Latest
Warning

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

Go to latest
Published: Jan 12, 2025 License: MIT Imports: 10 Imported by: 81

README

Wappalyzergo

A high performance port of the Wappalyzer Technology Detection Library to Go. Inspired by Webanalyze.

Uses data from https://github.com/AliasIO/wappalyzer

Features

  • Very simple and easy to use, with clean codebase.
  • Normalized regexes + auto-updating database of wappalyzer fingerprints.
  • Optimized for performance: parsing HTML manually for best speed.
Using go install
go install -v github.com/projectdiscovery/wappalyzergo/cmd/update-fingerprints@latest

After this command wappalyzergo library source will be in your current go.mod.

Example

Usage Example:

package main

import (
	"fmt"
	"io"
	"log"
	"net/http"

	wappalyzer "github.com/projectdiscovery/wappalyzergo"
)

func main() {
	resp, err := http.DefaultClient.Get("https://www.hackerone.com")
	if err != nil {
		log.Fatal(err)
	}
	data, _ := io.ReadAll(resp.Body) // Ignoring error for example

	wappalyzerClient, err := wappalyzer.New()
	fingerprints := wappalyzerClient.Fingerprint(resp.Header, data)
	fmt.Printf("%v\n", fingerprints)

	// Output: map[Acquia Cloud Platform:{} Amazon EC2:{} Apache:{} Cloudflare:{} Drupal:{} PHP:{} Percona:{} React:{} Varnish:{}]
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func FormatAppVersion added in v0.1.5

func FormatAppVersion(app, version string) string

func GetCategoriesMapping added in v0.1.7

func GetCategoriesMapping() map[int]categoryItem

func GetFingerprints added in v0.0.40

func GetFingerprints() string

GetFingerprints returns the fingerprint string from wappalyzer

func GetRawFingerprints added in v0.1.7

func GetRawFingerprints() string

Types

type AppInfo added in v0.0.78

type AppInfo struct {
	Description string
	Website     string
	CPE         string
	Icon        string
	Categories  []string
}

AppInfo contains basic information about an App.

func AppInfoFromFingerprint added in v0.1.5

func AppInfoFromFingerprint(fingerprint *CompiledFingerprint) AppInfo

type CatsInfo added in v0.0.110

type CatsInfo struct {
	Cats []int
}

CatsInfo contains basic information about an App.

type CompiledFingerprint

type CompiledFingerprint struct {
	// contains filtered or unexported fields
}

CompiledFingerprint contains the compiled fingerprints from the tech json

func (*CompiledFingerprint) GetDOMRules added in v0.1.5

func (f *CompiledFingerprint) GetDOMRules() map[string]map[string]*ParsedPattern

func (*CompiledFingerprint) GetJSRules added in v0.1.5

func (f *CompiledFingerprint) GetJSRules() map[string]*ParsedPattern

type CompiledFingerprints

type CompiledFingerprints struct {
	// Apps is organized as <name, fingerprint>
	Apps map[string]*CompiledFingerprint
}

CompiledFingerprints contains a map of fingerprints for tech detection

type Fingerprint

type Fingerprint struct {
	Cats        []int                             `json:"cats"`
	CSS         []string                          `json:"css"`
	Cookies     map[string]string                 `json:"cookies"`
	Dom         map[string]map[string]interface{} `json:"dom"`
	JS          map[string]string                 `json:"js"`
	Headers     map[string]string                 `json:"headers"`
	HTML        []string                          `json:"html"`
	Script      []string                          `json:"scripts"`
	ScriptSrc   []string                          `json:"scriptSrc"`
	Meta        map[string][]string               `json:"meta"`
	Implies     []string                          `json:"implies"`
	Description string                            `json:"description"`
	Website     string                            `json:"website"`
	CPE         string                            `json:"cpe"`
	Icon        string                            `json:"icon"`
}

Fingerprint is a single piece of information about a tech validated and normalized

type Fingerprints

type Fingerprints struct {
	// Apps is organized as <name, fingerprint>
	Apps map[string]*Fingerprint `json:"apps"`
}

Fingerprints contains a map of fingerprints for tech detection

type ParsedPattern added in v0.1.7

type ParsedPattern struct {
	Confidence int
	Version    string
	SkipRegex  bool
	// contains filtered or unexported fields
}

ParsedPattern encapsulates a regular expression with additional metadata for confidence and version extraction.

func ParsePattern added in v0.1.7

func ParsePattern(pattern string) (*ParsedPattern, error)

ParsePattern extracts information from a pattern, supporting both regex and simple patterns

func (*ParsedPattern) Evaluate added in v0.1.7

func (p *ParsedPattern) Evaluate(target string) (bool, string)

type UniqueFingerprints added in v0.1.5

type UniqueFingerprints struct {
	// contains filtered or unexported fields
}

func NewUniqueFingerprints added in v0.1.5

func NewUniqueFingerprints() UniqueFingerprints

func (UniqueFingerprints) GetValues added in v0.1.5

func (u UniqueFingerprints) GetValues() map[string]struct{}

func (UniqueFingerprints) SetIfNotExists added in v0.1.5

func (u UniqueFingerprints) SetIfNotExists(value, version string, confidence int)

type Wappalyze

type Wappalyze struct {
	// contains filtered or unexported fields
}

Wappalyze is a client for working with tech detection

func New

func New() (*Wappalyze, error)

New creates a new tech detection instance

func (*Wappalyze) Fingerprint

func (s *Wappalyze) Fingerprint(headers map[string][]string, body []byte) map[string]struct{}

Fingerprint identifies technologies on a target, based on the received response headers and body.

Body should not be mutated while this function is being called, or it may lead to unexpected things.

func (*Wappalyze) FingerprintWithCats added in v0.0.110

func (s *Wappalyze) FingerprintWithCats(headers map[string][]string, body []byte) map[string]CatsInfo

FingerprintWithCats identifies technologies on a target, based on the received response headers and body. It also returns categories information about the technology, is there's any Body should not be mutated while this function is being called, or it may lead to unexpected things.

func (*Wappalyze) FingerprintWithInfo added in v0.0.78

func (s *Wappalyze) FingerprintWithInfo(headers map[string][]string, body []byte) map[string]AppInfo

FingerprintWithInfo identifies technologies on a target, based on the received response headers and body. It also returns basic information about the technology, such as description and website URL as well as icon.

Body should not be mutated while this function is being called, or it may lead to unexpected things.

func (*Wappalyze) FingerprintWithTitle

func (s *Wappalyze) FingerprintWithTitle(headers map[string][]string, body []byte) (map[string]struct{}, string)

FingerprintWithTitle identifies technologies on a target, based on the received response headers and body. It also returns the title of the page.

Body should not be mutated while this function is being called, or it may lead to unexpected things.

func (*Wappalyze) GetCompiledFingerprints added in v0.1.5

func (s *Wappalyze) GetCompiledFingerprints() *CompiledFingerprints

GetCompiledFingerprints returns the compiled fingerprints

func (*Wappalyze) GetFingerprints added in v0.1.5

func (s *Wappalyze) GetFingerprints() *Fingerprints

GetFingerprints returns the original fingerprints

Directories

Path Synopsis
cmd

Jump to

Keyboard shortcuts

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