info[:links] << link
end
@request_url = request.url
+
+ render_index
end
def show_file_links
end
def sharing_scopes
- ["GET /arvados/v1/collections/#{@object.uuid}", "GET /arvados/v1/keep_services"]
+ ["GET /arvados/v1/collections/#{@object.uuid}", "GET /arvados/v1/collections/#{@object.uuid}/", "GET /arvados/v1/keep_services/accessible"]
end
def search_scopes
- ApiClientAuthorization.where(filters: [['scopes', '=', sharing_scopes]])
+ begin
+ ApiClientAuthorization.filter([['scopes', '=', sharing_scopes]]).results
+ rescue ArvadosApiClient::AccessForbiddenException
+ nil
+ end
end
def show
end
@output_of = jobs_with.call(output: @object.uuid)
@log_of = jobs_with.call(log: @object.uuid)
- folder_links = Link.limit(RELATION_LIMIT).order("modified_at DESC")
+ @folder_links = Link.limit(RELATION_LIMIT).order("modified_at DESC")
.where(head_uuid: @object.uuid, link_class: 'name').results
- folder_hash = Group.where(uuid: folder_links.map(&:tail_uuid)).to_hash
- @folders = folder_links.map { |link| folder_hash[link.tail_uuid] }
+ folder_hash = Group.where(uuid: @folder_links.map(&:tail_uuid)).to_hash
+ @folders = @folder_links.map { |link| folder_hash[link.tail_uuid] }
@permissions = Link.limit(RELATION_LIMIT).order("modified_at DESC")
.where(head_uuid: @object.uuid, link_class: 'permission',
name: 'can_read').results
.where(head_uuid: @object.uuid, tail_uuid: current_user.uuid,
link_class: 'resources', name: 'wants')
.results.any?
- @search_sharing = search_scopes.select { |s| s.scopes != ['all'] }
+ @search_sharing = search_scopes
end
@prov_svg = ProvenanceHelper::create_provenance_graph(@object.provenance, "provenance_svg",
{:request => request,
:direction => :top_down,
:combine_jobs => :script_only,
:pdata_only => true}) rescue nil
+
+ super
end
def sharing_popup
- @search_sharing = search_scopes.select { |s| s.scopes != ['all'] }
+ @search_sharing = search_scopes
respond_to do |format|
format.html
format.js
end
end
+ helper_method :download_link
+
+ def download_link
+ collections_url + "/download/#{@object.uuid}/#{@search_sharing.first.api_token}"
+ end
+
def share
a = ApiClientAuthorization.create(scopes: sharing_scopes)
- @search_sharing = search_scopes.select { |s| s.scopes != ['all'] }
+ @search_sharing = search_scopes
render 'sharing_popup'
end
def unshare
- @search_sharing = search_scopes.select { |s| s.scopes != ['all'] }
+ @search_sharing = search_scopes
@search_sharing.each do |s|
s.destroy
end
- @search_sharing = search_scopes.select { |s| s.scopes != ['all'] }
+ @search_sharing = search_scopes
render 'sharing_popup'
end