Commit f6cbf23e authored by Toon Claes's avatar Toon Claes

Refactor to enable not all records are replicable

Some replicable types might have records that are not possible to
replicate.

This change splits out a scope for the replicables that are
replicatable. The Geo primary node can use this scope for example for
checksumming. To determine replicables for a Secondary node, this scope
is also used, in combination with the selective sync and object storage
settings.

Closes https://gitlab.com/gitlab-org/gitlab/-/issues/243567
parent d89cf462
...@@ -207,6 +207,11 @@ For example, to add support for files referenced by a `Widget` model with a ...@@ -207,6 +207,11 @@ For example, to add support for files referenced by a `Widget` model with a
end end
``` ```
NOTE: **Note:**
If there is a common constraint for records to be available for replication,
make sure to also overwrite the `available_replicables` scope.
1. Create `ee/app/replicators/geo/widget_replicator.rb`. Implement the 1. Create `ee/app/replicators/geo/widget_replicator.rb`. Implement the
`#carrierwave_uploader` method which should return a `CarrierWave::Uploader`. `#carrierwave_uploader` method which should return a `CarrierWave::Uploader`.
And implement the class method `.model` to return the `Widget` class. And implement the class method `.model` to return the `Widget` class.
......
...@@ -24,8 +24,9 @@ module EE ...@@ -24,8 +24,9 @@ module EE
scope :has_external_diffs, -> { with_files.where(stored_externally: true) } scope :has_external_diffs, -> { with_files.where(stored_externally: true) }
scope :project_id_in, ->(ids) { where(merge_request_id: ::MergeRequest.where(target_project_id: ids)) } scope :project_id_in, ->(ids) { where(merge_request_id: ::MergeRequest.where(target_project_id: ids)) }
scope :checksummed, -> { has_external_diffs.where(merge_request_diff_detail: ::MergeRequestDiffDetail.checksummed) } scope :checksummed, -> { where(merge_request_diff_detail: ::MergeRequestDiffDetail.checksummed) }
scope :checksum_failed, -> { has_external_diffs.where(merge_request_diff_detail: ::MergeRequestDiffDetail.checksum_failed) } scope :checksum_failed, -> { where(merge_request_diff_detail: ::MergeRequestDiffDetail.checksum_failed) }
scope :available_replicables, -> { has_external_diffs }
end end
class_methods do class_methods do
...@@ -34,9 +35,9 @@ module EE ...@@ -34,9 +35,9 @@ module EE
def replicables_for_current_secondary(primary_key_in) def replicables_for_current_secondary(primary_key_in)
node = ::Gitlab::Geo.current_node node = ::Gitlab::Geo.current_node
has_external_diffs.primary_key_in(primary_key_in) available_replicables.primary_key_in(primary_key_in)
.merge(selective_sync_scope(node)) .merge(selective_sync_scope(node))
.merge(object_storage_scope(node)) .merge(object_storage_scope(node))
end end
private private
......
...@@ -14,6 +14,7 @@ module Gitlab ...@@ -14,6 +14,7 @@ module Gitlab
scope :checksummed, -> { where.not(verification_checksum: nil) } scope :checksummed, -> { where.not(verification_checksum: nil) }
scope :checksum_failed, -> { where.not(verification_failure: nil) } scope :checksum_failed, -> { where.not(verification_failure: nil) }
scope :available_replicables, -> { all }
sha_attribute :verification_checksum sha_attribute :verification_checksum
end end
......
...@@ -135,19 +135,19 @@ module Gitlab ...@@ -135,19 +135,19 @@ module Gitlab
end end
def self.checksummed def self.checksummed
model.checksummed model.available_replicables.checksummed
end end
def self.checksummed_count def self.checksummed_count
model.checksummed.count model.available_replicables.checksummed.count
end end
def self.checksum_failed_count def self.checksum_failed_count
model.checksum_failed.count model.available_replicables.checksum_failed.count
end end
def self.primary_total_count def self.primary_total_count
model.count model.available_replicables.count
end end
def self.registry_count def self.registry_count
......
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