1 module CurrentApiClient
7 Thread.current[:api_client]
10 def current_api_client_authorization
11 Thread.current[:api_client_authorization]
15 Thread.current[:api_url_base]
18 def current_default_owner
19 # owner_uuid for newly created objects
20 ((current_api_client_authorization &&
21 current_api_client_authorization.default_owner_uuid) ||
22 (current_user && current_user.default_owner_uuid) ||
23 (current_user && current_user.uuid) ||
27 # Where is the client connecting from?
28 def current_api_client_ip_address
29 Thread.current[:api_client_ip_address]
32 # Does the current API client authorization include any of ok_scopes?
33 def current_api_client_auth_has_scope(ok_scopes)
34 auth_scopes = current_api_client_authorization.andand.scopes || []
35 unless auth_scopes.index('all') or (auth_scopes & ok_scopes).any?
36 logger.warn "Insufficient auth scope: need #{ok_scopes}, #{current_api_client_authorization.inspect} has #{auth_scopes}"
43 [Server::Application.config.uuid_prefix,
45 '000000000000000'].join('-')
49 [Server::Application.config.uuid_prefix,
51 '000000000000000'].join('-')
56 real_current_user = Thread.current[:user]
57 Thread.current[:user] = User.new(is_admin: true, is_active: true)
58 $system_user = User.where('uuid=?', system_user_uuid).first
60 $system_user = User.new(uuid: system_user_uuid,
69 Thread.current[:user] = real_current_user
77 ActiveRecord::Base.transaction do
78 $system_group = Group.
79 where(uuid: system_group_uuid).first_or_create do |g|
80 g.update_attributes(name: "System group",
81 description: "System group")
82 User.all.collect(&:uuid).each do |user_uuid|
83 Link.create(link_class: 'permission',
85 tail_kind: 'arvados#group',
86 tail_uuid: system_group_uuid,
87 head_kind: 'arvados#user',
97 def act_as_system_user
99 user_was = Thread.current[:user]
100 Thread.current[:user] = system_user
102 Thread.current[:user] = user_was
105 Thread.current[:user] = system_user