54 lines
1.7 KiB
Ruby
54 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class LfsObject < ApplicationRecord
|
|
include AfterCommitQueue
|
|
include Checksummable
|
|
include EachBatch
|
|
include ObjectStorage::BackgroundMove
|
|
|
|
has_many :lfs_objects_projects, dependent: :destroy # rubocop:disable Cop/ActiveRecordDependent
|
|
has_many :projects, -> { distinct }, through: :lfs_objects_projects
|
|
|
|
scope :with_files_stored_locally, -> { where(file_store: LfsObjectUploader::Store::LOCAL) }
|
|
scope :with_files_stored_remotely, -> { where(file_store: LfsObjectUploader::Store::REMOTE) }
|
|
|
|
validates :oid, presence: true, uniqueness: true
|
|
|
|
mount_uploader :file, LfsObjectUploader
|
|
|
|
after_save :update_file_store, if: :saved_change_to_file?
|
|
|
|
def update_file_store
|
|
# The file.object_store is set during `uploader.store!`
|
|
# which happens after object is inserted/updated
|
|
self.update_column(:file_store, file.object_store)
|
|
end
|
|
|
|
def project_allowed_access?(project)
|
|
if project.fork_network_member
|
|
lfs_objects_projects
|
|
.where("EXISTS(?)", project.fork_network.fork_network_members.select(1).where("fork_network_members.project_id = lfs_objects_projects.project_id"))
|
|
.exists?
|
|
else
|
|
lfs_objects_projects.where(project_id: project.id).exists?
|
|
end
|
|
end
|
|
|
|
def local_store?
|
|
file_store == LfsObjectUploader::Store::LOCAL
|
|
end
|
|
|
|
# rubocop: disable DestroyAll
|
|
def self.destroy_unreferenced
|
|
joins("LEFT JOIN lfs_objects_projects ON lfs_objects_projects.lfs_object_id = #{table_name}.id")
|
|
.where(lfs_objects_projects: { id: nil })
|
|
.destroy_all
|
|
end
|
|
# rubocop: enable DestroyAll
|
|
|
|
def self.calculate_oid(path)
|
|
self.hexdigest(path)
|
|
end
|
|
end
|
|
|
|
LfsObject.prepend_if_ee('EE::LfsObject')
|