ZuploZuplo
LoginStart for Free
  • Documentation
  • API Reference
Introduction
Getting Started
    Develop using the Portal
      1 - Setup Your Gateway2 - Rate Limiting3 - API Key Auth4 - Deploy5 - Dynamic Rate LimitingMCP - Quick start
    Develop Locally
      1 - Setup Your Gateway2 - Rate Limiting3 - API Key Auth
Concepts
Development
Policies
    Policy Catalog
    Authentication
    Authorization
      AuthZEN Authorization PolicyOkta FGA Authorization PolicyOpenFGA Authorization PolicyAxiomatics Authorization PolicyJWT Scope Validation PolicyAccess Control List PolicyRBAC Authorization PolicyGeo-location filtering PolicyIP Restriction Policy
    Security & Validation
    Metrics, Billing & Quotas
    Testing
    Request Modification
    Response Modification
    Upstream Authentication
    Archival
    GraphQL
    Other
    Guides
Handlers
API Keys
MCP Server
MCP Gateway
AI Gateway
Developer Portal
Monetization
Deploying & Source Control
Observability
Networking & Infrastructure
Account Management
Programming API
Build with AI
Zuplo CLI
Migration Guides
Platform LimitsSecuritySupportTrust & ComplianceChangelog
powered by Zudoku
Authorization

Geo-location filtering Policy

Block requests based on geo-location parameters: country, region code, and ASN

Configuration

The configuration shows how to configure the policy in the 'policies.json' document.

config/policies.json
{ "name": "my-geo-filter-inbound-policy", "policyType": "geo-filter-inbound", "handler": { "export": "GeoFilterInboundPolicy", "module": "$import(@zuplo/runtime)", "options": { "allow": { "asns": "395747, 28304", "countries": "US, CA", "regionCodes": "TX, WA" }, "block": { "asns": "395747, 28304", "countries": "US, CA", "regionCodes": "TX, WA" }, "ignoreUnknown": true } } }

Policy Configuration

  • name <string> - The name of your policy instance. This is used as a reference in your routes.
  • policyType <string> - The identifier of the policy. This is used by the Zuplo UI. Value should be geo-filter-inbound.
  • handler.export <string> - The name of the exported type. Value should be GeoFilterInboundPolicy.
  • handler.module <string> - The module containing the policy. Value should be $import(@zuplo/runtime).
  • handler.options <object> - The options for this policy. See Policy Options below.

Policy Options

The options for this policy are specified below. All properties are optional unless specifically marked as required.

  • block <object> - No description available.
    • countries <string> - comma separated string of country codes to allow (e.g. "US, CA").
    • regionCodes <string> - comma separated string of region codes to allow (e.g. "TX, WA").
    • asns <string> - comma separated string of ASNs to allow (e.g. "395747, 28304").
  • allow <object> - No description available.
    • countries <string> - comma separated string of country codes to allow (e.g. "US, CA").
    • regionCodes <string> - comma separated string of region codes to allow (e.g. "TX, WA").
    • asns <string> - comma separated string of ASNs to allow (e.g. "395747, 28304").
  • ignoreUnknown <boolean> - Specifies whether unknown geo-location parameters should be ignored (allowed through). Defaults to true.

Using the Policy

Geo-location Filter Policy

Specify an allow list or block list of:

  • Countries - Country of the incoming request. The two-letter country code in the request, for example, "US".
  • regionCodes - If known, the ISO 3166-2 code for the first-level region associated with the IP address of the incoming request, for example, "TX"
  • ASNs - ASN of the incoming request, for example, 395747.

If you specify an allow and block list for the same location type (e.g. country) may have no effect or block all requests.

Code
{ "allow" : { "countries" : "US" }, "block" : { "countries" : "MC" } }

The policy will only allow requests from US, so any request from MC would be automatically blocked.

Read more about how policies work

Edit this page
Last modified on May 29, 2026
RBAC Authorization PolicyIP Restriction Policy
On this page
  • Configuration
    • Policy Configuration
    • Policy Options
  • Using the Policy
  • Geo-location Filter Policy
JSON