Commit 2d212e40 authored by Zeger-Jan van de Weg's avatar Zeger-Jan van de Weg

Remove repo_path from GitlabShell

The internal api returns '/' from gitlab, since
`8fad07383ada021fc995294fd0fe0f77fe37da35` from GitLab CE. To clean up
later, https://gitlab.com/gitlab-org/gitlab-shell/issues/135 was
created.

This change closes that issue, making it possible to remove the field
from the response on GitLab-CE too. Given the Rails app always returns
`/` as the repository_path, the associated checks are basically a noop
too. The tests are updated and at times look a little fishy, but those
are testing code that is to be removed in another MR.

Closes https://gitlab.com/gitlab-org/gitlab-shell/issues/135
parent fb8606f6
...@@ -3,14 +3,13 @@ require 'json' ...@@ -3,14 +3,13 @@ require 'json'
class GitAccessStatus class GitAccessStatus
attr_reader :message, :gl_repository, :gl_id, :gl_username, :repository_path, :gitaly, :git_protocol, :git_config_options attr_reader :message, :gl_repository, :gl_id, :gl_username, :repository_path, :gitaly, :git_protocol, :git_config_options
def initialize(status, message, gl_repository:, gl_id:, gl_username:, repository_path:, gitaly:, git_protocol:, git_config_options:) def initialize(status, message, gl_repository:, gl_id:, gl_username:, gitaly:, git_protocol:, git_config_options:)
@status = status @status = status
@message = message @message = message
@gl_repository = gl_repository @gl_repository = gl_repository
@gl_id = gl_id @gl_id = gl_id
@gl_username = gl_username @gl_username = gl_username
@git_config_options = git_config_options @git_config_options = git_config_options
@repository_path = repository_path
@gitaly = gitaly @gitaly = gitaly
@git_protocol = git_protocol @git_protocol = git_protocol
end end
...@@ -23,7 +22,6 @@ class GitAccessStatus ...@@ -23,7 +22,6 @@ class GitAccessStatus
gl_id: values["gl_id"], gl_id: values["gl_id"],
gl_username: values["gl_username"], gl_username: values["gl_username"],
git_config_options: values["git_config_options"], git_config_options: values["git_config_options"],
repository_path: values["repository_path"],
gitaly: values["gitaly"], gitaly: values["gitaly"],
git_protocol: values["git_protocol"]) git_protocol: values["git_protocol"])
end end
......
...@@ -19,7 +19,6 @@ class GitlabShell # rubocop:disable Metrics/ClassLength ...@@ -19,7 +19,6 @@ class GitlabShell # rubocop:disable Metrics/ClassLength
GL_PROTOCOL = 'ssh'.freeze GL_PROTOCOL = 'ssh'.freeze
attr_accessor :gl_id, :gl_repository, :repo_name, :command, :git_access, :git_protocol attr_accessor :gl_id, :gl_repository, :repo_name, :command, :git_access, :git_protocol
attr_reader :repo_path
def initialize(who) def initialize(who)
who_sym, = GitlabNet.parse_who(who) who_sym, = GitlabNet.parse_who(who)
...@@ -116,7 +115,6 @@ class GitlabShell # rubocop:disable Metrics/ClassLength ...@@ -116,7 +115,6 @@ class GitlabShell # rubocop:disable Metrics/ClassLength
raise AccessDeniedError, status.message unless status.allowed? raise AccessDeniedError, status.message unless status.allowed?
self.repo_path = status.repository_path
@gl_repository = status.gl_repository @gl_repository = status.gl_repository
@git_protocol = ENV['GIT_PROTOCOL'] @git_protocol = ENV['GIT_PROTOCOL']
@gitaly = status.gitaly @gitaly = status.gitaly
...@@ -139,7 +137,7 @@ class GitlabShell # rubocop:disable Metrics/ClassLength ...@@ -139,7 +137,7 @@ class GitlabShell # rubocop:disable Metrics/ClassLength
end end
executable = @command executable = @command
args = [repo_path] args = []
if GITALY_MIGRATED_COMMANDS.key?(executable) && @gitaly if GITALY_MIGRATED_COMMANDS.key?(executable) && @gitaly
executable = GITALY_MIGRATED_COMMANDS[executable] executable = GITALY_MIGRATED_COMMANDS[executable]
...@@ -293,11 +291,4 @@ class GitlabShell # rubocop:disable Metrics/ClassLength ...@@ -293,11 +291,4 @@ class GitlabShell # rubocop:disable Metrics/ClassLength
return false return false
end end
end end
def repo_path=(repo_path)
raise ArgumentError, "Repository path not provided. Please make sure you're using GitLab v8.10 or later." unless repo_path
raise InvalidRepositoryPathError if File.absolute_path(repo_path) != repo_path
@repo_path = repo_path
end
end end
...@@ -13,7 +13,6 @@ describe GitlabAccess do ...@@ -13,7 +13,6 @@ describe GitlabAccess do
gl_id: 'user-123', gl_id: 'user-123',
gl_username: 'testuser', gl_username: 'testuser',
git_config_options: ['receive.MaxInputSize=10000'], git_config_options: ['receive.MaxInputSize=10000'],
repository_path: '/home/git/repositories',
gitaly: nil, gitaly: nil,
git_protocol: 'version=2')) git_protocol: 'version=2'))
end end
...@@ -51,7 +50,6 @@ describe GitlabAccess do ...@@ -51,7 +50,6 @@ describe GitlabAccess do
gl_id: nil, gl_id: nil,
gl_username: nil, gl_username: nil,
git_config_options: nil, git_config_options: nil,
repository_path: nil,
gitaly: nil, gitaly: nil,
git_protocol: nil git_protocol: nil
)) ))
......
...@@ -29,7 +29,6 @@ describe GitlabShell do ...@@ -29,7 +29,6 @@ describe GitlabShell do
gl_id: gl_id, gl_id: gl_id,
gl_username: gl_username, gl_username: gl_username,
git_config_options: git_config_options, git_config_options: git_config_options,
repository_path: repo_path,
gitaly: { 'repository' => { 'relative_path' => repo_name, 'storage_name' => 'default'} , 'address' => 'unix:gitaly.socket' }, gitaly: { 'repository' => { 'relative_path' => repo_name, 'storage_name' => 'default'} , 'address' => 'unix:gitaly.socket' },
git_protocol: git_protocol git_protocol: git_protocol
) )
...@@ -45,7 +44,6 @@ describe GitlabShell do ...@@ -45,7 +44,6 @@ describe GitlabShell do
gl_id: gl_id, gl_id: gl_id,
gl_username: gl_username, gl_username: gl_username,
git_config_options: nil, git_config_options: nil,
repository_path: repo_path,
gitaly: nil, gitaly: nil,
git_protocol: git_protocol)) git_protocol: git_protocol))
allow(api).to receive(:two_factor_recovery_codes).and_return({ allow(api).to receive(:two_factor_recovery_codes).and_return({
...@@ -60,7 +58,6 @@ describe GitlabShell do ...@@ -60,7 +58,6 @@ describe GitlabShell do
let(:tmp_repos_path) { File.join(ROOT_PATH, 'tmp', 'repositories') } let(:tmp_repos_path) { File.join(ROOT_PATH, 'tmp', 'repositories') }
let(:repo_name) { 'gitlab-ci.git' } let(:repo_name) { 'gitlab-ci.git' }
let(:repo_path) { File.join(tmp_repos_path, repo_name) }
let(:gl_repository) { 'project-1' } let(:gl_repository) { 'project-1' }
let(:gl_id) { 'user-1' } let(:gl_id) { 'user-1' }
let(:gl_username) { 'testuser' } let(:gl_username) { 'testuser' }
...@@ -189,13 +186,13 @@ describe GitlabShell do ...@@ -189,13 +186,13 @@ describe GitlabShell do
end end
it "should execute the command" do it "should execute the command" do
expect(subject).to receive(:exec_cmd).with('git-upload-pack', repo_path) expect(subject).to receive(:exec_cmd).with('git-upload-pack')
end end
it "should log the command execution" do it "should log the command execution" do
message = "executing git command" message = "executing git command"
user_string = "user with id #{gl_id}" user_string = "user with id #{gl_id}"
expect($logger).to receive(:info).with(message, command: "git-upload-pack #{repo_path}", user: user_string) expect($logger).to receive(:info).with(message, command: "git-upload-pack", user: user_string)
end end
it "should use usernames if configured to do so" do it "should use usernames if configured to do so" do
...@@ -248,13 +245,13 @@ describe GitlabShell do ...@@ -248,13 +245,13 @@ describe GitlabShell do
end end
it "should execute the command" do it "should execute the command" do
expect(subject).to receive(:exec_cmd).with('git-receive-pack', repo_path) expect(subject).to receive(:exec_cmd).with('git-receive-pack')
end end
it "should log the command execution" do it "should log the command execution" do
message = "executing git command" message = "executing git command"
user_string = "user with id #{gl_id}" user_string = "user with id #{gl_id}"
expect($logger).to receive(:info).with(message, command: "git-receive-pack #{repo_path}", user: user_string) expect($logger).to receive(:info).with(message, command: "git-receive-pack", user: user_string)
end end
end end
...@@ -287,7 +284,7 @@ describe GitlabShell do ...@@ -287,7 +284,7 @@ describe GitlabShell do
shared_examples_for 'upload-archive' do |command| shared_examples_for 'upload-archive' do |command|
let(:ssh_cmd) { "#{command} gitlab-ci.git" } let(:ssh_cmd) { "#{command} gitlab-ci.git" }
let(:exec_cmd_params) { ['git-upload-archive', repo_path] } let(:exec_cmd_params) { ['git-upload-archive'] }
let(:exec_cmd_log_params) { exec_cmd_params } let(:exec_cmd_log_params) { exec_cmd_params }
after { subject.exec(ssh_cmd) } after { subject.exec(ssh_cmd) }
...@@ -441,7 +438,6 @@ describe GitlabShell do ...@@ -441,7 +438,6 @@ describe GitlabShell do
gl_id: nil, gl_id: nil,
gl_username: nil, gl_username: nil,
git_config_options: nil, git_config_options: nil,
repository_path: nil,
gitaly: nil, gitaly: nil,
git_protocol: nil)) git_protocol: nil))
message = 'Access denied' message = 'Access denied'
...@@ -449,25 +445,6 @@ describe GitlabShell do ...@@ -449,25 +445,6 @@ describe GitlabShell do
expect($logger).to receive(:warn).with(message, command: 'git-upload-pack gitlab-ci.git', user: user_string) expect($logger).to receive(:warn).with(message, command: 'git-upload-pack gitlab-ci.git', user: user_string)
end end
end end
describe 'set the repository path' do
context 'with a correct path' do
before { subject.exec(ssh_cmd) }
it { expect(subject.repo_path).to eq repo_path }
end
context "with a path that doesn't match an absolute path" do
before do
allow(File).to receive(:absolute_path) { 'y/gitlab-ci.git' }
end
it "refuses to assign the path" do
expect($stderr).to receive(:puts).with("GitLab: Invalid repository path")
expect(subject.exec(ssh_cmd)).to be_falsey
end
end
end
end end
describe :exec_cmd do describe :exec_cmd do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment