include_trash: {
type: 'boolean', required: false, description: "Include collections whose is_trashed attribute is true."
},
+ include_old_versions: {
+ type: 'boolean', required: false, description: "Include past collection versions."
+ },
})
end
resource_attrs[:portable_data_hash] = loc.to_s
resource_attrs.delete :uuid
end
+ resource_attrs.delete :version
+ resource_attrs.delete :current_version_uuid
super
end
def find_objects_for_index
+ opts = {}
if params[:include_trash] || ['destroy', 'trash', 'untrash'].include?(action_name)
- @objects = Collection.unscoped.readable_by(*@read_users)
+ opts.update({include_trash: true})
+ end
+ if params[:include_old_versions] || @include_old_versions
+ opts.update({include_old_versions: true})
end
+ @objects = Collection.readable_by(*@read_users, opts) if !opts.empty?
super
end
def find_object_by_uuid
+ @include_old_versions = true
+
if loc = Keep::Locator.parse(params[:id])
loc.strip_hints!
- if c = Collection.readable_by(*@read_users).where({ portable_data_hash: loc.to_s }).limit(1).first
+
+ # It matters which Collection object we pick because we use it to get signed_manifest_text,
+ # the value of which is affected by the value of trash_at.
+ #
+ # From postgres doc: "By default, null values sort as if larger than any non-null
+ # value; that is, NULLS FIRST is the default for DESC order, and
+ # NULLS LAST otherwise."
+ #
+ # "trash_at desc" sorts null first, then latest to earliest, so
+ # it will select the Collection object with the longest
+ # available lifetime.
+
+ if c = Collection.readable_by(*@read_users).where({ portable_data_hash: loc.to_s }).order("trash_at desc").limit(1).first
@object = {
uuid: c.portable_data_hash,
portable_data_hash: c.portable_data_hash,
@select ||= model_class.selectable_attributes - ["manifest_text", "unsigned_manifest_text"]
end
end
+
+ def load_filters_param
+ super
+ return if !params[:include_old_versions]
+ @filters = @filters.map do |col, operator, operand|
+ # Replace uuid filters when including past versions
+ if col == 'uuid'
+ ['current_version_uuid', operator, operand]
+ else
+ [col, operator, operand]
+ end
+ end
+ end
end