I prefer simplicity and using the first example but I’d be happy to hear other options. Here’s a few examples:

HTTP/1.1 403 POST /endpoint
{ "message": "Unauthorized access" }
HTTP/1.1 403 POST /endpoint
Unauthorized access (no json)
HTTP/1.1 403 POST /endpoint
{ "error": "Unauthorized access" }
HTTP/1.1 403 POST /endpoint
{
  "code": "UNAUTHORIZED",
  "message": "Unauthorized access",
}
HTTP/1.1 200 (🤡) POST /endpoint
{
  "error": true,
  "message": "Unauthorized access",
}
HTTP/1.1 403 POST /endpoint
{
  "status": 403,
  "code": "UNAUTHORIZED",
  "message": "Unauthorized access",
}

Or your own example.

  • isoOPA
    link
    fedilink
    arrow-up
    1
    ·
    17 days ago

    I’ve mistyped, I meant message in JSON body :)

    • DaniloT@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      17 days ago

      I see, but the first example option having no code still makes it harder to translate and show the user, so my vote is for the option with a code and message in the json.