123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 |
- package s3api
- import (
- "reflect"
- "testing"
- . "github.com/seaweedfs/seaweedfs/weed/s3api/s3_constants"
- "github.com/stretchr/testify/assert"
- "github.com/seaweedfs/seaweedfs/weed/pb/iam_pb"
- jsonpb "google.golang.org/protobuf/encoding/protojson"
- )
- func TestIdentityListFileFormat(t *testing.T) {
- s3ApiConfiguration := &iam_pb.S3ApiConfiguration{}
- identity1 := &iam_pb.Identity{
- Name: "some_name",
- Credentials: []*iam_pb.Credential{
- {
- AccessKey: "some_access_key1",
- SecretKey: "some_secret_key2",
- },
- },
- Actions: []string{
- ACTION_ADMIN,
- ACTION_READ,
- ACTION_WRITE,
- },
- }
- identity2 := &iam_pb.Identity{
- Name: "some_read_only_user",
- Credentials: []*iam_pb.Credential{
- {
- AccessKey: "some_access_key1",
- SecretKey: "some_secret_key1",
- },
- },
- Actions: []string{
- ACTION_READ,
- },
- }
- identity3 := &iam_pb.Identity{
- Name: "some_normal_user",
- Credentials: []*iam_pb.Credential{
- {
- AccessKey: "some_access_key2",
- SecretKey: "some_secret_key2",
- },
- },
- Actions: []string{
- ACTION_READ,
- ACTION_WRITE,
- },
- }
- s3ApiConfiguration.Identities = append(s3ApiConfiguration.Identities, identity1)
- s3ApiConfiguration.Identities = append(s3ApiConfiguration.Identities, identity2)
- s3ApiConfiguration.Identities = append(s3ApiConfiguration.Identities, identity3)
- m := jsonpb.MarshalOptions{
- EmitUnpopulated: true,
- Indent: " ",
- }
- text, _ := m.Marshal(s3ApiConfiguration)
- println(string(text))
- }
- func TestCanDo(t *testing.T) {
- ident1 := &Identity{
- Name: "anything",
- Actions: []Action{
- "Write:bucket1/a/b/c/*",
- "Write:bucket1/a/b/other",
- },
- }
- // object specific
- assert.Equal(t, true, ident1.canDo(ACTION_WRITE, "bucket1", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident1.canDo(ACTION_WRITE, "bucket1", "/a/b/c/d/e.txt"))
- assert.Equal(t, false, ident1.canDo(ACTION_DELETE_BUCKET, "bucket1", ""))
- assert.Equal(t, false, ident1.canDo(ACTION_WRITE, "bucket1", "/a/b/other/some"), "action without *")
- assert.Equal(t, false, ident1.canDo(ACTION_WRITE, "bucket1", "/a/b/*"), "action on parent directory")
- // bucket specific
- ident2 := &Identity{
- Name: "anything",
- Actions: []Action{
- "Read:bucket1",
- "Write:bucket1/*",
- "WriteAcp:bucket1",
- },
- }
- assert.Equal(t, true, ident2.canDo(ACTION_READ, "bucket1", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident2.canDo(ACTION_WRITE, "bucket1", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident2.canDo(ACTION_WRITE_ACP, "bucket1", ""))
- assert.Equal(t, false, ident2.canDo(ACTION_READ_ACP, "bucket1", ""))
- assert.Equal(t, false, ident2.canDo(ACTION_LIST, "bucket1", "/a/b/c/d.txt"))
- // across buckets
- ident3 := &Identity{
- Name: "anything",
- Actions: []Action{
- "Read",
- "Write",
- },
- }
- assert.Equal(t, true, ident3.canDo(ACTION_READ, "bucket1", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident3.canDo(ACTION_WRITE, "bucket1", "/a/b/c/d.txt"))
- assert.Equal(t, false, ident3.canDo(ACTION_LIST, "bucket1", "/a/b/other/some"))
- assert.Equal(t, false, ident3.canDo(ACTION_WRITE_ACP, "bucket1", ""))
- // partial buckets
- ident4 := &Identity{
- Name: "anything",
- Actions: []Action{
- "Read:special_*",
- "ReadAcp:special_*",
- },
- }
- assert.Equal(t, true, ident4.canDo(ACTION_READ, "special_bucket", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident4.canDo(ACTION_READ_ACP, "special_bucket", ""))
- assert.Equal(t, false, ident4.canDo(ACTION_READ, "bucket1", "/a/b/c/d.txt"))
- // admin buckets
- ident5 := &Identity{
- Name: "anything",
- Actions: []Action{
- "Admin:special_*",
- },
- }
- assert.Equal(t, true, ident5.canDo(ACTION_READ, "special_bucket", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident5.canDo(ACTION_READ_ACP, "special_bucket", ""))
- assert.Equal(t, true, ident5.canDo(ACTION_WRITE, "special_bucket", "/a/b/c/d.txt"))
- assert.Equal(t, true, ident5.canDo(ACTION_WRITE_ACP, "special_bucket", ""))
- // anonymous buckets
- ident6 := &Identity{
- Name: "anonymous",
- Actions: []Action{
- "Read",
- },
- }
- assert.Equal(t, true, ident6.canDo(ACTION_READ, "anything_bucket", "/a/b/c/d.txt"))
- //test deleteBucket operation
- ident7 := &Identity{
- Name: "anything",
- Actions: []Action{
- "DeleteBucket:bucket1",
- },
- }
- assert.Equal(t, true, ident7.canDo(ACTION_DELETE_BUCKET, "bucket1", ""))
- }
- type LoadS3ApiConfigurationTestCase struct {
- pbAccount *iam_pb.Account
- pbIdent *iam_pb.Identity
- expectIdent *Identity
- }
- func TestLoadS3ApiConfiguration(t *testing.T) {
- specifiedAccount := Account{
- Id: "specifiedAccountID",
- DisplayName: "specifiedAccountName",
- EmailAddress: "specifiedAccounEmail@example.com",
- }
- pbSpecifiedAccount := iam_pb.Account{
- Id: "specifiedAccountID",
- DisplayName: "specifiedAccountName",
- EmailAddress: "specifiedAccounEmail@example.com",
- }
- testCases := map[string]*LoadS3ApiConfigurationTestCase{
- "notSpecifyAccountId": {
- pbIdent: &iam_pb.Identity{
- Name: "notSpecifyAccountId",
- Actions: []string{
- "Read",
- "Write",
- },
- Credentials: []*iam_pb.Credential{
- {
- AccessKey: "some_access_key1",
- SecretKey: "some_secret_key2",
- },
- },
- },
- expectIdent: &Identity{
- Name: "notSpecifyAccountId",
- Account: &AccountAdmin,
- Actions: []Action{
- "Read",
- "Write",
- },
- Credentials: []*Credential{
- {
- AccessKey: "some_access_key1",
- SecretKey: "some_secret_key2",
- },
- },
- },
- },
- "specifiedAccountID": {
- pbAccount: &pbSpecifiedAccount,
- pbIdent: &iam_pb.Identity{
- Name: "specifiedAccountID",
- Account: &pbSpecifiedAccount,
- Actions: []string{
- "Read",
- "Write",
- },
- },
- expectIdent: &Identity{
- Name: "specifiedAccountID",
- Account: &specifiedAccount,
- Actions: []Action{
- "Read",
- "Write",
- },
- },
- },
- "anonymous": {
- pbIdent: &iam_pb.Identity{
- Name: "anonymous",
- Actions: []string{
- "Read",
- "Write",
- },
- },
- expectIdent: &Identity{
- Name: "anonymous",
- Account: &AccountAnonymous,
- Actions: []Action{
- "Read",
- "Write",
- },
- },
- },
- }
- config := &iam_pb.S3ApiConfiguration{
- Identities: make([]*iam_pb.Identity, 0),
- }
- for _, v := range testCases {
- config.Identities = append(config.Identities, v.pbIdent)
- if v.pbAccount != nil {
- config.Accounts = append(config.Accounts, v.pbAccount)
- }
- }
- iam := IdentityAccessManagement{}
- err := iam.loadS3ApiConfiguration(config)
- if err != nil {
- return
- }
- for _, ident := range iam.identities {
- tc := testCases[ident.Name]
- if !reflect.DeepEqual(ident, tc.expectIdent) {
- t.Errorf("not expect for ident name %s", ident.Name)
- }
- }
- }
|