X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/061dc0bcb7ced7ad196c6cc71dd25aab59948e46..2935de4fbccf43b7daedb9412f2ada1bf65c52ab:/apps/workbench/app/models/arvados_resource_list.rb diff --git a/apps/workbench/app/models/arvados_resource_list.rb b/apps/workbench/app/models/arvados_resource_list.rb index 3842c97c37..1a3c6b7e3c 100644 --- a/apps/workbench/app/models/arvados_resource_list.rb +++ b/apps/workbench/app/models/arvados_resource_list.rb @@ -1,7 +1,8 @@ class ArvadosResourceList + include ArvadosApiClientHelper include Enumerable - def initialize(resource_class) + def initialize resource_class=nil @resource_class = resource_class end @@ -25,6 +26,23 @@ class ArvadosResourceList self end + def select(columns=nil) + # If no column arguments were given, invoke Enumerable#select. + if columns.nil? + super() + else + @select ||= [] + @select += columns + self + end + end + + def filter _filters + @filters ||= [] + @filters += _filters + self + end + def where(cond) cond = cond.dup cond.keys.each do |uuid_key| @@ -47,7 +65,7 @@ class ArvadosResourceList end cond.keys.select { |x| x.match /_kind$/ }.each do |kind_key| if cond[kind_key].is_a? Class - cond = cond.merge({ kind_key => 'arvados#' + $arvados_api_client.class_kind(cond[kind_key]) }) + cond = cond.merge({ kind_key => 'arvados#' + arvados_api_client.class_kind(cond[kind_key]) }) end end api_params = { @@ -57,9 +75,11 @@ class ArvadosResourceList api_params[:eager] = '1' if @eager api_params[:limit] = @limit if @limit api_params[:offset] = @offset if @offset + api_params[:select] = @select if @select api_params[:order] = @orderby_spec if @orderby_spec - res = $arvados_api_client.api @resource_class, '', api_params - @results = $arvados_api_client.unpack_api_response res + api_params[:filters] = @filters if @filters + res = arvados_api_client.api @resource_class, '', api_params + @results = arvados_api_client.unpack_api_response res self end @@ -68,6 +88,10 @@ class ArvadosResourceList @results end + def results=(r) + @results = r + end + def all where({}) end @@ -79,6 +103,12 @@ class ArvadosResourceList self end + def collect + results.collect do |m| + yield m + end + end + def first results.first end @@ -123,4 +153,38 @@ class ArvadosResourceList results.offset if results.respond_to? :offset end + def result_links + results.links if results.respond_to? :links + end + + # Return links provided with API response that point to the + # specified object, and have the specified link_class. If link_class + # is false or omitted, return all links pointing to the specified + # object. + def links_for item_or_uuid, link_class=false + return [] if !result_links + unless @links_for_uuid + @links_for_uuid = {} + result_links.each do |link| + if link.respond_to? :head_uuid + @links_for_uuid[link.head_uuid] ||= [] + @links_for_uuid[link.head_uuid] << link + end + end + end + if item_or_uuid.respond_to? :uuid + uuid = item_or_uuid.uuid + else + uuid = item_or_uuid + end + (@links_for_uuid[uuid] || []).select do |link| + link_class == false or link.link_class == link_class + end + end + + # Note: this arbitrarily chooses one of (possibly) multiple names. + def name_for item_or_uuid + links_for(item_or_uuid, 'name').first.andand.name + end + end