X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a59152e34814f453a7380e68a55534e2f8922d57..b31cc1c673b03aec2a77b81a6bfc1da676a9dc69:/apps/workbench/app/models/user.rb diff --git a/apps/workbench/app/models/user.rb b/apps/workbench/app/models/user.rb index 3c85c2d952..cc9b9bb058 100644 --- a/apps/workbench/app/models/user.rb +++ b/apps/workbench/app/models/user.rb @@ -1,6 +1,41 @@ -class User < OrvosBase +class User < ArvadosBase + def initialize(*args) + super(*args) + @attribute_sortkey['first_name'] = '050' + @attribute_sortkey['last_name'] = '051' + end + def self.current - res = $orvos_api_client.api self, '/current' - $orvos_api_client.unpack_api_response(res) + res = $arvados_api_client.api self, '/current' + $arvados_api_client.unpack_api_response(res) + end + + def self.system + $arvados_system_user ||= begin + res = $arvados_api_client.api self, '/system' + $arvados_api_client.unpack_api_response(res) + end + end + + def full_name + (self.first_name || "") + " " + (self.last_name || "") + end + + def activate + self.private_reload($arvados_api_client.api(self.class, + "/#{self.uuid}/activate", + {})) + end + + def attributes_for_display + super.reject { |k,v| %w(owner_uuid default_owner_uuid identity_url prefs).index k } + end + + def attribute_editable?(attr) + (not (self.uuid.andand.match(/000000000000000$/) and self.is_admin)) and super(attr) + end + + def friendly_link_name + [self.first_name, self.last_name].compact.join ' ' end end