The Final Disposition API is used to communicate to the client the final state, or disposition, of a unit when it leaves the ROP and is placed in its highest possible value disposition. For example, an unused, open box unit being returned to stock as a final disposition.
When Optoro receives a 401 HTTP status, Optoro will request a new Authentication Token from the client’s services and retry the request.
When Optoro receives any other error (as described above and identified by a 4xx (not 401) or 5xx range http status code) Optoro will retry five times with the same message. The retries will happen at an exponential backoff cadence in order not to overload machines. If the failure persists, the message will be stored in a failure queue and Optoro will have a technical contact person reach out to client tech support to report a problem. When the problem has been resolved, Optoro can manually retry failed requests.
For Final Disposition acknowledgement, all errors are handled the same since this is not in a user facing flow. However, the differentiation of status codes will help Optoro when reporting an issue.
Client endpoint to which final disposition update is posted to.
This endpoint along with any authentication mechanisms needed must be communicated to client’s account manager.
Success. Optoro recommends client APIs respond with a JSON-structured object. This is used for debugging purposes only so this guidance is technically optional.
Bad Request
Not Authorized. A new Authentication Token from the client’s services and retry the request.
Validation Failure
Internal Server Error
Client Server Unavailable
{- "disposition": "rts",
- "timestamp": "2018-03-20T00:00:00",
- "location_identifier": "RTS-1112",
- "warehouse_identifier": "22",
- "optiturn_lp": "LPAA1234567",
- "program_identifier": "parcel_returns",
- "sku": "012344566700",
- "upc": "0123456789012",
- "condition": "N",
- "reference_unit_identifier": "Unit A",
- "store_identifier": "Store A",
- "reason": "no_item_in_box",
- "shipment_reference_identifier": "1"
}
{- "message": "Success"
}