Destructive Change-Ship-To wizard execute. The everyday PATCH path
(PATCH /v1/orders/{id}) refuses to mutate shipping_address_id
while active Shippo labels exist (the post-label silent-misship hard
block). This endpoint is the CS Lead override that orchestrates the
full void-then-repurchase flow in one transactional sweep:
orders.override_post_label_edit (server-side; equivalent
to the public-API destructive scope combination below).new_address_id OR
creates a new account_addresses row from new_address_payload
via the canonical addAddress() helper (Triple-lock validation
Shippo USPS CASS + AvaTax fires inline).voidLabel handler (Shippo refund API + GL reversal of the
freight JE keyed label:<id> + residential-surcharge reversal if
last active label + activity log).orders.shipping_address_id (and optionally
billing_address_id if also_change_billing=true).recalculateTaxForOrder against the new destination
(AvaTax re-finalization).repurchase_strategy: auto-buys the cheapest new label per
package (auto_cheapest), returns the rate set for the operator
to choose (manual), or skips repurchase entirely (defer).createShippingDeltaCharge helper to bill/refund the customer
for the rate delta vs original (idempotent on label_id).ORDER_SHIP_TO_CHANGED_VIA_WIZARD activity
row with full metadata, and broadcasts order.ship_to_changed.Both confirm_void_labels=true AND confirm_repurchase_labels=true
are required (unless repurchase_strategy=defer, which only needs
confirm_void_labels=true). This is the two-key safety gate
equivalent of the wizard’s review-confirm step in the UI.
Partial failure semantics: if any label refuses to void (e.g.
carrier-scanned, in-transit), the orders row is NOT updated.
Response returns 422 partial_void_failure with the list of labels
that did void + the offender so the operator can route to carrier
Package Intercept.
Scopes: orders:write AND fulfillment:write both required.
Idempotency: Idempotency-Key header is supported; repeat
submissions return the original response without re-charging.
Filed by NEW-GAP-CS-ADDRESS-CHANGE-POST-LABEL-PURCHASE + NEW-GAP- CHANGE-SHIP-TO-WIZARD-VOID-AND-REPURCHASE (2026-05-16).
Industry parallel: Shopify Edit Order (void + reissue); NetSuite Reverse Fulfillment + Re-fulfill; Acumatica Cancel Shipment
Documentation Index
Fetch the complete documentation index at: https://docs.arcuserp.com/llms.txt
Use this file to discover all available pages before exploring further.
API key issued per entity via Settings > Developers > API Keys.
Each key carries scopes (e.g. orders:read, products:write).
Bearer token format: Authorization: Bearer ark_live_ent_Test keys use ark_test_ent_. Both are issued per entity
via Settings > Developers > API Keys.
Client-generated unique key for idempotent POST/PATCH/DELETE operations. Alias for the Idempotency parameter. Max 255 chars. On retry with the same key, the original response is returned without re-executing the operation. Keys expire after 24 hours.
255UUID of the order to change ship-to for.
REQUIRED. Two-key safety gate; must be true to authorize label void.
Existing account_addresses.id (mutually exclusive with new_address_payload).
Raw address payload; creates a new account_addresses row via the canonical addAddress helper.
Also copy the new address into billing_address_id.
REQUIRED unless repurchase_strategy=defer.
auto_cheapest = auto-buy cheapest new label per package; manual = return rates and let operator choose; defer = leave packages unlabeled for the warehouse.
auto_cheapest, manual, defer Optional Stripe payment_method to bill the rate delta.
Audit attribution; defaults to API key owner if omitted.
Operator note for the audit log.
Ship-to changed successfully (may include partial purchase_failures with HTTP 200 when at least one new label posted).