-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix empty SCRIPT_NAME with partial match route bug #43
base: master
Are you sure you want to change the base?
Fix empty SCRIPT_NAME with partial match route bug #43
Conversation
Why you made the change: I made this change so that SCRIPT_NAME and PATH_INFO would be set appropriately in the scenario where a partial match route is used. How the change addresses the need: There is an issue with the current version of rewrite_partial_path_info where it does not set SCRIPT_NAME appropriately. When the request environments PATH_INFO is set, it causes the request.rack_request.path_info helper return the updated version, not the original. This is requst.rack_request.path_info eventually just reads the PATH_INFO value out of the request environment. As a side effect of this, the original code would always set the SCRIPT_NAME to "" because it would be slicing from request.rack_request.path_info[0, 0] in actuality. This change resolves this issue by first temporarily storing a dup of the original path_info and using that to determine the end index for the SCRIPT_NAME. This change also handles setting SCRIPT_NAME correctly for the somewhat unique but common case of matching the partial match exactly. I have added tests for each of these cases as I couldn't find any tests covering this before.
Fix empty SCRIPT_NAME with partial match route bug
Why you made the change: I did this so it was ancient, as well as because there was a missmatch between the version of rake specified and how it was used which was having problems. Upgrading to the latest version of rake resolves this issue so that `bundle exec rake` can successfully be run.
Why you made the change: I did this because travis ci was failing for weird reasons and figured maybe it had something to do with the default .travis.yml.
Why you made the change: I did this in hopes to avoid the `NoMethodError: undefined method `spec' for nil:NilClass` while using bundler 1.7.6 which is travis default bundler version.
Why you made the change: I did this because that is the default travis was testing against before so figured we shouldn't change it.
This reverts commit 14043cf.
This reverts commit 5170ae7.
@joshbuddy is there any chance you could review this PR as it fixes a bug in http_router? @jodosha do you have any pull with getting this in? It is the fix that resolves an actual bug in http_router, but also makes http://hanamirb.org work properly with http://sidekiq.org. |
I did this because sometimes the request path will be encoded. Since HTTP router unencodes the path, it loses the ability to correctly calculate the path info by performing math on the path length. This encodes the path info since it is used for correctly assigning the script name.
Add URI encoding for path info
@joshbuddy, please review this PR we need this on only for sidekiq ❤️💛💜💗💙 |
Will take a look!
… On Mar 1, 2017, at 14:44, Anton Davydov ***@***.***> wrote:
@joshbuddy, please review this PR we need this on only for sidekiq ❤️💛💜💗💙
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or mute the thread.
|
@joshbuddy you're my hero 🎉 P.S.: WDYT maybe it'll good to add someone from hanami core for helping with maintaining the project? Because we have some errors with this gem and we will be happy to fix it ASAP. /cc @jodosha |
Why you made the change:
I made this change so that SCRIPT_NAME and PATH_INFO would be set
appropriately in the scenario where a partial match route is used.
How the change addresses the need:
There is an issue with the current version of rewrite_partial_path_info
where it does not set SCRIPT_NAME appropriately. When the request
environments PATH_INFO is set, it causes the request.rack_request.path_info
helper return the updated version, not the original. This is
requst.rack_request.path_info eventually just reads the PATH_INFO value
out of the request environment. As a side effect of this, the original
code would always set the SCRIPT_NAME to "" because it would be slicing
from request.rack_request.path_info[0, 0] in actuality.
This change resolves this issue by first temporarily storing a dup of
the original path_info and using that to determine the end index for the
SCRIPT_NAME. This change also handles setting SCRIPT_NAME correctly for
the somewhat unique but common case of matching the partial match
exactly.
I have added tests for each of these cases as I couldn't find any tests
covering this before.