require 'logger'

desc "GitLab | LFS | Migrate LFS objects to remote storage"
namespace :gitlab do
  namespace :lfs do
    task migrate: :environment do
      logger = Logger.new(STDOUT)
      logger.info('Starting transfer of LFS files to object storage')

      LfsObject.with_files_stored_locally
        .find_each(batch_size: 10) do |lfs_object|
          lfs_object.file.migrate!(LfsObjectUploader::Store::REMOTE)

          logger.info("Transferred LFS object #{lfs_object.oid} of size #{lfs_object.size.to_i.bytes} to object storage")
        rescue => e
          logger.error("Failed to transfer LFS object #{lfs_object.oid} with error: #{e.message}")
        end
    end

    task migrate_to_local: :environment do
      logger = Logger.new(STDOUT)
      logger.info('Starting transfer of LFS files to local storage')

      LfsObject.with_files_stored_remotely
        .find_each(batch_size: 10) do |lfs_object|
        lfs_object.file.migrate!(LfsObjectUploader::Store::LOCAL)

        logger.info("Transferred LFS object #{lfs_object.oid} of size #{lfs_object.size.to_i.bytes} to local storage")
      rescue => e
        logger.error("Failed to transfer LFS object #{lfs_object.oid} with error: #{e.message}")
      end
    end
  end
end