Merge branch '2798-go-keep-client' into 1885-keep-proxy
[arvados.git] / apps / workbench / app / models / user.rb
1 class User < ArvadosBase
2   def initialize(*args)
3     super(*args)
4     @attribute_sortkey['first_name'] = '050'
5     @attribute_sortkey['last_name'] = '051'
6   end
7
8   def self.current
9     res = arvados_api_client.api self, '/current'
10     arvados_api_client.unpack_api_response(res)
11   end
12
13   def self.system
14     @@arvados_system_user ||= begin
15                                 res = arvados_api_client.api self, '/system'
16                                 arvados_api_client.unpack_api_response(res)
17                               end
18   end
19
20   def full_name
21     (self.first_name || "") + " " + (self.last_name || "")
22   end
23
24   def activate
25     self.private_reload(arvados_api_client.api(self.class,
26                                                "/#{self.uuid}/activate",
27                                                {}))
28   end
29
30   def attributes_for_display
31     super.reject { |k,v| %w(owner_uuid default_owner_uuid identity_url prefs).index k }
32   end
33
34  def attribute_editable?(attr)
35     (not (self.uuid.andand.match(/000000000000000$/) and self.is_admin)) and super(attr)
36   end
37
38   def friendly_link_name
39     [self.first_name, self.last_name].compact.join ' '
40   end
41
42   def unsetup
43     self.private_reload(arvados_api_client.api(self.class,
44                                                "/#{self.uuid}/unsetup",
45                                                {}))
46   end
47
48   def self.setup params
49     arvados_api_client.api(self, "/setup", params)
50   end
51
52 end