Skip to main content
PATCH
/
routing
/
{routing_id}
Update a Routing
curl --request PATCH \
  --url https://api-sandbox.y.uno/v1/routing/{routing_id} \
  --header 'Content-Type: application/json' \
  --header 'PRIVATE-SECRET-KEY: <api-key>' \
  --header 'PUBLIC-API-KEY: <api-key>' \
  --header 'X-Idempotency-Key: <x-idempotency-key>' \
  --data '
{
  "name": "Updated Card routing",
  "default_route": {},
  "condition_sets": [
    {}
  ]
}
'
{
  "id": "r_8f2c1d3e-4b5a-6c7d-8e9f-0a1b2c3d4e5f",
  "account_code": "acc-uuid",
  "payment_method": "CARD",
  "name": "Updated Card routing v2",
  "default_route": {
    "steps": [
      {
        "index": 1,
        "provider_id": "STRIPE",
        "connection_id": "f1a3c4d5-..."
      }
    ]
  },
  "condition_sets": [
    {
      "sort_number": 1,
      "name": "Updated Card routing",
      "conditions": [
        {}
      ],
      "route": {}
    }
  ],
  "created_at": "2026-05-12T14:30:00Z",
  "updated_at": "2026-05-12T14:30:00Z"
}

Documentation Index

Fetch the complete documentation index at: https://docs.y.uno/llms.txt

Use this file to discover all available pages before exploring further.

Replaces the routing’s full configuration. The body has the same shape as Create a Routing — the new default_route and condition_sets[] entirely supersede the previous live state. There is no field-level merge. account_code and payment_method are sticky to the routing_id — they’re set at creation and cannot be changed by PATCH.

Path Parameters

routing_id
string
required
The id returned by Create a Routing.

Response

id
string
Unique identifier for the routing.
account_code
string
Unique code for the account.
payment_method
enum
The payment method this routing applies to (e.g., CARD).
name
string
Label for the routing.
default_route
object
The default routing logic.
condition_sets
object[]
Optional conditional logic.
created_at
string
ISO 8601 timestamp.
updated_at
string
ISO 8601 timestamp.
curl -X PATCH 'https://api.y.uno/v1/routing/r_8f2c1d3e-4b5a-6c7d-8e9f-0a1b2c3d4e5f' \
  -H 'public-api-key: <YOUR_PUBLIC_KEY>' \
  -H 'private-secret-key: <YOUR_SECRET_KEY>' \
  -H 'Content-Type: application/json' \
  -H 'X-Idempotency-Key: <UUID>' \
  -d '{
    "payment_method": "CARD",
    "name": "Card routing v2 — adds BR installments rule",
    "default_route": {
      "steps": [
        {
          "index": 1,
          "provider_id": "STRIPE",
          "connection_id": "f1a3c4d5-7b8e-4a2c-9d1e-3f4a5b6c7d8e",
          "output": [
            { "status": "DECLINED", "next": 2 }
          ]
        },
        {
          "index": 2,
          "provider_id": "ADYEN",
          "connection_id": "b2c4d5e6-1a2b-3c4d-5e6f-7a8b9c0d1e2f"
        }
      ]
    },
    "condition_sets": [
      {
        "sort_number": 1,
        "name": "Brazil — 3 to 6 installments via Adyen",
        "description": "BR card transactions with 3–6 installments go to Adyen directly",
        "conditions": [
          { "condition_type": "COUNTRY",      "conditional": "EQUAL",   "values": ["BR"] },
          { "condition_type": "INSTALLMENTS", "conditional": "BETWEEN", "values": ["3", "6"] }
        ],
        "route": {
          "steps": [
            { "index": 1, "provider_id": "ADYEN", "connection_id": "b2c4d5e6-..." }
          ]
        }
      }
    ]
  }'

Errors

HTTPcodeWhen
404ROUTING_NOT_FOUNDUnknown routing_id, or id belongs to a different account.
400ROUTING_VALIDATION_FAILEDSchema or rule violation.
400ROUTING_PROVIDER_NOT_AVAILABLEA step references an inactive/unknown connection.
400ROUTING_PAYMENT_METHOD_IMMUTABLEBody’s payment_method doesn’t match the routing’s payment_method.
409ROUTING_VERSION_CONFLICTAnother concurrent PATCH won the publish race.
403INSUFFICIENT_SCOPEAPI key missing routing:write.

Authorizations

PUBLIC-API-KEY
string
header
default:<Your PUBLIC-API-KEY>
required
PRIVATE-SECRET-KEY
string
header
default:<Your PRIVATE-SECRET-KEY>
required

Headers

X-Idempotency-Key
string<uuid>
required

Path Parameters

routing_id
string<uuid>
required

Body

application/json
name
string
Example:

"Updated Card routing"

default_route
object
condition_sets
object[]

Response

OK

id
string
Example:

"r_8f2c1d3e-4b5a-6c7d-8e9f-0a1b2c3d4e5f"

account_code
string
Example:

"acc-uuid"

payment_method
string
Example:

"CARD"

name
string
Example:

"Updated Card routing v2"

default_route
object
condition_sets
object[]
created_at
string<date-time>
Example:

"2026-05-12T14:30:00Z"

updated_at
string<date-time>
Example:

"2026-05-12T14:30:00Z"