Commit 0e0f3adf authored by Sean McGivern's avatar Sean McGivern

Merge branch '232636-add-support-for-fixing-composer-404' into 'master'

Support private token headers for composer

Closes #232636

See merge request gitlab-org/gitlab!38641
parents 3c0b6a9f bcc83ffd
---
title: Fix composer 404 issues with http auth
merge_request: 38641
author:
type: fixed
...@@ -130,11 +130,8 @@ You also need to create a `auth.json` file with your GitLab credentials: ...@@ -130,11 +130,8 @@ You also need to create a `auth.json` file with your GitLab credentials:
```json ```json
{ {
"http-basic": { "gitlab-token": {
"gitlab.com": { "gitlab.com": "<personal_access_token>"
"username": "___token___",
"password": "<personal_access_token>"
}
} }
} }
``` ```
......
This diff is collapsed.
...@@ -16,10 +16,13 @@ RSpec.shared_examples 'Composer package index' do |user_type, status, add_member ...@@ -16,10 +16,13 @@ RSpec.shared_examples 'Composer package index' do |user_type, status, add_member
subject subject
expect(response).to have_gitlab_http_status(status) expect(response).to have_gitlab_http_status(status)
if status == :success
expect(response).to match_response_schema('public_api/v4/packages/composer/index') expect(response).to match_response_schema('public_api/v4/packages/composer/index')
expect(json_response).to eq presenter.root expect(json_response).to eq presenter.root
end end
end end
end
end end
RSpec.shared_examples 'Composer empty provider index' do |user_type, status, add_member = true| RSpec.shared_examples 'Composer empty provider index' do |user_type, status, add_member = true|
...@@ -87,13 +90,22 @@ RSpec.shared_examples 'process Composer api request' do |user_type, status, add_ ...@@ -87,13 +90,22 @@ RSpec.shared_examples 'process Composer api request' do |user_type, status, add_
end end
end end
RSpec.shared_context 'Composer auth headers' do |user_role, user_token| RSpec.shared_context 'Composer auth headers' do |user_role, user_token, auth_method = :token|
let(:token) { user_token ? personal_access_token.token : 'wrong' } let(:token) { user_token ? personal_access_token.token : 'wrong' }
let(:headers) { user_role == :anonymous ? {} : basic_auth_header(user.username, token) }
let(:headers) do
if user_role == :anonymous
{}
elsif auth_method == :token
{ 'Private-Token' => token }
else
basic_auth_header(user.username, token)
end
end
end end
RSpec.shared_context 'Composer api project access' do |project_visibility_level, user_role, user_token| RSpec.shared_context 'Composer api project access' do |project_visibility_level, user_role, user_token, auth_method|
include_context 'Composer auth headers', user_role, user_token do include_context 'Composer auth headers', user_role, user_token, auth_method do
before do before do
project.update!(visibility_level: Gitlab::VisibilityLevel.const_get(project_visibility_level, false)) project.update!(visibility_level: Gitlab::VisibilityLevel.const_get(project_visibility_level, false))
end end
......
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