Set Maximum content-length Accepted












0














Is there a way in Rails to specify the maximum allowed content-length so that requests that exceed this value are rejected immediately?



I have a login form on my application that is the only POST available to an unauthenticated user. This has been identified as a potential vulnerability to a slow POST DoS attack. One of the mitigations is to limit the allowed request size.



I cannot seem to find the knob to turn which will allow me to automatically reject the request if the content-length exceeds a particular value.



We're using the Puma web server if that affects the answer.










share|improve this question






















  • have you tried reading the request headers in your login controller?
    – Lenin Raj Rajasekaran
    Nov 19 '18 at 22:15










  • I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
    – Andy Davis
    Nov 20 '18 at 17:09
















0














Is there a way in Rails to specify the maximum allowed content-length so that requests that exceed this value are rejected immediately?



I have a login form on my application that is the only POST available to an unauthenticated user. This has been identified as a potential vulnerability to a slow POST DoS attack. One of the mitigations is to limit the allowed request size.



I cannot seem to find the knob to turn which will allow me to automatically reject the request if the content-length exceeds a particular value.



We're using the Puma web server if that affects the answer.










share|improve this question






















  • have you tried reading the request headers in your login controller?
    – Lenin Raj Rajasekaran
    Nov 19 '18 at 22:15










  • I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
    – Andy Davis
    Nov 20 '18 at 17:09














0












0








0







Is there a way in Rails to specify the maximum allowed content-length so that requests that exceed this value are rejected immediately?



I have a login form on my application that is the only POST available to an unauthenticated user. This has been identified as a potential vulnerability to a slow POST DoS attack. One of the mitigations is to limit the allowed request size.



I cannot seem to find the knob to turn which will allow me to automatically reject the request if the content-length exceeds a particular value.



We're using the Puma web server if that affects the answer.










share|improve this question













Is there a way in Rails to specify the maximum allowed content-length so that requests that exceed this value are rejected immediately?



I have a login form on my application that is the only POST available to an unauthenticated user. This has been identified as a potential vulnerability to a slow POST DoS attack. One of the mitigations is to limit the allowed request size.



I cannot seem to find the knob to turn which will allow me to automatically reject the request if the content-length exceeds a particular value.



We're using the Puma web server if that affects the answer.







ruby-on-rails security






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 19 '18 at 14:41









Andy Davis

6931919




6931919












  • have you tried reading the request headers in your login controller?
    – Lenin Raj Rajasekaran
    Nov 19 '18 at 22:15










  • I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
    – Andy Davis
    Nov 20 '18 at 17:09


















  • have you tried reading the request headers in your login controller?
    – Lenin Raj Rajasekaran
    Nov 19 '18 at 22:15










  • I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
    – Andy Davis
    Nov 20 '18 at 17:09
















have you tried reading the request headers in your login controller?
– Lenin Raj Rajasekaran
Nov 19 '18 at 22:15




have you tried reading the request headers in your login controller?
– Lenin Raj Rajasekaran
Nov 19 '18 at 22:15












I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
– Andy Davis
Nov 20 '18 at 17:09




I am sure that I could do that. I am trying to find something that would be a bit more canonical Rails.
– Andy Davis
Nov 20 '18 at 17:09












1 Answer
1






active

oldest

votes


















0














Puma has two parameters actually, the number of threads and the number of workers. If we slightly change the default puma.rb, it will look like that:



workers Integer(ENV['WORKERS_NUMBER'] || 1)
max_threads_count = Integer(ENV['RAILS_MAX_THREADS'] || 1)
min_threads_count = max_threads_count
threads min_threads_count, max_threads_count





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%2f53376974%2fset-maximum-content-length-accepted%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














    Puma has two parameters actually, the number of threads and the number of workers. If we slightly change the default puma.rb, it will look like that:



    workers Integer(ENV['WORKERS_NUMBER'] || 1)
    max_threads_count = Integer(ENV['RAILS_MAX_THREADS'] || 1)
    min_threads_count = max_threads_count
    threads min_threads_count, max_threads_count





    share|improve this answer


























      0














      Puma has two parameters actually, the number of threads and the number of workers. If we slightly change the default puma.rb, it will look like that:



      workers Integer(ENV['WORKERS_NUMBER'] || 1)
      max_threads_count = Integer(ENV['RAILS_MAX_THREADS'] || 1)
      min_threads_count = max_threads_count
      threads min_threads_count, max_threads_count





      share|improve this answer
























        0












        0








        0






        Puma has two parameters actually, the number of threads and the number of workers. If we slightly change the default puma.rb, it will look like that:



        workers Integer(ENV['WORKERS_NUMBER'] || 1)
        max_threads_count = Integer(ENV['RAILS_MAX_THREADS'] || 1)
        min_threads_count = max_threads_count
        threads min_threads_count, max_threads_count





        share|improve this answer












        Puma has two parameters actually, the number of threads and the number of workers. If we slightly change the default puma.rb, it will look like that:



        workers Integer(ENV['WORKERS_NUMBER'] || 1)
        max_threads_count = Integer(ENV['RAILS_MAX_THREADS'] || 1)
        min_threads_count = max_threads_count
        threads min_threads_count, max_threads_count






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 20 '18 at 7:08









        Mohammad Shahnawaz

        413217




        413217






























            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.





            Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


            Please pay close attention to the following guidance:


            • 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%2f53376974%2fset-maximum-content-length-accepted%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

            How to fix TextFormField cause rebuild widget in Flutter

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