X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/8f1554cf9cfc279e0127d7ea2c7a79a98e323f13..5b5c9a43929d392f32f7a4db1393df2dd106cbeb:/apps/workbench/app/models/arvados_base.rb diff --git a/apps/workbench/app/models/arvados_base.rb b/apps/workbench/app/models/arvados_base.rb index e0e93b9e2d..f5be0e1edc 100644 --- a/apps/workbench/app/models/arvados_base.rb +++ b/apps/workbench/app/models/arvados_base.rb @@ -329,11 +329,20 @@ class ArvadosBase < ActiveRecord::Base (current_user.is_admin or current_user.uuid == self.owner_uuid or new_record? or - (writable_by.include? current_user.uuid rescue false))) or false + (respond_to?(:writable_by) ? + writable_by.include?(current_user.uuid) : + (ArvadosBase.find(owner_uuid).writable_by.include? current_user.uuid rescue false)))) or false + end + + # Array of strings that are the names of attributes that can be edited + # with X-Editable. + def editable_attributes + self.class.columns.map(&:name) - + %w(created_at modified_at modified_by_user_uuid modified_by_client_uuid updated_at) end def attribute_editable?(attr, ever=nil) - if %w(created_at modified_at modified_by_user_uuid modified_by_client_uuid updated_at).include? attr.to_s + if not editable_attributes.include?(attr.to_s) false elsif not (current_user.andand.is_active) false