class Grack::Auth

Attributes

project[RW]
user[RW]

Public Instance Methods

can?(object, action, subject) click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 56
def can?(object, action, subject)
  abilities.allowed?(object, action, subject)
end
current_ref() click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 60
def current_ref
  if @env["HTTP_CONTENT_ENCODING"] =~ %rgzip/
    input = Zlib::GzipReader.new(@request.body).read
  else
    input = @request.body.read
  end
  # Need to reset seek point
  @request.body.rewind
  %rrefs\/heads\/([\w-]+)/.match(input).to_a.first
end
valid?() click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 5
def valid?
  # Authentication with username and password
  email, password = @auth.credentials
  self.user = User.find_by_email(email)
  return false unless user.try(:valid_password?, password)

  # Set GL_USER env variable
  ENV['GL_USER'] = email
  # Pass Gitolite update hook
  ENV['GL_BYPASS_UPDATE_HOOK'] = "true"

  # Need this patch due to the rails mount
  @env['PATH_INFO'] = @request.path
  @env['SCRIPT_NAME'] = ""

  # Find project by PATH_INFO from env
  if m = %r^\/([\w-]+).git/.match(@request.path_info).to_a
    self.project = Project.find_by_path(m.last)
    return false unless project
  end

  # Git upload and receive
  if @request.get?
    validate_get_request
  elsif @request.post?
    validate_post_request
  else
    false
  end
end
validate_get_request() click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 36
def validate_get_request
  true
end
validate_post_request() click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 40
def validate_post_request
  if @request.path_info.end_with?('git-upload-pack')
    can?(user, :push_code, project)
  elsif @request.path_info.end_with?('git-receive-pack')
    action = if project.protected_branch?(current_ref)
               :push_code_to_protected_branches
             else
               :push_code
             end

    can?(user, action, project)
  else
    false
  end
end

Protected Instance Methods

abilities() click to toggle source
# File lib/gitlab/backend/grack_auth.rb, line 73
def abilities
  @abilities ||= begin
                   abilities = Six.new
                   abilities << Ability
                   abilities
                 end
end