Skip to content

Commit

Permalink
Merge to master: Release 2.8.0.1 fix not found issues, OFAIRE cache a…
Browse files Browse the repository at this point in the history
…nd Annotator issues(#632)

* [ontoportal-bot] Gemfile.lock update

* implement caching for the ofaire service

* fix the browse page popularity sort

---------

Co-authored-by: OntoPortal Bot <[email protected]>
  • Loading branch information
syphax-bouazzouni and ontoportal-bot-lirmm authored May 25, 2024
1 parent ef3c6c1 commit 5079d80
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 6 deletions.
2 changes: 1 addition & 1 deletion app/controllers/concerns/submission_filter.rb
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ def ontology_hash(ont, submissions)
o[:individual_count_formatted] = number_with_delimiter(o[:individual_count], delimiter: ',')

o[:note_count] = ont.notes&.length || 0
o[:project_count] = ont.projects&.length ||
o[:project_count] = ont.projects&.length || 0
o[:popularity] = @analytics[ont.acronym] || 0
o[:rank] = sub&[:rank] || 0

Expand Down
61 changes: 56 additions & 5 deletions app/helpers/fair_score_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,23 +13,26 @@ def get_fairness_service_url(apikey = user_apikey)
end

def get_fairness_json(ontologies_acronyms, apikey = user_apikey)
Rails.cache.fetch("fairness-#{ontologies_acronyms.gsub(',', '-')}-#{apikey}", expires: 24.hours) do
if Rails.cache.exist?("fairness-#{ontologies_acronyms.gsub(',', '-')}-#{apikey}")
out = read_large_data("fairness-#{ontologies_acronyms.gsub(',', '-')}-#{apikey}")
else
out = "{}"
begin
out = {}
time = Benchmark.realtime do
conn = Faraday.new do |conn|
conn.options.timeout = 30
end
response = conn.get(get_fairness_service_url(apikey) + "&ontologies=#{ontologies_acronyms}&combined")
out = MultiJson.load(response.body.force_encoding('ISO-8859-1').encode('UTF-8'))
out = response.body.force_encoding('ISO-8859-1').encode('UTF-8')
end
puts "Call fairness service for: #{ontologies_acronyms} (#{time}s)"
rescue
Rails.logger.warn t('fair_score.fairness_unreachable_warning')
end

out
cache_large_data("fairness-#{ontologies_acronyms.gsub(',', '-')}-#{apikey}", out)
end
MultiJson.use :oj
MultiJson.load(out)
end

def get_fair_score(ontologies_acronyms, apikey = user_apikey)
Expand Down Expand Up @@ -139,5 +142,53 @@ def fairness_link(style: '', ontology: nil)
ontology = ontology || 'all'
render IconWithTooltipComponent.new(icon: "json.svg",link: "#{get_fairness_service_url}&ontologies=#{ontology}&combined=true", target: '_blank', title: t('fair_score.go_to_api'), size:'small', style: custom_style)
end

private
require 'zlib'

def cache_large_data(key, data, chunk_size = 1.megabyte)
compressed_data = Zlib::Deflate.deflate(data)
total_size = compressed_data.bytesize
Rails.logger.info "Total compressed data size: #{total_size} bytes"

# Determine the number of chunks
chunk_count = (total_size.to_f / chunk_size).ceil

chunk_count.times do |index|
chunk_key = "#{key}_chunk_#{index}"
start_byte = index * chunk_size
end_byte = start_byte + chunk_size - 1
chunk = compressed_data.byteslice(start_byte..end_byte)

unless Rails.cache.write(chunk_key, chunk, expires_in: 24.hours)
Rails.logger.error "Failed to write chunk #{index} for key: #{key}"
return false
end
end

# Store metadata about the chunks
metadata = { chunk_count: chunk_count }
Rails.cache.write("#{key}_metadata", metadata, expires_in: 24.hours)
Rails.cache.write(key, true, expires_in: 24.hours)
end

def read_large_data(key)
metadata = Rails.cache.read("#{key}_metadata")
return nil unless metadata

chunk_count = metadata[:chunk_count]
data = ''

chunk_count.times do |index|
chunk_key = "#{key}_chunk_#{index}"
chunk = Rails.cache.read(chunk_key)
return nil unless chunk
data << chunk
end

# Decompress data
Zlib::Inflate.inflate(data)
end

end

0 comments on commit 5079d80

Please sign in to comment.