projects
/
arvados.git
/ blobdiff
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' of git.curoverse.com:arvados into 11876-r-sdk
[arvados.git]
/
services
/
api
/
app
/
controllers
/
arvados
/
v1
/
collections_controller.rb
diff --git
a/services/api/app/controllers/arvados/v1/collections_controller.rb
b/services/api/app/controllers/arvados/v1/collections_controller.rb
index 017c023db2ad1363fdd8549040bc402e17dce59f..3803d37691132782e927e6e32cbb5fbee80657c7 100644
(file)
--- a/
services/api/app/controllers/arvados/v1/collections_controller.rb
+++ b/
services/api/app/controllers/arvados/v1/collections_controller.rb
@@
-1,8
+1,21
@@
+# Copyright (C) The Arvados Authors. All rights reserved.
+#
+# SPDX-License-Identifier: AGPL-3.0
+
require "arvados/keep"
require "arvados/keep"
+require "trashable"
class Arvados::V1::CollectionsController < ApplicationController
class Arvados::V1::CollectionsController < ApplicationController
- def self.limit_index_columns_read
- ["manifest_text"]
+ include DbCurrentTime
+ include TrashableController
+
+ def self._index_requires_parameters
+ (super rescue {}).
+ merge({
+ include_trash: {
+ type: 'boolean', required: false, description: "Include collections whose is_trashed attribute is true."
+ },
+ })
end
def create
end
def create
@@
-13,6
+26,13
@@
class Arvados::V1::CollectionsController < ApplicationController
super
end
super
end
+ def find_objects_for_index
+ if params[:include_trash] || ['destroy', 'trash', 'untrash'].include?(action_name)
+ @objects = Collection.readable_by(*@read_users, {include_trash: true, query_on: Collection.unscoped})
+ end
+ super
+ end
+
def find_object_by_uuid
if loc = Keep::Locator.parse(params[:id])
loc.strip_hints!
def find_object_by_uuid
if loc = Keep::Locator.parse(params[:id])
loc.strip_hints!
@@
-23,20
+43,23
@@
class Arvados::V1::CollectionsController < ApplicationController
manifest_text: c.signed_manifest_text,
}
end
manifest_text: c.signed_manifest_text,
}
end
+ true
else
super
end
else
super
end
- true
end
def show
if @object.is_a? Collection
end
def show
if @object.is_a? Collection
+ # Omit unsigned_manifest_text
+ @select ||= model_class.selectable_attributes - ["unsigned_manifest_text"]
super
else
send_json @object
end
end
super
else
send_json @object
end
end
+
def find_collections(visited, sp, &b)
case sp
when ArvadosModel
def find_collections(visited, sp, &b)
case sp
when ArvadosModel
@@
-184,8
+207,8
@@
class Arvados::V1::CollectionsController < ApplicationController
def load_limit_offset_order_params *args
super
if action_name == 'index'
def load_limit_offset_order_params *args
super
if action_name == 'index'
- # Omit manifest_text from index results unless expressly selected.
- @select ||= model_class.selectable_attributes - ["manifest_text"]
+ # Omit manifest_text
and unsigned_manifest_text
from index results unless expressly selected.
+ @select ||= model_class.selectable_attributes - ["manifest_text"
, "unsigned_manifest_text"
]
end
end
end
end
end
end