## Create or replace an origin cloud region mapping `client.cache.originCloudRegions.update(stringoriginIP, OriginCloudRegionUpdateParamsparams, RequestOptionsoptions?): OriginCloudRegion` **put** `/zones/{zone_id}/origin/cloud_regions/{origin_ip}` Creates a new IP-to-cloud-region mapping or replaces the existing mapping for the specified IP. PUT is idempotent — calling it repeatedly with the same body produces the same result. The IP path parameter is normalized to canonical form (RFC 5952 for IPv6) before storage. The vendor and region are validated against the list from `GET /zones/{zone_id}/origin/cloud_regions/supported_regions`. Returns 400 if the `origin_ip` in the body does not match the URL path parameter. Returns 403 (code 1164) when the zone has reached the limit of 3,500 IP mappings. ### Parameters - `originIP: string` - `params: OriginCloudRegionUpdateParams` - `zone_id: string` Path param: Identifier. - `origin_ip: string` Body param: Origin IP address (IPv4 or IPv6). For the single PUT endpoint (`PUT /origin/cloud_regions/{origin_ip}`), this field must match the path parameter or the request will be rejected with a 400 error. For the batch PUT endpoint, this field identifies which mapping to upsert. - `region: string` Body param: Cloud vendor region identifier. Must be a valid region for the specified vendor as returned by the supported_regions endpoint. - `vendor: "aws" | "azure" | "gcp" | "oci"` Body param: Cloud vendor hosting the origin. Must be one of the supported vendors. - `"aws"` - `"azure"` - `"gcp"` - `"oci"` ### Returns - `OriginCloudRegion` A single origin IP-to-cloud-region mapping. - `origin_ip: string` The origin IP address (IPv4 or IPv6). Normalized to canonical form (RFC 5952 for IPv6). - `region: string` Cloud vendor region identifier. - `vendor: "aws" | "azure" | "gcp" | "oci"` Cloud vendor hosting the origin. - `"aws"` - `"azure"` - `"gcp"` - `"oci"` - `modified_on?: string` Time this mapping was last modified. ### Example ```node import Cloudflare from 'cloudflare'; const client = new Cloudflare({ apiToken: process.env['CLOUDFLARE_API_TOKEN'], // This is the default and can be omitted }); const originCloudRegion = await client.cache.originCloudRegions.update('192.0.2.1', { zone_id: '023e105f4ecef8ad9ca31a8372d0c353', origin_ip: '192.0.2.1', region: 'us-east-1', vendor: 'aws', }); console.log(originCloudRegion.origin_ip); ``` #### Response ```json { "errors": [], "messages": [], "result": { "modified_on": "2026-03-01T12:00:00Z", "origin_ip": "192.0.2.1", "region": "us-east-1", "vendor": "aws" }, "success": true } ```