Documentation
¶
Overview ¶
zvelo.io safebrowsing adds support for a no-remote mode.
Index ¶
- Constants
- Variables
- func ValidURL(url string) bool
- type Config
- type PlatformType
- type SafeBrowser
- func (sb *SafeBrowser) Close() error
- func (sb *SafeBrowser) LookupURLs(urls []string) (threats [][]URLThreat, err error)
- func (sb *SafeBrowser) LookupURLsContext(ctx context.Context, urls []string) (threats [][]URLThreat, err error)
- func (sb *SafeBrowser) Status() (Stats, error)
- func (sb *SafeBrowser) WaitUntilReady(ctx context.Context) error
- type Stats
- type ThreatDescriptor
- type ThreatEntryType
- type ThreatType
- type URLThreat
Constants ¶
const ( // DefaultServerURL is the default URL for the Safe Browsing API. DefaultServerURL = "webrisk.googleapis.com" // DefaultUpdatePeriod is the default period for how often SafeBrowser will // reload its blacklist database. DefaultUpdatePeriod = 30 * time.Minute // DefaultID and DefaultVersion are the default client ID and Version // strings to send with every API call. DefaultID = "GoSafeBrowser" DefaultVersion = "1.0.0" // DefaultRequestTimeout is the default amount of time a single // api request can take. DefaultRequestTimeout = time.Minute )
const ( ThreatType_Malware = ThreatType(pb.ThreatType_MALWARE) ThreatType_SocialEngineering = ThreatType(pb.ThreatType_SOCIAL_ENGINEERING) ThreatType_UnwantedSoftware = ThreatType(pb.ThreatType_UNWANTED_SOFTWARE) ThreatType_PotentiallyHarmfulApplication = ThreatType(pb.ThreatType_POTENTIALLY_HARMFUL_APPLICATION) )
List of ThreatType constants.
const ( PlatformType_AnyPlatform = PlatformType(pb.PlatformType_ANY_PLATFORM) PlatformType_AllPlatforms = PlatformType(pb.PlatformType_ALL_PLATFORMS) PlatformType_Windows = PlatformType(pb.PlatformType_WINDOWS) PlatformType_Linux = PlatformType(pb.PlatformType_LINUX) PlatformType_Android = PlatformType(pb.PlatformType_ANDROID) PlatformType_OSX = PlatformType(pb.PlatformType_OSX) PlatformType_iOS = PlatformType(pb.PlatformType_IOS) PlatformType_Chrome = PlatformType(pb.PlatformType_CHROME) )
List of PlatformType constants.
const ( ThreatEntryType_URL = ThreatEntryType(pb.ThreatEntryType_URL) // These below are not supported yet. ThreatEntryType_Executable = ThreatEntryType(pb.ThreatEntryType_EXECUTABLE) ThreatEntryType_IPRange = ThreatEntryType(pb.ThreatEntryType_IP_RANGE) )
List of ThreatEntryType constants.
Variables ¶
var DefaultThreatLists = []ThreatDescriptor{ {ThreatType_Malware, PlatformType_AnyPlatform, ThreatEntryType_URL}, {ThreatType_SocialEngineering, PlatformType_AnyPlatform, ThreatEntryType_URL}, {ThreatType_UnwantedSoftware, PlatformType_AnyPlatform, ThreatEntryType_URL}, }
DefaultThreatLists is the default list of threat lists that SafeBrowser will maintain. Do not modify this variable.
Functions ¶
func ValidURL ¶
ValidURL parses the given string and returns true if it is a Safe Browsing compatible URL.
In general, clients can (and should) just call LookupURLs, which performs the same checks internally. This method can be useful when checking a batch of URLs, as the first parse failure will cause LookupURLs to stop processing the request and return an error.
Types ¶
type Config ¶
type Config struct { // ServerURL is the URL for the Safe Browsing API server. // If empty, it defaults to DefaultServerURL. ServerURL string // NoRemote puts the service in prefix-match only mode, where // matches are necessary but not sufficient to deem the request a match. // Results are expected to be run through the remote API downstream, with // the current instance acting as a pre-filter. NoRemote bool // ProxyURL is the URL of the proxy to use for all requests. // If empty, the underlying library uses $HTTP_PROXY environment variable. ProxyURL string // APIKey is the key used to authenticate with the Safe Browsing API // service. This field is required. APIKey string // ID and Version are client metadata associated with each API request to // identify the specific implementation of the client. // They are similar in usage to the "User-Agent" in an HTTP request. // If empty, these default to DefaultID and DefaultVersion, respectively. ID string Version string // DBPath is a path to a persistent database file. // If empty, SafeBrowser operates in a non-persistent manner. // This means that blacklist results will not be cached beyond the lifetime // of the SafeBrowser object. DBPath string // UpdatePeriod determines how often we update the internal list database. // If zero value, it defaults to DefaultUpdatePeriod. UpdatePeriod time.Duration // ThreatLists determines which threat lists that SafeBrowser should // subscribe to. The threats reported by LookupURLs will only be ones that // are specified by this list. // If empty, it defaults to DefaultThreatLists. ThreatLists []ThreatDescriptor // RequestTimeout determines the timeout value for the http client. RequestTimeout time.Duration // Logger is an io.Writer that allows SafeBrowser to write debug information // intended for human consumption. // If empty, no logs will be written. Logger io.Writer // contains filtered or unexported fields }
Config sets up the SafeBrowser object.
type PlatformType ¶
type PlatformType uint16
PlatformType is an enumeration type for platform classes. Examples of platform classes are Windows, Linux, Android, etc.
func (PlatformType) String ¶
func (pt PlatformType) String() string
type SafeBrowser ¶
type SafeBrowser struct {
// contains filtered or unexported fields
}
SafeBrowser is a client implementation of API v4.
It provides a set of lookup methods that allows the user to query whether certain entries are considered a threat. The implementation manages all of local database and caching that would normally be needed to interact with the API server.
func NewSafeBrowser ¶
func NewSafeBrowser(conf Config) (*SafeBrowser, error)
NewSafeBrowser creates a new SafeBrowser.
The conf struct allows the user to configure many aspects of the SafeBrowser's operation.
func (*SafeBrowser) Close ¶
func (sb *SafeBrowser) Close() error
Close cleans up all resources. This method must not be called concurrently with other lookup methods.
func (*SafeBrowser) LookupURLs ¶
func (sb *SafeBrowser) LookupURLs(urls []string) (threats [][]URLThreat, err error)
LookupURLs looks up the provided URLs. It returns a list of threats, one for every URL requested, and an error if any occurred. It is safe to call this method concurrently.
The outer dimension is across all URLs requested, and will always have the same length as urls regardless of whether an error occurs or not. The inner dimension is across every fragment that a given URL produces. For some URL at index i, one can check for a hit on any blacklist by checking if len(threats[i]) > 0. The ThreatEntryType field in the inner ThreatDescriptor will be set to ThreatEntryType_URL as this is a URL lookup.
If an error occurs, the caller should treat the threats list returned as a best-effort response to the query. The results may be stale or be partial.
func (*SafeBrowser) LookupURLsContext ¶
func (sb *SafeBrowser) LookupURLsContext(ctx context.Context, urls []string) (threats [][]URLThreat, err error)
LookupURLsContext looks up the provided URLs. The request will be canceled if the provided Context is canceled, or if Config.RequestTimeout has elapsed. It is safe to call this method concurrently.
See LookupURLs for details on the returned results.
func (*SafeBrowser) Status ¶
func (sb *SafeBrowser) Status() (Stats, error)
Status reports the status of SafeBrowser. It returns some statistics regarding the operation, and an error representing the status of its internal state. Most errors are transient and will recover themselves after some period.
func (*SafeBrowser) WaitUntilReady ¶
func (sb *SafeBrowser) WaitUntilReady(ctx context.Context) error
WaitUntilReady blocks until the database is not in an error state. Returns nil when the database is ready. Returns an error if the provided context is canceled or if the SafeBrowser instance is Closed.
type Stats ¶
type Stats struct { QueriesByDatabase int64 // Number of queries satisfied by the database alone QueriesByCache int64 // Number of queries satisfied by the cache alone QueriesByAPI int64 // Number of queries satisfied by an API call QueriesFail int64 // Number of queries that could not be satisfied DatabaseUpdateLag time.Duration // Duration since last *missed* update. 0 if next update is in the future. }
Stats records statistics regarding SafeBrowser's operation.
type ThreatDescriptor ¶
type ThreatDescriptor struct { ThreatType ThreatType PlatformType PlatformType ThreatEntryType ThreatEntryType }
A ThreatDescriptor describes a given threat, which itself is composed of several parameters along different dimensions: ThreatType, PlatformType, and ThreatEntryType.
type ThreatEntryType ¶
type ThreatEntryType uint16
ThreatEntryType is an enumeration type for threat entries. Examples of threat entries are via URLs, binary digests, and IP address ranges.
func (ThreatEntryType) String ¶
func (tet ThreatEntryType) String() string
type ThreatType ¶
type ThreatType uint16
ThreatType is an enumeration type for threats classes. Examples of threat classes are malware, social engineering, etc.
func (ThreatType) String ¶
func (tt ThreatType) String() string
type URLThreat ¶
type URLThreat struct { Pattern string ThreatDescriptor }
A URLThreat is a specialized ThreatDescriptor for the URL threat entry type.
Directories
¶
Path | Synopsis |
---|---|
cmd
|
|
sblookup
Command sblookup is a tool for looking up URLs via the command-line.
|
Command sblookup is a tool for looking up URLs via the command-line. |
sbserver
Command sbserver is an application for serving URL lookups via a simple API.
|
Command sbserver is an application for serving URL lookups via a simple API. |
internal
|
|
safebrowsing_proto
Package safebrowsing_proto is a generated protocol buffer package.
|
Package safebrowsing_proto is a generated protocol buffer package. |