datacite/lupo

View on GitHub
app/jobs/url_job.rb

Summary

Maintainability
B
4 hrs
Test Coverage
# frozen_string_literal: true

class UrlJob < ApplicationJob
  queue_as :lupo

  # retry_on ActiveRecord::Deadlocked, wait: 10.seconds, attempts: 3
  # retry_on Faraday::TimeoutError, wait: 10.minutes, attempts: 3

  # discard_on ActiveJob::DeserializationError

  def perform(doi_id)
    doi = Doi.where(doi: doi_id).first

    if doi.present?
      response = Doi.get_doi(doi: doi.doi, agency: doi.agency)
      url =
        if response.is_a?(String)
          nil
        else
          response.body.dig("data", "values", 0, "data", "value")
        end

      if url.present?
        if (
           doi.is_registered_or_findable? || %w[europ].include?(doi.provider_id)
         ) &&
            doi.minted.blank?
          doi.update(url: url, minted: Time.zone.now)
        else
          doi.update(url: url)
        end

        doi.update(aasm_state: "findable") if doi.type == "OtherDoi"

        doi.__elasticsearch__.index_document

        unless Rails.env.test?
          Rails.logger.info "[Handle] URL #{url} set for DOI #{doi.doi}."
        end
      else
        unless Rails.env.test?
          Rails.logger.info "[Handle] Error updating URL for DOI #{
                              doi.doi
                            }: URL not found."
        end
      end
    else
      unless Rails.env.test?
        Rails.logger.info "[Handle] Error updating URL for DOI #{
                            doi_id
                          }: DOI not found"
      end
    end
  end
end