X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/9f5d16ade2d95497ed9610eefd03d76fb15eb747..f107a5232d5e8788ae19daf1c5f6639f0c3cdb68:/apps/workbench/app/models/arvados_api_client.rb diff --git a/apps/workbench/app/models/arvados_api_client.rb b/apps/workbench/app/models/arvados_api_client.rb index 2f83a41152..d6e385fddc 100644 --- a/apps/workbench/app/models/arvados_api_client.rb +++ b/apps/workbench/app/models/arvados_api_client.rb @@ -9,7 +9,7 @@ class ArvadosApiClient @@client_mtx = Mutex.new @@api_client = nil - @@profiling_enabled = Rails.configuration.profiling_enabled rescue false + @@profiling_enabled = Rails.configuration.profiling_enabled def api(resources_kind, action, data=nil) profile_checkpoint @@ -90,7 +90,7 @@ class ArvadosApiClient resp end - def self.patch_paging_vars(ary, items_available, offset, limit) + def self.patch_paging_vars(ary, items_available, offset, limit, links=nil) if items_available (class << ary; self; end).class_eval { attr_accessor :items_available } ary.items_available = items_available @@ -102,14 +102,22 @@ class ArvadosApiClient if limit (class << ary; self; end).class_eval { attr_accessor :limit } ary.limit = limit - end + end + if links + (class << ary; self; end).class_eval { attr_accessor :links } + ary.links = links + end ary end def unpack_api_response(j, kind=nil) if j.is_a? Hash and j[:items].is_a? Array and j[:kind].match(/(_list|List)$/) - ary = j[:items].collect { |x| unpack_api_response x, j[:kind] } - ArvadosApiClient::patch_paging_vars(ary, j[:items_available], j[:offset], j[:limit]) + ary = j[:items].collect { |x| unpack_api_response x, x[:kind] } + links = ArvadosResourceList.new Link + links.results = (j[:links] || []).collect do |x| + unpack_api_response x, x[:kind] + end + self.class.patch_paging_vars(ary, j[:items_available], j[:offset], j[:limit], links) elsif j.is_a? Hash and (kind || j[:kind]) oclass = self.kind_class(kind || j[:kind]) if oclass