34 lines
1.1 KiB
Go
34 lines
1.1 KiB
Go
|
package querylog
|
||
|
|
||
|
// Client is the information required by the query log to match against clients
|
||
|
// during searches.
|
||
|
type Client struct {
|
||
|
Name string `json:"name"`
|
||
|
DisallowedRule string `json:"disallowed_rule"`
|
||
|
Whois *ClientWhois `json:"whois,omitempty"`
|
||
|
IDs []string `json:"ids"`
|
||
|
Disallowed bool `json:"disallowed"`
|
||
|
}
|
||
|
|
||
|
// ClientWhois is the filtered WHOIS data for the client.
|
||
|
//
|
||
|
// TODO(a.garipov): Merge with home.RuntimeClientWhoisInfo after the
|
||
|
// refactoring is done.
|
||
|
type ClientWhois struct {
|
||
|
City string `json:"city,omitempty"`
|
||
|
Country string `json:"country,omitempty"`
|
||
|
Orgname string `json:"orgname,omitempty"`
|
||
|
}
|
||
|
|
||
|
// clientCacheKey is the key by which a cached client information is found.
|
||
|
type clientCacheKey struct {
|
||
|
clientID string
|
||
|
ip string
|
||
|
}
|
||
|
|
||
|
// clientCache is the cache of client information found throughout a request to
|
||
|
// the query log API. It is used both to speed up the lookup, as well as to
|
||
|
// make sure that changes in client data between two lookups don't create
|
||
|
// discrepancies in our response.
|
||
|
type clientCache map[clientCacheKey]*Client
|