2 min read
What triggers it
The referenced resource does not exist. An id that never existed, was deleted, or belongs to another environment.
Example response
{
"error": {
"type": "invalid_request_error",
"code": "resource_not_found",
"message": "The referenced resource does not exist."
}
}
How to fix it
Check the id and that you are calling the right (live vs test) environment.
This is deterministic: the same request will fail again until fixed. See the HTTP 404 page for the class.
In practice
In a well-built client, resource_not_found is handled by branching on error.code rather than on the human error.message, which may be reworded over time. The HTTP status (404) gives the broad invalid_request_error class; the code gives the specifics; and, on field errors, error.param pinpoints the input to fix.
This code is deterministic — retrying the identical request reproduces it — so keep it out of your retry path and instead map it to a clear, actionable message. See Map errors to user-facing messages and Read the error envelope for the pattern.
Frequently asked questions
Is resource_not_found safe to retry?
No. It is deterministic; retrying the identical request produces the identical error. Fix the cause first.
Will this code ever change?
No. Error codes are stable contract. The human message may be reworded, but the code you branch on will not change.
Do I branch on the code or the HTTP status?
Both — the status for the retry-or-not decision, the code for the specific behaviour. See the error envelope.
Funding for UK limited companies
Credicorp lends to your company, not to you personally — short-term working capital with no personal guarantee. See what your business could access.