mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
Move lock to not surround pieces which don't use any internal members. (#7779)
Previously the read/write lock applied both for gateway use cases as well the object store use case. Nothing from sys is touched or looked at in the gateway usecase though, so we don't need to lock. Don't lock to make the gateway policy getting a little more efficient, particularly as where this is called from (checkRequestAuthType) is quite common.
This commit is contained in:
parent
510ec153b9
commit
7b8beecc81
@ -85,9 +85,6 @@ func (sys *PolicySys) Remove(bucketName string) {
|
|||||||
|
|
||||||
// IsAllowed - checks given policy args is allowed to continue the Rest API.
|
// IsAllowed - checks given policy args is allowed to continue the Rest API.
|
||||||
func (sys *PolicySys) IsAllowed(args policy.Args) bool {
|
func (sys *PolicySys) IsAllowed(args policy.Args) bool {
|
||||||
sys.RLock()
|
|
||||||
defer sys.RUnlock()
|
|
||||||
|
|
||||||
if globalIsGateway {
|
if globalIsGateway {
|
||||||
// When gateway is enabled, no cached value
|
// When gateway is enabled, no cached value
|
||||||
// is used to validate bucket policies.
|
// is used to validate bucket policies.
|
||||||
@ -99,6 +96,9 @@ func (sys *PolicySys) IsAllowed(args policy.Args) bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
sys.RLock()
|
||||||
|
defer sys.RUnlock()
|
||||||
|
|
||||||
// If policy is available for given bucket, check the policy.
|
// If policy is available for given bucket, check the policy.
|
||||||
if p, found := sys.bucketPolicyMap[args.BucketName]; found {
|
if p, found := sys.bucketPolicyMap[args.BucketName]; found {
|
||||||
return p.IsAllowed(args)
|
return p.IsAllowed(args)
|
||||||
|
Loading…
Reference in New Issue
Block a user