• This is Microsoft.
  • He returns Webhook success with a code 200 and plaintext 1.
  • He returns Webhook failure with a code 200 and a string tells its endpoint returned error 400.
  • the string didn’t tell what exactly the error.
  • Don’t be like Microsoft.

EDIT: Got a few details wrong since this happens a few months ago and this meme used to be on r/ProgrammerHumor. Also the proof:

  • barrage4u@lemmy.world
    link
    fedilink
    arrow-up
    8
    arrow-down
    1
    ·
    1 year ago

    It’s hard when you hit an endpoint that hits another endpoint, because technically the first request IS a 200. No right or wrong way as long as they are consistent and document it clearly imo

    • callmepk@lemmy.worldOP
      link
      fedilink
      arrow-up
      5
      ·
      1 year ago

      Now here is the fun part: they do not have a API documentation; they only have a very generic guide on how to setup webhook API

        • vfsh@lemmy.blahaj.zone
          link
          fedilink
          arrow-up
          2
          ·
          1 year ago

          Microsoft docs in general are the worst. Can’t tell you how many fucking dead links and straight up incorrect information I’ve come across on their official help articles

        • masterspace@lemmy.ca
          link
          fedilink
          arrow-up
          2
          ·
          1 year ago

          Lmao, Microsoft code docs are absolutely amazing compared to the undocumented bullshit I have to deal with at most companies that have rolled their own services.

          • LetsGOikz@lemmy.ml
            link
            fedilink
            arrow-up
            3
            ·
            edit-2
            1 year ago

            Shit, Microsoft docs are better than most other large companies with broadly used software even, not just random undocumented BS from smaller companies and products. In my experience, Microsoft’s Xamarin docs are somehow often a better guide for Android development than Google’s docs (good god are the official Android docs some of the hottest garbage that a company of Google’s size and talent could put out), and I’ve yet to find a better general reference for any language or library than Microsoft’s .NET documentation. I’ve seen a lot of people dunk on it for it’s verbosity and/or “example bloat” but I love the length of their docs for breaking down different use-cases and giving examples of each, along with potential misuses and recommended alternatives.

            That said, they do still have some garbage docs (like what OP is pointing out), but my general experience with their docs, especially for their larger/more mainstream products, has been surprisingly positive.

          • candyman337@lemmy.world
            link
            fedilink
            arrow-up
            1
            ·
            1 year ago

            Right but Microsoft isn’t most companies, it’s a SOFTWARE company. A multibillion dollar one at that. Compared to other even multimillion dollar companies, their docs are fucking atrocious

    • Scrubbles@poptalk.scrubbles.tech
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      I my experience you then send a different error code to help developers know that right away. Really if there is nothing the developer could do it should be a 500 server error. The server did in fact error.

      If the developer should have done something different then translate it to an appropriate code, 400 bad request or something

  • flashgnash@lemm.ee
    link
    fedilink
    arrow-up
    6
    ·
    1 year ago

    Working with Microsoft’s APIs is akin to trying to navigate a maze of barbed wire with a blindfold on

  • marcos@lemmy.world
    link
    fedilink
    arrow-up
    3
    ·
    1 year ago

    The quality of Microsoft APIs is legendary… if you just take a minute to study win32, you will be always glad that those webserver responses are the kind of shit you have to deal with.

    But to be fair, this looks exactly like a well designed API that somebody pushed behind a corporate firewall.

  • Ducks@ducks.dev
    link
    fedilink
    arrow-up
    2
    ·
    1 year ago

    Or when you hit an API and the error message comes back as html instead of json.

    • squirmy_wormy@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      What don’t you like about graphql error handling? Whenever I’ve made a graphql api, I use the default errors as unhandled/system errors and payloads return handled error types.

      It’s a bit more boilerplate to wire up, but I find it smooth to build and use

      • z2k_@lemmy.nz
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        Just making a point that it always returns a 200 even when it errors.

  • Walop@sopuli.xyz
    link
    fedilink
    arrow-up
    1
    ·
    1 year ago

    After working few years on a complex web application, I am starting to feel this style. Doing RESTful APIs for anything else than dead simple CRUD is pain.

  • UncommonBagOfLoot@lemmy.world
    link
    fedilink
    arrow-up
    0
    ·
    1 year ago

    Wait, do you know if this still happens?

    I have a ticket in our backlog to investigate similar issue with Teams Webhook reporting success but not posting anything.

    None of us wanted to look at it so been in our backlog for a whilr