39 lines
1.1 KiB
Ruby
39 lines
1.1 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
# Projects::RepositoryStorageMove are details of repository storage moves for a
|
||
|
# project. For example, moving a project to another gitaly node to help
|
||
|
# balance storage capacity.
|
||
|
module Projects
|
||
|
class RepositoryStorageMove < ApplicationRecord
|
||
|
extend ::Gitlab::Utils::Override
|
||
|
include RepositoryStorageMovable
|
||
|
|
||
|
self.table_name = 'project_repository_storage_moves'
|
||
|
|
||
|
belongs_to :container, class_name: 'Project', inverse_of: :repository_storage_moves, foreign_key: :project_id
|
||
|
alias_attribute :project, :container
|
||
|
scope :with_projects, -> { includes(container: :route) }
|
||
|
|
||
|
override :update_repository_storage
|
||
|
def update_repository_storage(new_storage)
|
||
|
container.update_column(:repository_storage, new_storage)
|
||
|
end
|
||
|
|
||
|
override :schedule_repository_storage_update_worker
|
||
|
def schedule_repository_storage_update_worker
|
||
|
Projects::UpdateRepositoryStorageWorker.perform_async(
|
||
|
project_id,
|
||
|
destination_storage_name,
|
||
|
id
|
||
|
)
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
override :error_key
|
||
|
def error_key
|
||
|
:project
|
||
|
end
|
||
|
end
|
||
|
end
|