|
@ -5,6 +5,7 @@ import ( |
|
|
"net/http" |
|
|
"net/http" |
|
|
"os" |
|
|
"os" |
|
|
"strings" |
|
|
"strings" |
|
|
|
|
|
"sync" |
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/filer" |
|
|
"github.com/chrislusf/seaweedfs/weed/filer" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
@ -23,6 +24,8 @@ type Iam interface { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type IdentityAccessManagement struct { |
|
|
type IdentityAccessManagement struct { |
|
|
|
|
|
m sync.RWMutex |
|
|
|
|
|
|
|
|
identities []*Identity |
|
|
identities []*Identity |
|
|
domain string |
|
|
domain string |
|
|
} |
|
|
} |
|
@ -131,19 +134,23 @@ func (iam *IdentityAccessManagement) loadS3ApiConfiguration(config *iam_pb.S3Api |
|
|
} |
|
|
} |
|
|
identities = append(identities, t) |
|
|
identities = append(identities, t) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
iam.m.Lock() |
|
|
// atomically switch
|
|
|
// atomically switch
|
|
|
iam.identities = identities |
|
|
iam.identities = identities |
|
|
|
|
|
iam.m.Unlock() |
|
|
return nil |
|
|
return nil |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (iam *IdentityAccessManagement) isEnabled() bool { |
|
|
func (iam *IdentityAccessManagement) isEnabled() bool { |
|
|
|
|
|
|
|
|
|
|
|
iam.m.RLock() |
|
|
|
|
|
defer iam.m.RUnlock() |
|
|
return len(iam.identities) > 0 |
|
|
return len(iam.identities) > 0 |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (iam *IdentityAccessManagement) lookupByAccessKey(accessKey string) (identity *Identity, cred *Credential, found bool) { |
|
|
func (iam *IdentityAccessManagement) lookupByAccessKey(accessKey string) (identity *Identity, cred *Credential, found bool) { |
|
|
|
|
|
|
|
|
|
|
|
iam.m.RLock() |
|
|
|
|
|
defer iam.m.RUnlock() |
|
|
for _, ident := range iam.identities { |
|
|
for _, ident := range iam.identities { |
|
|
for _, cred := range ident.Credentials { |
|
|
for _, cred := range ident.Credentials { |
|
|
// println("checking", ident.Name, cred.AccessKey)
|
|
|
// println("checking", ident.Name, cred.AccessKey)
|
|
@ -157,7 +164,8 @@ func (iam *IdentityAccessManagement) lookupByAccessKey(accessKey string) (identi |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (iam *IdentityAccessManagement) lookupAnonymous() (identity *Identity, found bool) { |
|
|
func (iam *IdentityAccessManagement) lookupAnonymous() (identity *Identity, found bool) { |
|
|
|
|
|
|
|
|
|
|
|
iam.m.RLock() |
|
|
|
|
|
defer iam.m.RUnlock() |
|
|
for _, ident := range iam.identities { |
|
|
for _, ident := range iam.identities { |
|
|
if ident.Name == "anonymous" { |
|
|
if ident.Name == "anonymous" { |
|
|
return ident, true |
|
|
return ident, true |
|
|