Skip to content

Commit

Permalink
Fix: optimize the way we do our calls to the API (#14)
Browse files Browse the repository at this point in the history
* use $DEBUG_API_CLIENT instead of $DEBUG for debugging  request

* add  $API_CLIENT_INVALIDATE_CACHE option to disable cache

* save and re-use the top_level_links http response as the result do not change

* deprecate the find method in favor of get method for better performance

* disable the refresh_cache on each update call
  • Loading branch information
syphax-bouazzouni authored Dec 18, 2023
1 parent dc6ede1 commit ff69534
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 24 deletions.
3 changes: 2 additions & 1 deletion Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ GEM

PLATFORMS
x86_64-darwin-21
x86_64-darwin-23
x86_64-linux

DEPENDENCIES
Expand All @@ -63,4 +64,4 @@ DEPENDENCIES
test-unit

BUNDLED WITH
2.3.23
2.4.21
10 changes: 5 additions & 5 deletions lib/ontologies_api_client/collection.rb
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def method_missing(meth, *args, &block)
##
# Get all top-level links for the API
def top_level_links
HTTP.get(LinkedData::Client.settings.rest_url)
@top_level_links||= HTTP.get(LinkedData::Client.settings.rest_url)
end

##
Expand Down Expand Up @@ -75,16 +75,16 @@ def where(params = {}, &block)

##
# Find a resource by id
# @deprecated replace with "get"
def find(id, params = {})
found = where do |obj|
obj.id.eql?(id)
end
found.first
[get(id, params)]
end

##
# Get a resource by id (this will retrieve it from the REST service)
def get(id, params = {})
path = collection_path
id = "#{path}/#{id}" unless id.include?(path)
HTTP.get(id, params)
end

Expand Down
26 changes: 14 additions & 12 deletions lib/ontologies_api_client/http.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
require 'multi_json'
require 'digest'
require 'ostruct'

require 'benchmark'
##
# This monkeypatch makes OpenStruct act like Struct objects
class OpenStruct
Expand Down Expand Up @@ -58,18 +58,20 @@ def self.get(path, params = {}, options = {})
raw = options[:raw] || false # return the unparsed body of the request
params = params.delete_if { |k, v| v == nil || v.to_s.empty? }
params[:ncbo_cache_buster] = Time.now.to_f if raw # raw requests don't get cached to ensure body is available
invalidate_cache = params.delete(:invalidate_cache) || false

invalidate_cache = params.delete(:invalidate_cache) || $API_CLIENT_INVALIDATE_CACHE || false
begin
puts "Getting: #{path} with #{params}" if $DEBUG
begin
response = conn.get do |req|
req.url path
req.params = params.dup
req.options[:timeout] = 60
req.headers.merge(headers)
req.headers[:invalidate_cache] = invalidate_cache
response = nil
time = Benchmark.realtime do
response = conn.get do |req|
req.url path
req.params = params.dup
req.options[:timeout] = 60
req.headers.merge(headers)
req.headers[:invalidate_cache] = invalidate_cache
end
end
puts "Getting: #{path} with #{params} (#{time}s)" if $DEBUG_API_CLIENT
rescue Exception => e
params = Faraday::Utils.build_query(params)
path << "?" unless params.empty? || path.include?("?")
Expand All @@ -87,7 +89,7 @@ def self.get(path, params = {}, options = {})
obj = recursive_struct(load_json(response.body))
end
rescue StandardError => e
puts "Problem getting #{path}" if $DEBUG
puts "Problem getting #{path}" if $DEBUG_API_CLIENT
raise e
end
obj
Expand Down Expand Up @@ -143,7 +145,7 @@ def self.patch(path, obj)
end

def self.delete(id)
puts "Deleting #{id}" if $DEBUG
puts "Deleting #{id}" if $DEBUG_API_CLIENT
response = conn.delete id
raise StandardError, response.body if response.status >= 500

Expand Down
9 changes: 4 additions & 5 deletions lib/ontologies_api_client/models/ontology.rb
Original file line number Diff line number Diff line change
Expand Up @@ -52,10 +52,6 @@ def admin?(user)
return administeredBy.any? {|u| u == user.id}
end

def invalidate_cache(cache_refresh_all = true)
self.class.all(invalidate_cache: true, include_views: true)
super(cache_refresh_all)
end

# ACL with administrators
def full_acl
Expand Down Expand Up @@ -108,7 +104,7 @@ def self.find_by(attrs, *args)
# Override to search for views as well by default
# Views get hidden on the REST service unless the `include_views`
# parameter is set to `true`
def find(id, params = {})
def self.find(id, params = {})
params[:include_views] = params[:include_views] || true
super(id, params)
end
Expand All @@ -119,6 +115,9 @@ def self.include_params
"acronym,administeredBy,group,hasDomain,name,notes,projects,reviews,summaryOnly,viewingRestriction"
end

def self.find_by_acronym(acronym, params = {})
[find(acronym, params)]
end
end
end
end
Expand Down
2 changes: 1 addition & 1 deletion lib/ontologies_api_client/read_write.rb
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ def invalidate_cache(cache_refresh_all = true)
HTTP.get(self.id, invalidate_cache: true) if self.id
session = Thread.current[:session]
session[:last_updated] = Time.now.to_f if session
refresh_cache
# refresh_cache
end

def refresh_cache
Expand Down

0 comments on commit ff69534

Please sign in to comment.