Request filtering for websites
To prevent malicious actors from misusing your public API key, you can filter out unwanted identification requests. These requests are not billed and will receive an error instead of the identification result.
This page covers filtering requests made from web browsers. You can filter requests by website origin or HTTP headers. To block requests from mobile applications, see Request filtering for mobile applications.
Configuration
Inside the Dashboard, navigate to Security in the left-hand menu.
Filter by website origin
You can create a blocklist or allowlist of specific origins.
- Allowlist: If you only need to use your public API key on a few origins, you should allow only those origins and block all others.
- Blocklist: If you need to use your public API key on many origins, you can choose to only block specific origins you suspect might be stealing your API key.
To filter requests by origin:
- Navigate to the Security > Web.
- Under Websites, click Configure.
- To create an Allowlist, set Default behavior to
Forbid all besides origins listed below
. Then fill in the Exceptions field with your list of allowed origins. - Alternatively, to create a Blocklist, set Default behavior to
Allow all besides origins listed below
. Then fill in the Exceptions field with your list of blocked origins. - Click Save.
A website origin is defined by the scheme and the domain name of the URL used to access it.
You can use the wildcard character (*) as a subdomain name.
Filter by HTTP header
You can filter out identification requests by HTTP headers. Requests you might want to filter out include server-side rendering applications, crawlers, search indexing bots, or website availability monitors.
To filter requests by HTTP header:
- Navigate to the Security > Web.
- Under Forbidden HTTP Headers, click Add rule.
- Fill in the Header name.
- Choose your Match Rule.
- Fill in the Value. You can use regular expressions.
Regular expressions in header rules
The regular expression (regex) match rule is defined by the RE2 notation. To make sure you are using the correct notation, you can:
- Go to regex101.com.
- Select the Golang Flavor option on the left.
- Debug the regular expression to suit your needs.
- Copy the Regular expression and paste it into the Value field in the rule form as-is.
Limitations
- The maximum number of request filtering rules on the web is defined by Account limits. If you need more request filtering rules, please reach out to our support team.
- It can take up to 5 minutes to start filtering incoming requests after creating or editing an origin or header rule.
Rule Priority and Examples
If any rule matches, the request filtering processing stops, and the result is immediately applied. This has clear interaction when only Forbidden Origins rules are set up but might be less clear when both Allowed Origins and Forbidden HTTP Headers rules are involved. The basic precedence is as follows:
- Allowed/Forbidden Origins rules are checked first.
- Forbidden HTTP Headers rules are checked second.
Let us illustrate that interaction on a more specific example.
Rules Configuration
We'll configure two different rules
- one is going to whitelist our own website (
https://example.com
) and - the second one is going to further prohibit any headers coming from
somesocialnetwork
Referer.
Result
Because the Allowed Origins rule has strict precedence, we will see the following result.
Origin | Headers | Result |
---|---|---|
https://example.com | Referer: somesocialnetwork.com | ALLOW |
As you can see on the example, the request came through because the Allow Origins rule was applied first, and that stopped the processing despite having somesocialnetwork.com as a Referer.
Updated 2 months ago