DELETE different resources with one requests - Is it ok or we should try to mix those resources to one












3















Let assume that I have a collection with /playrequests endpoint. It is a collection (list) for those players who want to find another player to start a match.



The server will check this collection periodically and if it finds two unassigned players, it will create another resource in another collection with /quickmatchs endpoint and also change (for example) a field in the PlayRequests collection for both players to shows that they are assigned to a quickMatch.



At this point, players can send a PUT or PATCH request to set the (for example) "ready" field of their related quickMach resource to true. so the server and each of them can find out that if both of them is ready and the match can be started.



(The Issue Part Is Below Part...)



Also, before a the playRequests assigned to a match and also after they assigned to it, they can send a DELETE request to /playrequests endpoint to tell the server that they want to give up the request. So if the match doesn't create yet, It is ok. the resource related to the player will remove from playRequests collection. but if player assigned to a match, the server must delete the related playRequest and also it must delete the related quickMatch resource from the quickMatchs collection. ( and also we should modify the playRequest related to another player to indicate that it's unassigned now. or we can check and change it later when he to check the status of his related resources in both collection. It is not the main issue for now. )



So, my question is that is it ok to change a resource that is related to the given end point and also change another resource accordingly, If it is necessary? ( I mean is it ok to manipulate different resources with different endpoints in one request? I don't want to send multiple requests.) or I need to mix those two collections to avoid such an action?



I know that many things ( different strategies ) are possible but I want to know that (from the viewpoint of RESTFUL) what is standard/appropriate and what is not? (consider that I am kinda new to restful)










share|improve this question



























    3















    Let assume that I have a collection with /playrequests endpoint. It is a collection (list) for those players who want to find another player to start a match.



    The server will check this collection periodically and if it finds two unassigned players, it will create another resource in another collection with /quickmatchs endpoint and also change (for example) a field in the PlayRequests collection for both players to shows that they are assigned to a quickMatch.



    At this point, players can send a PUT or PATCH request to set the (for example) "ready" field of their related quickMach resource to true. so the server and each of them can find out that if both of them is ready and the match can be started.



    (The Issue Part Is Below Part...)



    Also, before a the playRequests assigned to a match and also after they assigned to it, they can send a DELETE request to /playrequests endpoint to tell the server that they want to give up the request. So if the match doesn't create yet, It is ok. the resource related to the player will remove from playRequests collection. but if player assigned to a match, the server must delete the related playRequest and also it must delete the related quickMatch resource from the quickMatchs collection. ( and also we should modify the playRequest related to another player to indicate that it's unassigned now. or we can check and change it later when he to check the status of his related resources in both collection. It is not the main issue for now. )



    So, my question is that is it ok to change a resource that is related to the given end point and also change another resource accordingly, If it is necessary? ( I mean is it ok to manipulate different resources with different endpoints in one request? I don't want to send multiple requests.) or I need to mix those two collections to avoid such an action?



    I know that many things ( different strategies ) are possible but I want to know that (from the viewpoint of RESTFUL) what is standard/appropriate and what is not? (consider that I am kinda new to restful)










    share|improve this question

























      3












      3








      3








      Let assume that I have a collection with /playrequests endpoint. It is a collection (list) for those players who want to find another player to start a match.



      The server will check this collection periodically and if it finds two unassigned players, it will create another resource in another collection with /quickmatchs endpoint and also change (for example) a field in the PlayRequests collection for both players to shows that they are assigned to a quickMatch.



      At this point, players can send a PUT or PATCH request to set the (for example) "ready" field of their related quickMach resource to true. so the server and each of them can find out that if both of them is ready and the match can be started.



      (The Issue Part Is Below Part...)



      Also, before a the playRequests assigned to a match and also after they assigned to it, they can send a DELETE request to /playrequests endpoint to tell the server that they want to give up the request. So if the match doesn't create yet, It is ok. the resource related to the player will remove from playRequests collection. but if player assigned to a match, the server must delete the related playRequest and also it must delete the related quickMatch resource from the quickMatchs collection. ( and also we should modify the playRequest related to another player to indicate that it's unassigned now. or we can check and change it later when he to check the status of his related resources in both collection. It is not the main issue for now. )



      So, my question is that is it ok to change a resource that is related to the given end point and also change another resource accordingly, If it is necessary? ( I mean is it ok to manipulate different resources with different endpoints in one request? I don't want to send multiple requests.) or I need to mix those two collections to avoid such an action?



      I know that many things ( different strategies ) are possible but I want to know that (from the viewpoint of RESTFUL) what is standard/appropriate and what is not? (consider that I am kinda new to restful)










      share|improve this question














      Let assume that I have a collection with /playrequests endpoint. It is a collection (list) for those players who want to find another player to start a match.



      The server will check this collection periodically and if it finds two unassigned players, it will create another resource in another collection with /quickmatchs endpoint and also change (for example) a field in the PlayRequests collection for both players to shows that they are assigned to a quickMatch.



      At this point, players can send a PUT or PATCH request to set the (for example) "ready" field of their related quickMach resource to true. so the server and each of them can find out that if both of them is ready and the match can be started.



      (The Issue Part Is Below Part...)



      Also, before a the playRequests assigned to a match and also after they assigned to it, they can send a DELETE request to /playrequests endpoint to tell the server that they want to give up the request. So if the match doesn't create yet, It is ok. the resource related to the player will remove from playRequests collection. but if player assigned to a match, the server must delete the related playRequest and also it must delete the related quickMatch resource from the quickMatchs collection. ( and also we should modify the playRequest related to another player to indicate that it's unassigned now. or we can check and change it later when he to check the status of his related resources in both collection. It is not the main issue for now. )



      So, my question is that is it ok to change a resource that is related to the given end point and also change another resource accordingly, If it is necessary? ( I mean is it ok to manipulate different resources with different endpoints in one request? I don't want to send multiple requests.) or I need to mix those two collections to avoid such an action?



      I know that many things ( different strategies ) are possible but I want to know that (from the viewpoint of RESTFUL) what is standard/appropriate and what is not? (consider that I am kinda new to restful)







      rest api restful-url






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Jan 2 at 10:51









      ArmamediaArmamedia

      11119




      11119
























          1 Answer
          1






          active

          oldest

          votes


















          0















          it ok to change a resource that is related to the given end point and also change another resource accordingly




          Yes, and there are consequences.



          Suppose we have two resources, /fizz and /buzz, and the representations of those resources are related via some implementation details on the server. On the client, we have accessed both of these resources, so we have cached copies of each of them.



          The potential issue here is that the server changes the representations of these resources together, but as far as the client is concerned, they are separate.



          For instance, if the client sends an unsafe request to change /fizz, a successful response message from the server will invalidate the locally cached copy of that representation, but the stale representation of /buzz does not get evicted. In effect, the client now has a view of the world with version 0 /buzz and version 1 /fizz.



          Is that OK? "It depends" -- will expensive things happen to you if your clients are in a state of unmatched representations? Can you patch over the "problem" in other ways (for instance, by telling the client to check resources for updates more often)?






          share|improve this answer
























          • I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

            – Armamedia
            Jan 2 at 15:02











          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54005019%2fdelete-different-resources-with-one-requests-is-it-ok-or-we-should-try-to-mix%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          0















          it ok to change a resource that is related to the given end point and also change another resource accordingly




          Yes, and there are consequences.



          Suppose we have two resources, /fizz and /buzz, and the representations of those resources are related via some implementation details on the server. On the client, we have accessed both of these resources, so we have cached copies of each of them.



          The potential issue here is that the server changes the representations of these resources together, but as far as the client is concerned, they are separate.



          For instance, if the client sends an unsafe request to change /fizz, a successful response message from the server will invalidate the locally cached copy of that representation, but the stale representation of /buzz does not get evicted. In effect, the client now has a view of the world with version 0 /buzz and version 1 /fizz.



          Is that OK? "It depends" -- will expensive things happen to you if your clients are in a state of unmatched representations? Can you patch over the "problem" in other ways (for instance, by telling the client to check resources for updates more often)?






          share|improve this answer
























          • I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

            – Armamedia
            Jan 2 at 15:02
















          0















          it ok to change a resource that is related to the given end point and also change another resource accordingly




          Yes, and there are consequences.



          Suppose we have two resources, /fizz and /buzz, and the representations of those resources are related via some implementation details on the server. On the client, we have accessed both of these resources, so we have cached copies of each of them.



          The potential issue here is that the server changes the representations of these resources together, but as far as the client is concerned, they are separate.



          For instance, if the client sends an unsafe request to change /fizz, a successful response message from the server will invalidate the locally cached copy of that representation, but the stale representation of /buzz does not get evicted. In effect, the client now has a view of the world with version 0 /buzz and version 1 /fizz.



          Is that OK? "It depends" -- will expensive things happen to you if your clients are in a state of unmatched representations? Can you patch over the "problem" in other ways (for instance, by telling the client to check resources for updates more often)?






          share|improve this answer
























          • I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

            – Armamedia
            Jan 2 at 15:02














          0












          0








          0








          it ok to change a resource that is related to the given end point and also change another resource accordingly




          Yes, and there are consequences.



          Suppose we have two resources, /fizz and /buzz, and the representations of those resources are related via some implementation details on the server. On the client, we have accessed both of these resources, so we have cached copies of each of them.



          The potential issue here is that the server changes the representations of these resources together, but as far as the client is concerned, they are separate.



          For instance, if the client sends an unsafe request to change /fizz, a successful response message from the server will invalidate the locally cached copy of that representation, but the stale representation of /buzz does not get evicted. In effect, the client now has a view of the world with version 0 /buzz and version 1 /fizz.



          Is that OK? "It depends" -- will expensive things happen to you if your clients are in a state of unmatched representations? Can you patch over the "problem" in other ways (for instance, by telling the client to check resources for updates more often)?






          share|improve this answer














          it ok to change a resource that is related to the given end point and also change another resource accordingly




          Yes, and there are consequences.



          Suppose we have two resources, /fizz and /buzz, and the representations of those resources are related via some implementation details on the server. On the client, we have accessed both of these resources, so we have cached copies of each of them.



          The potential issue here is that the server changes the representations of these resources together, but as far as the client is concerned, they are separate.



          For instance, if the client sends an unsafe request to change /fizz, a successful response message from the server will invalidate the locally cached copy of that representation, but the stale representation of /buzz does not get evicted. In effect, the client now has a view of the world with version 0 /buzz and version 1 /fizz.



          Is that OK? "It depends" -- will expensive things happen to you if your clients are in a state of unmatched representations? Can you patch over the "problem" in other ways (for instance, by telling the client to check resources for updates more often)?







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Jan 2 at 14:29









          VoiceOfUnreasonVoiceOfUnreason

          21.4k22051




          21.4k22051













          • I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

            – Armamedia
            Jan 2 at 15:02



















          • I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

            – Armamedia
            Jan 2 at 15:02

















          I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

          – Armamedia
          Jan 2 at 15:02





          I think I got my answer. so It is OK and the consequences are my responsibility. It is an API for a game and it will not be published publicly. Also, Yes the client will check for Updates periodically. Also, not all of the methods are open for both endpoints. I think all these things will reduce the consequences to near the zero. am I right? So As I understood, It Is standard and has no conflict with restful philosophy, Right?

          – Armamedia
          Jan 2 at 15:02




















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54005019%2fdelete-different-resources-with-one-requests-is-it-ok-or-we-should-try-to-mix%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          MongoDB - Not Authorized To Execute Command

          in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

          How to fix TextFormField cause rebuild widget in Flutter