|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| |\  
| | 
| | | Respect routing precedence for HEAD requests | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | | Fixes the issue described in #18764 - prevents Rack middleware from
swallowing up HEAD requests that should have been matched by a
higher-precedence `get` route, but still allows Rack middleware to
respond to HEAD requests. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | This reverts commit 0b3397872582f2cf1bc6960960a6393f477c55e6, reversing
changes made to 56d52e3749180e6c1dcf7166adbad967470aa78b.
As pointed out on the PR, this will hide development mistakes too, which
is not ideal. | 
| |\ \  
| | | 
| | | | Catch InvalidURIError on bad paths on redirect. | 
| | | | 
| | | 
| | | 
| | | 
| | | | Handle URI::InvalidURIError errors on the redirect route method, so it
wont raise a 500 if a bad path is given. | 
| |/ / |  | 
| | | 
| | 
| | 
| | 
| | 
| | | People should be free to mutate the header object, but not to set a new
header object.  That header object may be specific to the webserver, and
we need to hide it's internals. | 
| | | 
| | 
| | 
| | 
| | | this way we don't have to mutate the instance (as much) when writing a
rack response | 
| | | 
| | 
| | 
| | 
| | 
| | | `ActionDispatch::SSL` changes headers to `Hash`.
So some headers will be broken if there are some middlewares
on ActionDispatch::SSL and if it uses `Rack::Utils::HeaderHash`. | 
| | | 
| | 
| | 
| | 
| | | I want to decouple Rails from the rack ENV as much as possible.  We
should try to keep as few references to the env as possible | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | | See the following commit to have context about this change:
https://github.com/rails/rails/commit/757a2bc3e3e52a5d9418656928db993db42b741b | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | | does the work | 
| | | |  | 
| | | |  | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | | matches? should only deal with methods on the request object, so lets
just filter out anything that the request object doesn't respond to | 
| | | 
| | 
| | 
| | 
| | | this way we can remove the strange "respond_to?" conditional in the
`matches?` loop | 
| | | |  | 
| | | 
| | 
| | 
| | | [Robin Dupret & Shunsuke Aida] | 
| | | 
| | 
| | 
| | 
| | | The `GetIp` class doesn't need to keep a reference to the middleware, so
there is no reason to pass the middleware instance to the `GetIp` class | 
| |\ \  
| | | 
| | | | Fix regression in #20017 wrong number of arguments error | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | | and use coherent quoting/spacing.
This should hopefully fix a regression that was introduced with #20017,
causing deployment pushes to Heroku to be rejected with the following
trace:
ArgumentError: wrong number of arguments (2 for 3)
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tatic.rb:16:in `initialize'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/gem
s/heroku-deflater-0.5.3/lib/heroku-deflater/serve_zipped_assets.rb:15:in
`new'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/gem
s/heroku-deflater-0.5.3/lib/heroku-deflater/serve_zipped_assets.rb:15:in
`initialize'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:43:in `new'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:43:in `build'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:118:in `block in build'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:118:in `each'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:118:in `inject'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/actionpack/lib/action_dispatch/middleware/s
tack.rb:118:in `build'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/engine.rb:509:in `app'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/application/finisher.rb:
34:in `block in <module:Finisher>'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/initializable.rb:30:in
`instance_exec'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/initializable.rb:30:in
`run'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/initializable.rb:55:in
`block in run_initializers'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/initializable.rb:54:in
`run_initializers'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/vendor/bundle/ruby/2.2.0/bun
dler/gems/rails-0ef7e73f0af7/railties/lib/rails/application.rb:352:in
`initialize!'
remote:
/tmp/build_a3b8845b716508af12d99859d1a58c5c/config/environment.rb:5:in
`<top (required)>' | 
| |\ \ \  
| | | | 
| | | | | Use block variable instead of global | 
| | | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | | ```ruby
require 'benchmark/ips'
Benchmark.ips do |x|
  x.report("$&") {
    "foo".sub(/f/) { $&.upcase }
  }
  x.report("block var") {
    "foo".sub(/f/) {|match| match.upcase }
  }
end
```
```
Calculating -------------------------------------
                  $&    48.658k i/100ms
           block var    49.666k i/100ms
-------------------------------------------------
                  $&    873.156k (± 9.3%) i/s -      4.331M
           block var    969.744k (± 9.2%) i/s -      4.818M
```
It's faster, and gets rid of a few "magic" global variables | 
| |\ \ \ \  
| | | | | 
| | | | | | Deprecate `assert_template` and `assigns()`. | 
| | |/ / / |  | 
| | |/ /  
|/| |   
| | |   
| | |   
| | |   
| | | | It's better to use Ruby methods when possible over methods defined by
Active Support because then it does not need to rely on any
dependencies. | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | | match method without setting `:via` option has been deprecated
fix minor typo | 
| |/ / |  | 
| |\ \  
| | | 
| | | 
| | | 
| | | | vngrs/remove_already_defined_methods_in_rack_request
Remove already defined methods in super class of ActionDispatch::Request class | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | | These methods had defined in 2004 by dhh in initial commit and `ActionDispatch::Request`
class has been inherited from `Rack::Request` class in 2009 by josh.
In 2014 these methods and more of them defined in `Rack::Request` class
so we don't need them anymore in rails codebase. | 
| |/ /  
| |   
| |   
| |   
| |   
| | | Set `config.static_index` to serve a static directory index file not
named `index`. For example, to serve `main.html` instead of `index.html`
for directory requests, set `config.static_index` to `"main"`. | 
| |\ \  
| | | 
| | | | Add application/vnd.api+json alias to the JSON MIME Type. | 
| | | | |  | 
| | | | |  | 
| | | | 
| | | 
| | | 
| | | | add missing dot to end of the doc | 
| |/ / |  | 
| | | 
| | 
| | 
| | | I should have deleted this earlier with 42e66fac38b54dd53d062fb5d3376218ed2ffdae | 
| | | 
| | 
| | 
| | 
| | | if we add an else conditional to the `presence` check, we can eliminate
the second `||` branch in the caller | 
| | | 
| | 
| | 
| | | this way we can keep the knowledge of `env` hash keys in one place. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | spelling fix [ci skip]
example to be consistent [ci skip]
grammatical fix
typo fixes [ci skip] | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | | Based on #19976 and #18305. | 
| | | 
| | 
| | 
| | 
| | 
| | | * Fix a few typos
* Wrap lines to 80 chars
* Use `+` instead of `<tt>` | 
| | | |  |