X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a6439c7ddc3407193889386051f06df2a1e74ea9..6386f2aca83b477210bda19a3284ea31463d2efc:/apps/workbench/app/models/user.rb diff --git a/apps/workbench/app/models/user.rb b/apps/workbench/app/models/user.rb index c03e317f54..87ea5faefa 100644 --- a/apps/workbench/app/models/user.rb +++ b/apps/workbench/app/models/user.rb @@ -6,20 +6,15 @@ class User < ArvadosBase end def self.current - res = $arvados_api_client.api self, '/current' - $arvados_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 owned_items - res = $arvados_api_client.api self.class, "/#{self.uuid}/owned_items" - $arvados_api_client.unpack_api_response(res) + @@arvados_system_user ||= begin + res = arvados_api_client.api self, '/system' + arvados_api_client.unpack_api_response(res) + end end def full_name @@ -27,17 +22,21 @@ class User < ArvadosBase end def activate - self.private_reload($arvados_api_client.api(self.class, - "/#{self.uuid}/activate", - {})) + self.private_reload(arvados_api_client.api(self.class, + "/#{self.uuid}/activate", + {})) + end + + def contents params={} + Group.contents params.merge(uuid: self.uuid) 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) + def attribute_editable? attr, *args + (not (self.uuid.andand.match(/000000000000000$/) and self.is_admin)) and super end def friendly_link_name @@ -45,13 +44,19 @@ class User < ArvadosBase end def unsetup - self.private_reload($arvados_api_client.api(self.class, - "/#{self.uuid}/unsetup", - {})) + self.private_reload(arvados_api_client.api(self.class, + "/#{self.uuid}/unsetup", + {})) end def self.setup params - $arvados_api_client.api(self, "/setup", params) + arvados_api_client.api(self, "/setup", params) + end + + def update_profile params + self.private_reload(arvados_api_client.api(self.class, + "/#{self.uuid}/profile", + params)) end end