check.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package tos
  2. import (
  3. "github.com/volcengine/ve-tos-golang-sdk/v2/tos/enum"
  4. )
  5. func IsValidBucketName(name string) error {
  6. if length := len(name); length < 3 || length > 63 {
  7. return InvalidBucketNameLength
  8. }
  9. for i := range name {
  10. if char := name[i]; !(('a' <= char && char <= 'z') || ('0' <= char && char <= '9') || char == '-') {
  11. return InvalidBucketNameCharacter
  12. }
  13. }
  14. if name[0] == '-' || name[len(name)-1] == '-' {
  15. return InvalidBucketNameStartingOrEnding
  16. }
  17. return nil
  18. }
  19. // isValidBucketName validate bucket name, return TosClientError if failed
  20. func isValidBucketName(name string, isCustomDomain bool) error {
  21. if isCustomDomain {
  22. return nil
  23. }
  24. return IsValidBucketName(name)
  25. }
  26. // isValidNames validate bucket name and keys, return TosClientError if failed
  27. func isValidNames(bucket string, key string, isCustomDomain bool, keys ...string) error {
  28. if err := isValidBucketName(bucket, isCustomDomain); err != nil {
  29. return err
  30. }
  31. if err := isValidKey(key, keys...); err != nil {
  32. return err
  33. }
  34. return nil
  35. }
  36. // validKey validate single key, return TosClientError if failed
  37. func validKey(key string) error {
  38. if len(key) < 1 {
  39. return InvalidObjectNameLength
  40. }
  41. return nil
  42. }
  43. // isValidKey validate keys, return TosClientError if failed
  44. func isValidKey(key string, keys ...string) error {
  45. if err := validKey(key); err != nil {
  46. return err
  47. }
  48. for _, k := range keys {
  49. if err := validKey(k); err != nil {
  50. return err
  51. }
  52. }
  53. return nil
  54. }
  55. // isValidACL validate aclType, return TosClientError if failed
  56. func isValidACL(aclType enum.ACLType) error {
  57. if aclType == enum.ACLPrivate || aclType == enum.ACLPublicRead || aclType == enum.ACLPublicReadWrite ||
  58. aclType == enum.ACLAuthRead || aclType == enum.ACLBucketOwnerRead ||
  59. aclType == enum.ACLBucketOwnerFullControl || aclType == enum.ACLLogDeliveryWrite ||
  60. aclType == enum.ACLBucketOwnerEntrusted {
  61. return nil
  62. }
  63. return InvalidACL
  64. }
  65. // isValidStorageClass validate Storage Class, return TosClientError if failed
  66. func isValidStorageClass(storageClass enum.StorageClassType) error {
  67. if storageClass == enum.StorageClassIa || storageClass == enum.StorageClassStandard || storageClass == enum.StorageClassArchiveFr || storageClass == enum.StorageClassColdArchive || storageClass == enum.StorageClassIntelligentTiering {
  68. return nil
  69. }
  70. return InvalidStorageClass
  71. }
  72. func isValidGrantee(granteeType enum.GranteeType) error {
  73. if granteeType == enum.GranteeUser || granteeType == enum.GranteeGroup {
  74. return nil
  75. }
  76. return InvalidGrantee
  77. }
  78. func isValidCannedType(cannedType enum.CannedType) error {
  79. if cannedType == enum.CannedAllUsers || cannedType == enum.CannedAuthenticatedUsers {
  80. return nil
  81. }
  82. return InvalidCanned
  83. }
  84. func isValidAzRedundancy(redundancyType enum.AzRedundancyType) error {
  85. if redundancyType == enum.AzRedundancySingleAz || redundancyType == enum.AzRedundancyMultiAz {
  86. return nil
  87. }
  88. return InvalidAzRedundancy
  89. }
  90. func isValidMetadataDirective(directiveType enum.MetadataDirectiveType) error {
  91. if directiveType == enum.MetadataDirectiveCopy || directiveType == enum.MetadataDirectiveReplace {
  92. return nil
  93. }
  94. return InvalidMetadataDirective
  95. }
  96. func isValidPermission(permissionType enum.PermissionType) error {
  97. if permissionType == enum.PermissionRead || permissionType == enum.PermissionReadAcp ||
  98. permissionType == enum.PermissionWriteAcp || permissionType == enum.PermissionWrite ||
  99. permissionType == enum.PermissionFullControl {
  100. return nil
  101. }
  102. return InvalidPermission
  103. }
  104. func isValidSSECAlgorithm(algorithm string) error {
  105. if algorithm == enum.SSETosAlg || algorithm == enum.SSEKMS {
  106. return nil
  107. }
  108. return InvalidSSECAlgorithm
  109. }