Commit 139b3bed authored by Tiago Botelho's avatar Tiago Botelho

Renames remote_mirror_available to mirror_available to not only incorporate...

Renames remote_mirror_available to mirror_available to not only incorporate push mirrors but pull mirrors as well.
parent 35de313a
...@@ -128,7 +128,6 @@ ...@@ -128,7 +128,6 @@
- if License.feature_available?(:repository_mirrors) - if License.feature_available?(:repository_mirrors)
= render partial: 'repository_mirrors_form', locals: { f: f } = render partial: 'repository_mirrors_form', locals: { f: f }
= render partial: 'repository_remote_mirrors_form', locals: { f: f }
%fieldset %fieldset
%legend Sign-up Restrictions %legend Sign-up Restrictions
......
class RenameRemoteMirrorAvailableToMirrorAvailable < ActiveRecord::Migration
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def up
rename_column_concurrently :application_settings, :remote_mirror_available, :mirror_available
end
def down
cleanup_concurrent_column_rename :application_settings, :mirror_available, :remote_mirror_available
end
end
class AddPullMirrorAvailableOverriddenToProjects < ActiveRecord::Migration
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def change
add_column :projects, :pull_mirror_available_overridden, :boolean
end
end
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
# #
# It's strongly recommended that you check this file into your version control system. # It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20171124182517) do ActiveRecord::Schema.define(version: 20171129152659) do
# These are extensions that must be enabled in order to support this database # These are extensions that must be enabled in order to support this database
enable_extension "plpgsql" enable_extension "plpgsql"
...@@ -162,7 +162,6 @@ ActiveRecord::Schema.define(version: 20171124182517) do ...@@ -162,7 +162,6 @@ ActiveRecord::Schema.define(version: 20171124182517) do
t.integer "circuitbreaker_failure_wait_time", default: 30 t.integer "circuitbreaker_failure_wait_time", default: 30
t.integer "circuitbreaker_failure_reset_time", default: 1800 t.integer "circuitbreaker_failure_reset_time", default: 1800
t.integer "circuitbreaker_storage_timeout", default: 30 t.integer "circuitbreaker_storage_timeout", default: 30
t.boolean "remote_mirror_available", default: true, null: false
t.integer "circuitbreaker_access_retries", default: 3 t.integer "circuitbreaker_access_retries", default: 3
t.integer "circuitbreaker_backoff_threshold", default: 80 t.integer "circuitbreaker_backoff_threshold", default: 80
t.boolean "throttle_unauthenticated_enabled", default: false, null: false t.boolean "throttle_unauthenticated_enabled", default: false, null: false
...@@ -179,6 +178,7 @@ ActiveRecord::Schema.define(version: 20171124182517) do ...@@ -179,6 +178,7 @@ ActiveRecord::Schema.define(version: 20171124182517) do
t.integer "gitaly_timeout_default", default: 55, null: false t.integer "gitaly_timeout_default", default: 55, null: false
t.integer "gitaly_timeout_medium", default: 30, null: false t.integer "gitaly_timeout_medium", default: 30, null: false
t.integer "gitaly_timeout_fast", default: 10, null: false t.integer "gitaly_timeout_fast", default: 10, null: false
t.boolean "mirror_available", default: true, null: false
end end
create_table "approvals", force: :cascade do |t| create_table "approvals", force: :cascade do |t|
...@@ -1856,6 +1856,7 @@ ActiveRecord::Schema.define(version: 20171124182517) do ...@@ -1856,6 +1856,7 @@ ActiveRecord::Schema.define(version: 20171124182517) do
t.boolean "resolve_outdated_diff_discussions" t.boolean "resolve_outdated_diff_discussions"
t.boolean "remote_mirror_available_overridden" t.boolean "remote_mirror_available_overridden"
t.boolean "only_mirror_protected_branches" t.boolean "only_mirror_protected_branches"
t.boolean "pull_mirror_available_overridden"
end end
add_index "projects", ["ci_id"], name: "index_projects_on_ci_id", using: :btree add_index "projects", ["ci_id"], name: "index_projects_on_ci_id", using: :btree
......
...@@ -2,6 +2,7 @@ class Projects::MirrorsController < Projects::ApplicationController ...@@ -2,6 +2,7 @@ class Projects::MirrorsController < Projects::ApplicationController
include RepositorySettingsRedirect include RepositorySettingsRedirect
include SafeMirrorParams include SafeMirrorParams
# Authorize # Authorize
before_action :authorize_admin_mirror
before_action :authorize_admin_project! before_action :authorize_admin_project!
before_action :remote_mirror, only: [:update] before_action :remote_mirror, only: [:update]
before_action :check_repository_mirrors_available! before_action :check_repository_mirrors_available!
...@@ -73,12 +74,8 @@ class Projects::MirrorsController < Projects::ApplicationController ...@@ -73,12 +74,8 @@ class Projects::MirrorsController < Projects::ApplicationController
@remote_mirror = @project.remote_mirrors.first_or_initialize @remote_mirror = @project.remote_mirrors.first_or_initialize
end end
def remote_mirror_attributes
{ remote_mirrors_attributes: %i[url id enabled only_protected_branches] }
end
def mirror_params_attributes def mirror_params_attributes
attributes = [ [
:mirror, :mirror,
:import_url, :import_url,
:username_only_import_url, :username_only_import_url,
...@@ -92,14 +89,15 @@ class Projects::MirrorsController < Projects::ApplicationController ...@@ -92,14 +89,15 @@ class Projects::MirrorsController < Projects::ApplicationController
password password
ssh_known_hosts ssh_known_hosts
regenerate_ssh_private_key regenerate_ssh_private_key
],
remote_mirror_attributes: %i[
url
id
enabled
only_protected_branches
] ]
] ]
if can?(current_user, :admin_remote_mirror, project)
attributes << remote_mirror_attributes
end
attributes
end end
def mirror_params def mirror_params
......
...@@ -23,7 +23,7 @@ module EE ...@@ -23,7 +23,7 @@ module EE
:slack_app_secret, :slack_app_secret,
:slack_app_verification_token, :slack_app_verification_token,
:allow_group_owners_to_manage_ldap, :allow_group_owners_to_manage_ldap,
:remote_mirror_available :mirror_available
] ]
end end
......
...@@ -41,7 +41,7 @@ module EE ...@@ -41,7 +41,7 @@ module EE
mirror_max_capacity: Settings.gitlab['mirror_max_capacity'], mirror_max_capacity: Settings.gitlab['mirror_max_capacity'],
mirror_capacity_threshold: Settings.gitlab['mirror_capacity_threshold'], mirror_capacity_threshold: Settings.gitlab['mirror_capacity_threshold'],
allow_group_owners_to_manage_ldap: true, allow_group_owners_to_manage_ldap: true,
remote_mirror_available: true mirror_available: true
) )
end end
end end
......
...@@ -500,7 +500,7 @@ module EE ...@@ -500,7 +500,7 @@ module EE
def remote_mirror_available? def remote_mirror_available?
remote_mirror_available_overridden || remote_mirror_available_overridden ||
current_application_settings.remote_mirror_available current_application_settings.mirror_available
end end
private private
......
...@@ -21,7 +21,7 @@ class RemoteMirror < ActiveRecord::Base ...@@ -21,7 +21,7 @@ class RemoteMirror < ActiveRecord::Base
validate :url_availability, if: -> (mirror) { mirror.url_changed? || mirror.enabled? } validate :url_availability, if: -> (mirror) { mirror.url_changed? || mirror.enabled? }
validates :url, addressable_url: true, if: :url_changed? validates :url, addressable_url: true, if: :url_changed?
after_save :set_override_remote_mirror_available, unless: -> { Gitlab::CurrentSettings.current_application_settings.remote_mirror_available } after_save :set_override_remote_mirror_available, unless: -> { Gitlab::CurrentSettings.current_application_settings.mirror_available }
after_save :refresh_remote, if: :mirror_url_changed? after_save :refresh_remote, if: :mirror_url_changed?
after_update :reset_fields, if: :mirror_url_changed? after_update :reset_fields, if: :mirror_url_changed?
after_destroy :remove_remote after_destroy :remove_remote
......
...@@ -26,8 +26,8 @@ module EE ...@@ -26,8 +26,8 @@ module EE
end end
with_scope :global with_scope :global
condition(:remote_mirror_available) do condition(:mirror_available) do
::Gitlab::CurrentSettings.current_application_settings.remote_mirror_available ::Gitlab::CurrentSettings.current_application_settings.mirror_available
end end
rule { admin }.enable :change_repository_storage rule { admin }.enable :change_repository_storage
...@@ -60,7 +60,7 @@ module EE ...@@ -60,7 +60,7 @@ module EE
rule { can?(:developer_access) }.enable :admin_board rule { can?(:developer_access) }.enable :admin_board
rule { (remote_mirror_available & can?(:admin_project)) | admin }.enable :admin_remote_mirror rule { (mirror_available & can?(:admin_project)) | admin }.enable :admin_mirror
rule { deploy_board_disabled & ~is_development }.prevent :read_deploy_board rule { deploy_board_disabled & ~is_development }.prevent :read_deploy_board
......
- if Gitlab.com? && License.feature_available?(:repository_mirrors) - if Gitlab.com? && License.feature_available?(:repository_mirrors)
%fieldset %fieldset
%legend Repository mirror settings %legend Repository mirror settings
.form-group
= f.label :mirror_available, 'Enable mirror configuration', class: 'control-label col-sm-2'
.col-sm-10
.checkbox
= f.label :mirror_available, do
= f.check_box :mirror_available
Allow mirrors to be setup for projects
%span.help-block
If disabled, only admins will be able to setup mirrors in projects.
= link_to icon('question-circle'), help_page_path('workflow/repository_mirroring')
.form-group .form-group
= f.label :mirror_max_delay, class: 'control-label col-sm-2' do = f.label :mirror_max_delay, class: 'control-label col-sm-2' do
Maximum delay (Minutes) Maximum delay (Minutes)
......
%fieldset
%legend Repository Remote mirror settings
.form-group
= f.label :remote_mirror_available, 'Enable remote mirror configuration', class: 'control-label col-sm-2'
.col-sm-10
.checkbox
= f.label :remote_mirror_available do
= f.check_box :remote_mirror_available
Allow remote mirrors to be setup for projects
%span.help-block
If disabled, only admins will be able to setup remote mirrors in projects.
= link_to icon('question-circle'), help_page_path('workflow/repository_mirroring', anchor: 'pushing-to-a-remote-repository')
...@@ -2,6 +2,6 @@ ...@@ -2,6 +2,6 @@
= webpack_bundle_tag 'mirrors' = webpack_bundle_tag 'mirrors'
- if @project.feature_available?(:repository_mirrors) - if @project.feature_available?(:repository_mirrors)
= render 'projects/mirrors/pull' - if can?(current_user, :admin_mirror, @project)
- if can?(current_user, :admin_remote_mirror, @project) = render 'projects/mirrors/pull'
= render 'projects/mirrors/push' = render 'projects/mirrors/push'
...@@ -108,6 +108,7 @@ excluded_attributes: ...@@ -108,6 +108,7 @@ excluded_attributes:
- :storage_version - :storage_version
- :remote_mirror_available_overridden - :remote_mirror_available_overridden
- :only_mirror_protected_branches - :only_mirror_protected_branches
- :pull_mirror_available_overridden
snippets: snippets:
- :expired_at - :expired_at
merge_request_diff: merge_request_diff:
......
...@@ -9,7 +9,7 @@ describe Projects::MirrorsController do ...@@ -9,7 +9,7 @@ describe Projects::MirrorsController do
context 'when remote mirrors are disabled' do context 'when remote mirrors are disabled' do
before do before do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
end end
context 'when user is admin' do context 'when user is admin' do
...@@ -162,7 +162,7 @@ describe Projects::MirrorsController do ...@@ -162,7 +162,7 @@ describe Projects::MirrorsController do
let(:project) { create(:project, :repository, :remote_mirror) } let(:project) { create(:project, :repository, :remote_mirror) }
before do before do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
sign_in(project.owner) sign_in(project.owner)
end end
......
...@@ -451,7 +451,7 @@ describe Project do ...@@ -451,7 +451,7 @@ describe Project do
end end
it 'does nothing when remote mirror is disabled globally and not overridden' do it 'does nothing when remote mirror is disabled globally and not overridden' do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
project.remote_mirror_available_overridden = false project.remote_mirror_available_overridden = false
expect_any_instance_of(RemoteMirror).not_to receive(:sync) expect_any_instance_of(RemoteMirror).not_to receive(:sync)
...@@ -1040,28 +1040,28 @@ describe Project do ...@@ -1040,28 +1040,28 @@ describe Project do
end end
end end
describe '#remote_mirror_available?' do describe '#mirror_available?' do
let(:project) { create(:project) } let(:project) { create(:project) }
context 'when remote mirror global setting is enabled' do context 'when remote mirror global setting is enabled' do
it 'returns true' do it 'returns true' do
expect(project.remote_mirror_available?).to be(true) expect(project.mirror_available?).to be(true)
end end
end end
context 'when remote mirror global setting is disabled' do context 'when remote mirror global setting is disabled' do
before do before do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
end end
it 'returns true when overridden' do it 'returns true when overridden' do
project.remote_mirror_available_overridden = true project.remote_mirror_available_overridden = true
expect(project.remote_mirror_available?).to be(true) expect(project.mirror_available?).to be(true)
end end
it 'returns false when not overridden' do it 'returns false when not overridden' do
expect(project.remote_mirror_available?).to be(false) expect(project.mirror_available?).to be(false)
end end
end end
end end
......
...@@ -10,7 +10,7 @@ describe ProjectPolicy do ...@@ -10,7 +10,7 @@ describe ProjectPolicy do
project.add_developer(developer) project.add_developer(developer)
end end
context 'admin_remote_mirror' do context 'admin_mirror' do
context 'with remote mirror setting enabled' do context 'with remote mirror setting enabled' do
context 'with admin' do context 'with admin' do
subject do subject do
...@@ -18,7 +18,7 @@ describe ProjectPolicy do ...@@ -18,7 +18,7 @@ describe ProjectPolicy do
end end
it do it do
is_expected.to be_allowed(:admin_remote_mirror) is_expected.to be_allowed(:admin_mirror)
end end
end end
...@@ -28,7 +28,7 @@ describe ProjectPolicy do ...@@ -28,7 +28,7 @@ describe ProjectPolicy do
end end
it do it do
is_expected.to be_allowed(:admin_remote_mirror) is_expected.to be_allowed(:admin_mirror)
end end
end end
...@@ -38,14 +38,14 @@ describe ProjectPolicy do ...@@ -38,14 +38,14 @@ describe ProjectPolicy do
end end
it do it do
is_expected.to be_disallowed(:admin_remote_mirror) is_expected.to be_disallowed(:admin_mirror)
end end
end end
end end
context 'with remote mirror setting disabled' do context 'with remote mirror setting disabled' do
before do before do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
end end
context 'with admin' do context 'with admin' do
...@@ -54,7 +54,7 @@ describe ProjectPolicy do ...@@ -54,7 +54,7 @@ describe ProjectPolicy do
end end
it do it do
is_expected.to be_allowed(:admin_remote_mirror) is_expected.to be_allowed(:admin_mirror)
end end
end end
...@@ -64,7 +64,7 @@ describe ProjectPolicy do ...@@ -64,7 +64,7 @@ describe ProjectPolicy do
end end
it do it do
is_expected.to be_disallowed(:admin_remote_mirror) is_expected.to be_disallowed(:admin_mirror)
end end
end end
end end
......
...@@ -38,7 +38,7 @@ describe GitPushService do ...@@ -38,7 +38,7 @@ describe GitPushService do
context 'when remote mirror feature is disabled' do context 'when remote mirror feature is disabled' do
before do before do
stub_application_setting(remote_mirror_available: false) stub_application_setting(mirror_available: false)
end end
context 'with remote mirrors global setting overridden' do context 'with remote mirrors global setting overridden' 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