diff options
| author | chrislu <chris.lu@gmail.com> | 2023-02-07 14:45:20 -0800 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2023-02-07 14:45:20 -0800 |
| commit | 5de93fe4420b14ca63378cff0a5d2565920cb511 (patch) | |
| tree | e17a0ee155137744e04f1a4b664476d13f955f1e /weed/s3api | |
| parent | 5083429704ad77df6b24934461a849e55ec3386b (diff) | |
| download | seaweedfs-5de93fe4420b14ca63378cff0a5d2565920cb511.tar.xz seaweedfs-5de93fe4420b14ca63378cff0a5d2565920cb511.zip | |
refactoring
Diffstat (limited to 'weed/s3api')
| -rw-r--r-- | weed/s3api/s3bucket/s3api_bucket.go | 40 | ||||
| -rw-r--r-- | weed/s3api/s3bucket/s3api_bucket_test.go | 37 |
2 files changed, 77 insertions, 0 deletions
diff --git a/weed/s3api/s3bucket/s3api_bucket.go b/weed/s3api/s3bucket/s3api_bucket.go new file mode 100644 index 000000000..b14e8ed71 --- /dev/null +++ b/weed/s3api/s3bucket/s3api_bucket.go @@ -0,0 +1,40 @@ +package s3bucket + +import ( + "fmt" + "net" + "strings" + "unicode" +) + +// https://docs.aws.amazon.com/AmazonS3/latest/userguide/bucketnamingrules.html +func VerifyS3BucketName(name string) (err error) { + if len(name) < 3 || len(name) > 63 { + return fmt.Errorf("bucket name must between [3, 63] characters") + } + for idx, ch := range name { + if !(unicode.IsLower(ch) || ch == '.' || ch == '-' || unicode.IsNumber(ch)) { + return fmt.Errorf("bucket name can only contain lower case characters, numbers, dots, and hyphens") + } + if idx > 0 && (ch == '.' && name[idx-1] == '.') { + return fmt.Errorf("bucket names must not contain two adjacent periods") + } + //TODO buckets with s3 transfer accleration cannot have . in name + } + if name[0] == '.' || name[0] == '-' { + return fmt.Errorf("name must start with number or lower case character") + } + if name[len(name)-1] == '.' || name[len(name)-1] == '-' { + return fmt.Errorf("name must end with number or lower case character") + } + if strings.HasPrefix(name, "xn--") { + return fmt.Errorf("prefix xn-- is a reserved and not allowed in bucket prefix") + } + if strings.HasSuffix(name, "-s3alias") { + return fmt.Errorf("suffix -s3alias is a reserved and not allowed in bucket suffix") + } + if net.ParseIP(name) != nil { + return fmt.Errorf("bucket name cannot be ip addresses") + } + return nil +} diff --git a/weed/s3api/s3bucket/s3api_bucket_test.go b/weed/s3api/s3bucket/s3api_bucket_test.go new file mode 100644 index 000000000..b331a793a --- /dev/null +++ b/weed/s3api/s3bucket/s3api_bucket_test.go @@ -0,0 +1,37 @@ +package s3bucket + +import ( + "github.com/stretchr/testify/assert" + "testing" +) + +func Test_verifyBucketName(t *testing.T) { + invalidS3BucketNames := []string{ + "A9325325b", + "123.12.153.10", + "abc214..2", + "d", + ".ewfs3253543", + "grehtrry-", + "----------", + "x@fdsgr032", + } + for _, invalidName := range invalidS3BucketNames { + err := VerifyS3BucketName(invalidName) + assert.NotNil(t, err) + } + validS3BucketName := []string{ + "a9325325b", + "999.12.153.10", + "abc214.2", + "3d3d3d", + "ewfs3253543", + "grehtrry-a", + "0----------0", + "xafdsgr032", + } + for _, invalidName := range validS3BucketName { + err := VerifyS3BucketName(invalidName) + assert.Nil(t, err) + } +} |
