Commit aaa916f15c9bde139058888be660705390cc02db
1 parent
b5442eb5
Exists in
master
and in
4 other branches
use high level api and compatibility with Passenger
Showing
1 changed file
with
8 additions
and
7 deletions
 
Show diff stats
lib/gitlab/backend/grack_auth.rb
| ... | ... | @@ -12,21 +12,22 @@ module Grack | 
| 12 | 12 | # Pass Gitolite update hook | 
| 13 | 13 | ENV['GL_BYPASS_UPDATE_HOOK'] = "true" | 
| 14 | 14 | |
| 15 | - # Need this patch because the rails mount | |
| 16 | - @env['PATH_INFO'] = @env['REQUEST_PATH'] | |
| 15 | + # Need this patch due to the rails mount | |
| 16 | + @env['PATH_INFO'] = @request.path | |
| 17 | + @env['SCRIPT_NAME'] = "" | |
| 17 | 18 | |
| 18 | 19 | # Find project by PATH_INFO from env | 
| 19 | - if m = /^\/([\w-]+).git/.match(@env['PATH_INFO']).to_a | |
| 20 | + if m = /^\/([\w-]+).git/.match(@request.path_info).to_a | |
| 20 | 21 | return false unless project = Project.find_by_path(m.last) | 
| 21 | 22 | end | 
| 22 | 23 | |
| 23 | 24 | # Git upload and receive | 
| 24 | - if @env['REQUEST_METHOD'] == 'GET' | |
| 25 | + if @request.get? | |
| 25 | 26 | true | 
| 26 | - elsif @env['REQUEST_METHOD'] == 'POST' | |
| 27 | - if @env['REQUEST_URI'].end_with?('git-upload-pack') | |
| 27 | + elsif @request.post? | |
| 28 | + if @request.path_info.end_with?('git-upload-pack') | |
| 28 | 29 | return project.dev_access_for?(user) | 
| 29 | - elsif @env['REQUEST_URI'].end_with?('git-receive-pack') | |
| 30 | + elsif @request.path_info.end_with?('git-receive-pack') | |
| 30 | 31 | if project.protected_branches.map(&:name).include?(current_ref) | 
| 31 | 32 | project.master_access_for?(user) | 
| 32 | 33 | else | ... | ... |