Spring Data Rest - customize endpoint name












0















By default, Spring data REST use camelCase for endpoint names.



For example, if the repository is



@RepositoryRestResource(collectionResourceRel = "users", path = "users")
public interface UserRepository extends PagingAndSortingRepository<User, Integer> {

List<User> findByUsername(@Param("username") String username);

}


Then the endpoint is http://localhost:8080/users/search/findByUsername?username=test



How can I customize the endpoint so it use snake_case, became like this: http://localhost:8080/users/search/find_by_username?username=test



Or even different method name




  • change find_by_username : http://localhost:8080/users/search/by_username?username=test

  • (stripping the find_by_username): http://localhost:8080/users/search?username=test


Thanks










share|improve this question



























    0















    By default, Spring data REST use camelCase for endpoint names.



    For example, if the repository is



    @RepositoryRestResource(collectionResourceRel = "users", path = "users")
    public interface UserRepository extends PagingAndSortingRepository<User, Integer> {

    List<User> findByUsername(@Param("username") String username);

    }


    Then the endpoint is http://localhost:8080/users/search/findByUsername?username=test



    How can I customize the endpoint so it use snake_case, became like this: http://localhost:8080/users/search/find_by_username?username=test



    Or even different method name




    • change find_by_username : http://localhost:8080/users/search/by_username?username=test

    • (stripping the find_by_username): http://localhost:8080/users/search?username=test


    Thanks










    share|improve this question

























      0












      0








      0








      By default, Spring data REST use camelCase for endpoint names.



      For example, if the repository is



      @RepositoryRestResource(collectionResourceRel = "users", path = "users")
      public interface UserRepository extends PagingAndSortingRepository<User, Integer> {

      List<User> findByUsername(@Param("username") String username);

      }


      Then the endpoint is http://localhost:8080/users/search/findByUsername?username=test



      How can I customize the endpoint so it use snake_case, became like this: http://localhost:8080/users/search/find_by_username?username=test



      Or even different method name




      • change find_by_username : http://localhost:8080/users/search/by_username?username=test

      • (stripping the find_by_username): http://localhost:8080/users/search?username=test


      Thanks










      share|improve this question














      By default, Spring data REST use camelCase for endpoint names.



      For example, if the repository is



      @RepositoryRestResource(collectionResourceRel = "users", path = "users")
      public interface UserRepository extends PagingAndSortingRepository<User, Integer> {

      List<User> findByUsername(@Param("username") String username);

      }


      Then the endpoint is http://localhost:8080/users/search/findByUsername?username=test



      How can I customize the endpoint so it use snake_case, became like this: http://localhost:8080/users/search/find_by_username?username=test



      Or even different method name




      • change find_by_username : http://localhost:8080/users/search/by_username?username=test

      • (stripping the find_by_username): http://localhost:8080/users/search?username=test


      Thanks







      spring spring-boot spring-data-rest






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Jan 2 at 2:35









      TimothyTimothy

      539




      539
























          1 Answer
          1






          active

          oldest

          votes


















          0














          The @RestResource annotation also gives us the ability to customize the URL path mapped to a repository method and the link id in the JSON returned by the HATEOAS resource discovery.



          To do that, we use the optional parameters of the annotation:





          • path for the URL path


          • rel for the link id


          By executing a cUrl to http://localhost:8080/users/search/, we can now see our new method listed with other resources:



          {
          "_links": {
          "findByUsername": {
          "href": "http://localhost:8080/users/search/findByUsername{?username}"
          },
          "self": {
          "href": "http://localhost:8080/users/search/"
          }
          }
          }


          So to customize the rest url endpoint, we can simply add the @RestResource annotation:



          @RestResource(path = "byUsername", rel = "customFindMethod")
          List<User> findByUsername(@Param("username") String username);


          If we do the resource discovery again, the resulting JSON will confirm our changes:



          {
          "_links": {
          "customFindMethod": {
          "href": "http://localhost:8080/users/search/byUsername{?username}",
          "templated": true
          },
          "self": {
          "href": "http://localhost:8080/users/search/"
          }
          }
          }


          For more details you can check her






          share|improve this answer























            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%2f54000603%2fspring-data-rest-customize-endpoint-name%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














            The @RestResource annotation also gives us the ability to customize the URL path mapped to a repository method and the link id in the JSON returned by the HATEOAS resource discovery.



            To do that, we use the optional parameters of the annotation:





            • path for the URL path


            • rel for the link id


            By executing a cUrl to http://localhost:8080/users/search/, we can now see our new method listed with other resources:



            {
            "_links": {
            "findByUsername": {
            "href": "http://localhost:8080/users/search/findByUsername{?username}"
            },
            "self": {
            "href": "http://localhost:8080/users/search/"
            }
            }
            }


            So to customize the rest url endpoint, we can simply add the @RestResource annotation:



            @RestResource(path = "byUsername", rel = "customFindMethod")
            List<User> findByUsername(@Param("username") String username);


            If we do the resource discovery again, the resulting JSON will confirm our changes:



            {
            "_links": {
            "customFindMethod": {
            "href": "http://localhost:8080/users/search/byUsername{?username}",
            "templated": true
            },
            "self": {
            "href": "http://localhost:8080/users/search/"
            }
            }
            }


            For more details you can check her






            share|improve this answer




























              0














              The @RestResource annotation also gives us the ability to customize the URL path mapped to a repository method and the link id in the JSON returned by the HATEOAS resource discovery.



              To do that, we use the optional parameters of the annotation:





              • path for the URL path


              • rel for the link id


              By executing a cUrl to http://localhost:8080/users/search/, we can now see our new method listed with other resources:



              {
              "_links": {
              "findByUsername": {
              "href": "http://localhost:8080/users/search/findByUsername{?username}"
              },
              "self": {
              "href": "http://localhost:8080/users/search/"
              }
              }
              }


              So to customize the rest url endpoint, we can simply add the @RestResource annotation:



              @RestResource(path = "byUsername", rel = "customFindMethod")
              List<User> findByUsername(@Param("username") String username);


              If we do the resource discovery again, the resulting JSON will confirm our changes:



              {
              "_links": {
              "customFindMethod": {
              "href": "http://localhost:8080/users/search/byUsername{?username}",
              "templated": true
              },
              "self": {
              "href": "http://localhost:8080/users/search/"
              }
              }
              }


              For more details you can check her






              share|improve this answer


























                0












                0








                0







                The @RestResource annotation also gives us the ability to customize the URL path mapped to a repository method and the link id in the JSON returned by the HATEOAS resource discovery.



                To do that, we use the optional parameters of the annotation:





                • path for the URL path


                • rel for the link id


                By executing a cUrl to http://localhost:8080/users/search/, we can now see our new method listed with other resources:



                {
                "_links": {
                "findByUsername": {
                "href": "http://localhost:8080/users/search/findByUsername{?username}"
                },
                "self": {
                "href": "http://localhost:8080/users/search/"
                }
                }
                }


                So to customize the rest url endpoint, we can simply add the @RestResource annotation:



                @RestResource(path = "byUsername", rel = "customFindMethod")
                List<User> findByUsername(@Param("username") String username);


                If we do the resource discovery again, the resulting JSON will confirm our changes:



                {
                "_links": {
                "customFindMethod": {
                "href": "http://localhost:8080/users/search/byUsername{?username}",
                "templated": true
                },
                "self": {
                "href": "http://localhost:8080/users/search/"
                }
                }
                }


                For more details you can check her






                share|improve this answer













                The @RestResource annotation also gives us the ability to customize the URL path mapped to a repository method and the link id in the JSON returned by the HATEOAS resource discovery.



                To do that, we use the optional parameters of the annotation:





                • path for the URL path


                • rel for the link id


                By executing a cUrl to http://localhost:8080/users/search/, we can now see our new method listed with other resources:



                {
                "_links": {
                "findByUsername": {
                "href": "http://localhost:8080/users/search/findByUsername{?username}"
                },
                "self": {
                "href": "http://localhost:8080/users/search/"
                }
                }
                }


                So to customize the rest url endpoint, we can simply add the @RestResource annotation:



                @RestResource(path = "byUsername", rel = "customFindMethod")
                List<User> findByUsername(@Param("username") String username);


                If we do the resource discovery again, the resulting JSON will confirm our changes:



                {
                "_links": {
                "customFindMethod": {
                "href": "http://localhost:8080/users/search/byUsername{?username}",
                "templated": true
                },
                "self": {
                "href": "http://localhost:8080/users/search/"
                }
                }
                }


                For more details you can check her







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered Jan 2 at 2:58









                TinyOSTinyOS

                94311129




                94311129
































                    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%2f54000603%2fspring-data-rest-customize-endpoint-name%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

                    Monofisismo

                    Angular Downloading a file using contenturl with Basic Authentication

                    Olmecas