X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/e98e77b844dc5a4d2dcfa0752f3bd6b74822d88c..f98e0188777b3e2d229c968824b3e64307dae4e6:/services/api/lib/current_api_client.rb diff --git a/services/api/lib/current_api_client.rb b/services/api/lib/current_api_client.rb index 197dcd8f3e..49638677b1 100644 --- a/services/api/lib/current_api_client.rb +++ b/services/api/lib/current_api_client.rb @@ -1,3 +1,15 @@ +# Copyright (C) The Arvados Authors. All rights reserved. +# +# SPDX-License-Identifier: AGPL-3.0 + +$system_user = nil +$system_group = nil +$all_users_group = nil +$anonymous_user = nil +$anonymous_group = nil +$anonymous_group_read_permission = nil +$empty_collection = nil + module CurrentApiClient def current_user Thread.current[:user] @@ -83,9 +95,7 @@ module CurrentApiClient User.all.collect(&:uuid).each do |user_uuid| Link.create!(link_class: 'permission', name: 'can_manage', - tail_kind: 'arvados#group', tail_uuid: system_group_uuid, - head_kind: 'arvados#user', head_uuid: user_uuid) end end @@ -146,6 +156,18 @@ module CurrentApiClient end end + def anonymous_group_read_permission + $anonymous_group_read_permission = + check_cache $anonymous_group_read_permission do + act_as_system_user do + Link.where(tail_uuid: all_users_group.uuid, + head_uuid: anonymous_group.uuid, + link_class: "permission", + name: "can_read").first_or_create! + end + end + end + def anonymous_user $anonymous_user = check_cache $anonymous_user do act_as_system_user do @@ -187,9 +209,24 @@ module CurrentApiClient # If the given value is nil, or the cache has been cleared since it # was set, yield. Otherwise, return the given value. def check_cache value - Rails.cache.fetch "CurrentApiClient.$globals" do - value = nil - true + if not Rails.env.test? and + ActionController::Base.cache_store.is_a? ActiveSupport::Cache::FileStore and + not File.owned? ActionController::Base.cache_store.cache_path + # If we don't own the cache dir, we're probably + # crunch-dispatch. Whoever we are, using this cache is likely to + # either fail or screw up the cache for someone else. So we'll + # just assume the $globals are OK to live forever. + # + # The reason for making the globals expire with the cache in the + # first place is to avoid leaking state between test cases: in + # production, we don't expect the database seeds to ever go away + # even when the cache is cleared, so there's no particular + # reason to expire our global variables. + else + Rails.cache.fetch "CurrentApiClient.$globals" do + value = nil + true + end end return value unless value.nil? yield