Search code examples
restapiasp.net-web-apirestful-architecture

RESTful API and real life example


We have a web application (AngularJS and Web API) which has quite a simple functionality - displays a list of jobs and allows users to select and cancel selected jobs.

We are trying to follow RESTful approach with our API, but that's where it gets confusing.

Getting jobs is easy - simple GET: /jobs

How shall we cancel the selected jobs? Bearing in mind that this is the only operation on jobs we need to implement. The easiest and most logical approach (to me) is to send the list of selected jobs IDs to the API (server) and do necessary procedures. But that's not RESTful way.

If we are to do it following RESTful approach it seams that we need to send PATCH request to jobs, with json similar to this:

PATCH: /jobs
[
    {
      "op": "replace",
      "path": "/jobs/123",
      "status": "cancelled"
    },
    {
      "op": "replace",
      "path": "/jobs/321",
      "status": "cancelled"
    },
]

That will require generating this json on client, then mapping it to some the model on server, parsing "path" property to get the job ID and then do actual cancellation. This seems very convoluted and artificial to me.

What is the general advice on this kind of operation? I'm curious what people do in real life when a lot of operations can't be simply mapped to RESTful resource paradigm.

Thanks!


Solution

  • If by cancelling a job you mean deleting it then you could use the DELETE verb:

    DELETE /jobs?ids=123,321,...
    

    If by cancelling a job you mean setting some status field to cancelled then you could use the PATCH verb:

    PATCH /jobs
    Content-Type: application/json
    [ { "id": 123, "status": "cancelled" }, { "id": 321, "status": "cancelled" } ]