diff --git a/CHANGELOG.md b/CHANGELOG.md index cec578a30..a0e7c0585 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -45,6 +45,7 @@ This document outlines major changes between releases. - Complete multipart upload doesn't unnecessary copy now. Thus, the total time of multipart upload was reduced by 2 times (#63) - Use gate key to form object owner (#175) - Apply placement policies and copies if there is at least one valid value (#168) +- Generalise config param `use_default_xmlns_for_complete_multipart` to `use_default_xmlns` so that use default xmlns for all requests (#221) ### Removed - Drop `tree.service` param (now endpoints from `peers` section are used) (#133) diff --git a/api/data/notifications.go b/api/data/notifications.go index c2710d205..0a894e5b8 100644 --- a/api/data/notifications.go +++ b/api/data/notifications.go @@ -1,7 +1,10 @@ package data +import "encoding/xml" + type ( NotificationConfiguration struct { + XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ NotificationConfiguration" json:"-"` QueueConfigurations []QueueConfiguration `xml:"QueueConfiguration" json:"QueueConfigurations"` // Not supported topics TopicConfigurations []TopicConfiguration `xml:"TopicConfiguration" json:"TopicConfigurations"` diff --git a/api/handler/acl.go b/api/handler/acl.go index 37be4dd03..047229900 100644 --- a/api/handler/acl.go +++ b/api/handler/acl.go @@ -6,7 +6,6 @@ import ( "crypto/elliptic" "encoding/hex" "encoding/json" - "encoding/xml" stderrors "errors" "fmt" "net/http" @@ -304,7 +303,7 @@ func (h *handler) PutBucketACLHandler(w http.ResponseWriter, r *http.Request) { h.logAndSendError(w, "could not parse bucket acl", reqInfo, err) return } - } else if err = xml.NewDecoder(r.Body).Decode(list); err != nil { + } else if err = h.cfg.NewXMLDecoder(r.Body).Decode(list); err != nil { h.logAndSendError(w, "could not parse bucket acl", reqInfo, errors.GetAPIError(errors.ErrMalformedXML)) return } @@ -441,7 +440,7 @@ func (h *handler) PutObjectACLHandler(w http.ResponseWriter, r *http.Request) { h.logAndSendError(w, "could not parse bucket acl", reqInfo, err) return } - } else if err = xml.NewDecoder(r.Body).Decode(list); err != nil { + } else if err = h.cfg.NewXMLDecoder(r.Body).Decode(list); err != nil { h.logAndSendError(w, "could not parse bucket acl", reqInfo, errors.GetAPIError(errors.ErrMalformedXML)) return } diff --git a/api/handler/api.go b/api/handler/api.go index 4835cabf1..12be43406 100644 --- a/api/handler/api.go +++ b/api/handler/api.go @@ -35,7 +35,7 @@ type ( PlacementPolicy(string) (netmap.PlacementPolicy, bool) CopiesNumbers(string) ([]uint32, bool) DefaultCopiesNumbers() []uint32 - NewCompleteMultipartDecoder(io.Reader) *xml.Decoder + NewXMLDecoder(io.Reader) *xml.Decoder DefaultMaxAge() int NotificatorEnabled() bool ResolveZoneList() []string diff --git a/api/handler/cors.go b/api/handler/cors.go index 7a623b25b..4de3b5a70 100644 --- a/api/handler/cors.go +++ b/api/handler/cors.go @@ -50,8 +50,9 @@ func (h *handler) PutBucketCorsHandler(w http.ResponseWriter, r *http.Request) { } p := &layer.PutCORSParams{ - BktInfo: bktInfo, - Reader: r.Body, + BktInfo: bktInfo, + Reader: r.Body, + NewDecoder: h.cfg.NewXMLDecoder, } p.CopiesNumbers, err = h.pickCopiesNumbers(parseMetadata(r), bktInfo.LocationConstraint) diff --git a/api/handler/delete.go b/api/handler/delete.go index 51a5dff66..3224e6ec0 100644 --- a/api/handler/delete.go +++ b/api/handler/delete.go @@ -24,8 +24,9 @@ const maxObjectsToDelete = 1000 // DeleteObjectsRequest -- xml carrying the object key names which should be deleted. type DeleteObjectsRequest struct { + XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ Delete" json:"-"` // Element to enable quiet mode for the request - Quiet bool + Quiet bool `xml:"Quiet,omitempty"` // List of objects to be deleted Objects []ObjectIdentifier `xml:"Object"` } @@ -177,7 +178,7 @@ func (h *handler) DeleteMultipleObjectsHandler(w http.ResponseWriter, r *http.Re // Unmarshal list of keys to be deleted. requested := &DeleteObjectsRequest{} - if err := xml.NewDecoder(r.Body).Decode(requested); err != nil { + if err := h.cfg.NewXMLDecoder(r.Body).Decode(requested); err != nil { h.logAndSendError(w, "couldn't decode body", reqInfo, errors.GetAPIError(errors.ErrMalformedXML)) return } diff --git a/api/handler/handlers_test.go b/api/handler/handlers_test.go index b8c5227b2..14f63d7a7 100644 --- a/api/handler/handlers_test.go +++ b/api/handler/handlers_test.go @@ -82,7 +82,7 @@ func (c *configMock) DefaultCopiesNumbers() []uint32 { return c.defaultCopiesNumbers } -func (c *configMock) NewCompleteMultipartDecoder(r io.Reader) *xml.Decoder { +func (c *configMock) NewXMLDecoder(r io.Reader) *xml.Decoder { return xml.NewDecoder(r) } diff --git a/api/handler/locking.go b/api/handler/locking.go index d82918788..ba062d4ff 100644 --- a/api/handler/locking.go +++ b/api/handler/locking.go @@ -2,7 +2,6 @@ package handler import ( "context" - "encoding/xml" "fmt" "net/http" "strconv" @@ -42,7 +41,7 @@ func (h *handler) PutBucketObjectLockConfigHandler(w http.ResponseWriter, r *htt } lockingConf := &data.ObjectLockConfiguration{} - if err = xml.NewDecoder(r.Body).Decode(lockingConf); err != nil { + if err = h.cfg.NewXMLDecoder(r.Body).Decode(lockingConf); err != nil { h.logAndSendError(w, "couldn't parse locking configuration", reqInfo, err) return } @@ -122,7 +121,7 @@ func (h *handler) PutObjectLegalHoldHandler(w http.ResponseWriter, r *http.Reque } legalHold := &data.LegalHold{} - if err = xml.NewDecoder(r.Body).Decode(legalHold); err != nil { + if err = h.cfg.NewXMLDecoder(r.Body).Decode(legalHold); err != nil { h.logAndSendError(w, "couldn't parse legal hold configuration", reqInfo, err) return } @@ -210,7 +209,7 @@ func (h *handler) PutObjectRetentionHandler(w http.ResponseWriter, r *http.Reque } retention := &data.Retention{} - if err = xml.NewDecoder(r.Body).Decode(retention); err != nil { + if err = h.cfg.NewXMLDecoder(r.Body).Decode(retention); err != nil { h.logAndSendError(w, "couldn't parse object retention", reqInfo, err) return } diff --git a/api/handler/multipart_upload.go b/api/handler/multipart_upload.go index ce237bc34..b86941705 100644 --- a/api/handler/multipart_upload.go +++ b/api/handler/multipart_upload.go @@ -406,7 +406,7 @@ func (h *handler) CompleteMultipartUploadHandler(w http.ResponseWriter, r *http. ) reqBody := new(CompleteMultipartUpload) - if err = h.cfg.NewCompleteMultipartDecoder(r.Body).Decode(reqBody); err != nil { + if err = h.cfg.NewXMLDecoder(r.Body).Decode(reqBody); err != nil { h.logAndSendError(w, "could not read complete multipart upload xml", reqInfo, errors.GetAPIError(errors.ErrMalformedXML), additional...) return diff --git a/api/handler/notifications.go b/api/handler/notifications.go index e0e7b49de..fbd59988f 100644 --- a/api/handler/notifications.go +++ b/api/handler/notifications.go @@ -2,7 +2,6 @@ package handler import ( "context" - "encoding/xml" "fmt" "net/http" "strings" @@ -26,11 +25,6 @@ type ( User string Time time.Time } - - NotificationConfiguration struct { - XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ NotificationConfiguation"` - NotificationConfiguration data.NotificationConfiguration - } ) const ( @@ -105,7 +99,7 @@ func (h *handler) PutBucketNotificationHandler(w http.ResponseWriter, r *http.Re } conf := &data.NotificationConfiguration{} - if err = xml.NewDecoder(r.Body).Decode(conf); err != nil { + if err = h.cfg.NewXMLDecoder(r.Body).Decode(conf); err != nil { h.logAndSendError(w, "couldn't decode notification configuration", reqInfo, errors.GetAPIError(errors.ErrMalformedXML)) return } diff --git a/api/handler/put.go b/api/handler/put.go index ae3f804dc..9262d0d24 100644 --- a/api/handler/put.go +++ b/api/handler/put.go @@ -433,7 +433,7 @@ func (h *handler) PostObject(w http.ResponseWriter, r *http.Request) { if tagging := auth.MultipartFormValue(r, "tagging"); tagging != "" { buffer := bytes.NewBufferString(tagging) - tagSet, err = readTagSet(buffer) + tagSet, err = h.readTagSet(buffer) if err != nil { h.logAndSendError(w, "could not read tag set", reqInfo, err) return @@ -742,7 +742,7 @@ func (h *handler) CreateBucketHandler(w http.ResponseWriter, r *http.Request) { return } - createParams, err := parseLocationConstraint(r) + createParams, err := h.parseLocationConstraint(r) if err != nil { h.logAndSendError(w, "could not parse body", reqInfo, err) return @@ -859,13 +859,13 @@ func isAlphaNum(char int32) bool { return 'a' <= char && char <= 'z' || '0' <= char && char <= '9' } -func parseLocationConstraint(r *http.Request) (*createBucketParams, error) { +func (h *handler) parseLocationConstraint(r *http.Request) (*createBucketParams, error) { if r.ContentLength == 0 { return new(createBucketParams), nil } params := new(createBucketParams) - if err := xml.NewDecoder(r.Body).Decode(params); err != nil { + if err := h.cfg.NewXMLDecoder(r.Body).Decode(params); err != nil { return nil, errors.GetAPIError(errors.ErrMalformedXML) } return params, nil diff --git a/api/handler/tagging.go b/api/handler/tagging.go index 306d8c154..bd56451d1 100644 --- a/api/handler/tagging.go +++ b/api/handler/tagging.go @@ -1,7 +1,6 @@ package handler import ( - "encoding/xml" "io" "net/http" "sort" @@ -29,7 +28,7 @@ func (h *handler) PutObjectTaggingHandler(w http.ResponseWriter, r *http.Request ctx := r.Context() reqInfo := middleware.GetReqInfo(ctx) - tagSet, err := readTagSet(r.Body) + tagSet, err := h.readTagSet(r.Body) if err != nil { h.logAndSendError(w, "could not read tag set", reqInfo, err) return @@ -153,7 +152,7 @@ func (h *handler) DeleteObjectTaggingHandler(w http.ResponseWriter, r *http.Requ func (h *handler) PutBucketTaggingHandler(w http.ResponseWriter, r *http.Request) { reqInfo := middleware.GetReqInfo(r.Context()) - tagSet, err := readTagSet(r.Body) + tagSet, err := h.readTagSet(r.Body) if err != nil { h.logAndSendError(w, "could not read tag set", reqInfo, err) return @@ -208,9 +207,9 @@ func (h *handler) DeleteBucketTaggingHandler(w http.ResponseWriter, r *http.Requ w.WriteHeader(http.StatusNoContent) } -func readTagSet(reader io.Reader) (map[string]string, error) { +func (h *handler) readTagSet(reader io.Reader) (map[string]string, error) { tagging := new(Tagging) - if err := xml.NewDecoder(reader).Decode(tagging); err != nil { + if err := h.cfg.NewXMLDecoder(reader).Decode(tagging); err != nil { return nil, errors.GetAPIError(errors.ErrMalformedXML) } diff --git a/api/handler/versioning.go b/api/handler/versioning.go index 36965eb69..7e61bf86d 100644 --- a/api/handler/versioning.go +++ b/api/handler/versioning.go @@ -1,7 +1,6 @@ package handler import ( - "encoding/xml" "net/http" "git.frostfs.info/TrueCloudLab/frostfs-s3-gw/api/data" @@ -14,7 +13,7 @@ func (h *handler) PutBucketVersioningHandler(w http.ResponseWriter, r *http.Requ reqInfo := middleware.GetReqInfo(r.Context()) configuration := new(VersioningConfiguration) - if err := xml.NewDecoder(r.Body).Decode(configuration); err != nil { + if err := h.cfg.NewXMLDecoder(r.Body).Decode(configuration); err != nil { h.logAndSendError(w, "couldn't decode versioning configuration", reqInfo, errors.GetAPIError(errors.ErrIllegalVersioningConfigurationException)) return } diff --git a/api/layer/cors.go b/api/layer/cors.go index 180f6019e..10f4177e7 100644 --- a/api/layer/cors.go +++ b/api/layer/cors.go @@ -3,7 +3,6 @@ package layer import ( "bytes" "context" - "encoding/xml" errorsStd "errors" "fmt" "io" @@ -25,7 +24,7 @@ func (n *layer) PutBucketCORS(ctx context.Context, p *PutCORSParams) error { cors = &data.CORSConfiguration{} ) - if err := xml.NewDecoder(tee).Decode(cors); err != nil { + if err := p.NewDecoder(tee).Decode(cors); err != nil { return fmt.Errorf("xml decode cors: %w", err) } diff --git a/api/layer/layer.go b/api/layer/layer.go index c94e4d650..799a6f0c8 100644 --- a/api/layer/layer.go +++ b/api/layer/layer.go @@ -4,6 +4,7 @@ import ( "context" "crypto/ecdsa" "crypto/rand" + "encoding/xml" "fmt" "io" "net/url" @@ -146,6 +147,7 @@ type ( BktInfo *data.BucketInfo Reader io.Reader CopiesNumbers []uint32 + NewDecoder func(io.Reader) *xml.Decoder } // CopyObjectParams stores object copy request parameters. diff --git a/cmd/s3-gw/app.go b/cmd/s3-gw/app.go index adece9221..1e31248a7 100644 --- a/cmd/s3-gw/app.go +++ b/cmd/s3-gw/app.go @@ -77,15 +77,15 @@ type ( isResolveListAllow bool // True if ResolveZoneList contains allowed zones completeMultipartKeepalive time.Duration - mu sync.RWMutex - defaultPolicy netmap.PlacementPolicy - regionMap map[string]netmap.PlacementPolicy - copiesNumbers map[string][]uint32 - defaultCopiesNumbers []uint32 - defaultXMLNSForCompleteMultipart bool - bypassContentEncodingInChunks bool - clientCut bool - maxBufferSizeForPut uint64 + mu sync.RWMutex + defaultPolicy netmap.PlacementPolicy + regionMap map[string]netmap.PlacementPolicy + copiesNumbers map[string][]uint32 + defaultCopiesNumbers []uint32 + defaultXMLNS bool + bypassContentEncodingInChunks bool + clientCut bool + maxBufferSizeForPut uint64 } maxClientsConfig struct { @@ -173,12 +173,12 @@ func (a *App) initLayer(ctx context.Context) { func newAppSettings(log *Logger, v *viper.Viper) *appSettings { settings := &appSettings{ - logLevel: log.lvl, - maxClient: newMaxClients(v), - defaultXMLNSForCompleteMultipart: v.GetBool(cfgKludgeUseDefaultXMLNSForCompleteMultipartUpload), - defaultMaxAge: fetchDefaultMaxAge(v, log.logger), - notificatorEnabled: v.GetBool(cfgEnableNATS), - completeMultipartKeepalive: v.GetDuration(cfgKludgeCompleteMultipartUploadKeepalive), + logLevel: log.lvl, + maxClient: newMaxClients(v), + defaultXMLNS: v.GetBool(cfgKludgeUseDefaultXMLNS), + defaultMaxAge: fetchDefaultMaxAge(v, log.logger), + notificatorEnabled: v.GetBool(cfgEnableNATS), + completeMultipartKeepalive: v.GetDuration(cfgKludgeCompleteMultipartUploadKeepalive), } settings.resolveZoneList = v.GetStringSlice(cfgResolveBucketAllow) @@ -274,11 +274,11 @@ func (s *appSettings) DefaultCopiesNumbers() []uint32 { return s.defaultCopiesNumbers } -func (s *appSettings) NewCompleteMultipartDecoder(r io.Reader) *xml.Decoder { +func (s *appSettings) NewXMLDecoder(r io.Reader) *xml.Decoder { dec := xml.NewDecoder(r) s.mu.RLock() - if s.defaultXMLNSForCompleteMultipart { + if s.defaultXMLNS { dec.DefaultSpace = awsDefaultNamespace } s.mu.RUnlock() @@ -286,9 +286,9 @@ func (s *appSettings) NewCompleteMultipartDecoder(r io.Reader) *xml.Decoder { return dec } -func (s *appSettings) useDefaultNamespaceForCompleteMultipart(useDefaultNamespace bool) { +func (s *appSettings) useDefaultXMLNamespace(useDefaultNamespace bool) { s.mu.Lock() - s.defaultXMLNSForCompleteMultipart = useDefaultNamespace + s.defaultXMLNS = useDefaultNamespace s.mu.Unlock() } @@ -600,7 +600,7 @@ func (a *App) updateSettings() { a.settings.initPlacementPolicy(a.log, a.cfg) - a.settings.useDefaultNamespaceForCompleteMultipart(a.cfg.GetBool(cfgKludgeUseDefaultXMLNSForCompleteMultipartUpload)) + a.settings.useDefaultXMLNamespace(a.cfg.GetBool(cfgKludgeUseDefaultXMLNS)) a.settings.setBypassContentEncodingInChunks(a.cfg.GetBool(cfgKludgeBypassContentEncodingCheckInChunks)) a.settings.setClientCut(a.cfg.GetBool(cfgClientCut)) a.settings.setBufferMaxSizeForPut(a.cfg.GetUint64(cfgBufferMaxSizeForPut)) diff --git a/cmd/s3-gw/app_settings.go b/cmd/s3-gw/app_settings.go index 6034598b5..433e0c1ba 100644 --- a/cmd/s3-gw/app_settings.go +++ b/cmd/s3-gw/app_settings.go @@ -130,9 +130,9 @@ const ( // Settings. cfgApplicationBuildTime = "app.build_time" // Kludge. - cfgKludgeUseDefaultXMLNSForCompleteMultipartUpload = "kludge.use_default_xmlns_for_complete_multipart" - cfgKludgeCompleteMultipartUploadKeepalive = "kludge.complete_multipart_keepalive" - cfgKludgeBypassContentEncodingCheckInChunks = "kludge.bypass_content_encoding_check_in_chunks" + cfgKludgeUseDefaultXMLNS = "kludge.use_default_xmlns" + cfgKludgeCompleteMultipartUploadKeepalive = "kludge.complete_multipart_keepalive" + cfgKludgeBypassContentEncodingCheckInChunks = "kludge.bypass_content_encoding_check_in_chunks" // Command line args. cmdHelp = "help" @@ -534,7 +534,7 @@ func newSettings() *viper.Viper { v.SetDefault(cfgBufferMaxSizeForPut, 1024*1024) // 1mb // kludge - v.SetDefault(cfgKludgeUseDefaultXMLNSForCompleteMultipartUpload, false) + v.SetDefault(cfgKludgeUseDefaultXMLNS, false) v.SetDefault(cfgKludgeCompleteMultipartUploadKeepalive, 10*time.Second) v.SetDefault(cfgKludgeBypassContentEncodingCheckInChunks, false) diff --git a/cmd/s3-gw/decoder_test.go b/cmd/s3-gw/decoder_test.go index d9022d0a2..3da63e240 100644 --- a/cmd/s3-gw/decoder_test.go +++ b/cmd/s3-gw/decoder_test.go @@ -41,42 +41,42 @@ func TestDefaultNamespace(t *testing.T) { }{ { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: false, + defaultXMLNS: false, }, input: xmlBodyWithNamespace, err: false, }, { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: false, + defaultXMLNS: false, }, input: xmlBody, err: true, }, { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: false, + defaultXMLNS: false, }, input: xmlBodyWithInvalidNamespace, err: true, }, { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: true, + defaultXMLNS: true, }, input: xmlBodyWithNamespace, err: false, }, { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: true, + defaultXMLNS: true, }, input: xmlBody, err: false, }, { settings: &appSettings{ - defaultXMLNSForCompleteMultipart: true, + defaultXMLNS: true, }, input: xmlBodyWithInvalidNamespace, err: true, @@ -84,7 +84,7 @@ func TestDefaultNamespace(t *testing.T) { } { t.Run("", func(t *testing.T) { model := new(handler.CompleteMultipartUpload) - err := tc.settings.NewCompleteMultipartDecoder(bytes.NewBufferString(tc.input)).Decode(model) + err := tc.settings.NewXMLDecoder(bytes.NewBufferString(tc.input)).Decode(model) if tc.err { require.Error(t, err) } else { diff --git a/config/config.env b/config/config.env index 4e6b4c71d..dbae386eb 100644 --- a/config/config.env +++ b/config/config.env @@ -138,8 +138,8 @@ S3_GW_ALLOWED_ACCESS_KEY_ID_PREFIXES=Ck9BHsgKcnwfCTUSFm6pxhoNS4cBqgN2NQ8zVgPjqZD S3_GW_RESOLVE_BUCKET_ALLOW=container # S3_GW_RESOLVE_BUCKET_DENY= -# Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse`CompleteMultipartUpload` xml body. -S3_GW_KLUDGE_USE_DEFAULT_XMLNS_FOR_COMPLETE_MULTIPART=false +# Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse xml bodies. +S3_GW_KLUDGE_USE_DEFAULT_XMLNS=false # Set timeout between whitespace transmissions during CompleteMultipartUpload processing. S3_GW_KLUDGE_COMPLETE_MULTIPART_KEEPALIVE=10s # Use this flag to be able to use chunked upload approach without having `aws-chunked` value in `Content-Encoding` header. @@ -149,4 +149,4 @@ S3_GW_TRACING_ENABLED=false S3_GW_TRACING_ENDPOINT="localhost:4318" S3_GW_TRACING_EXPORTER="otlp_grpc" -S3_GW_RUNTIME_SOFT_MEMORY_LIMIT=1073741824 \ No newline at end of file +S3_GW_RUNTIME_SOFT_MEMORY_LIMIT=1073741824 diff --git a/config/config.yaml b/config/config.yaml index 6a25957da..b487f670a 100644 --- a/config/config.yaml +++ b/config/config.yaml @@ -167,12 +167,12 @@ resolve_bucket: deny: kludge: - # Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse`CompleteMultipartUpload` xml body. - use_default_xmlns_for_complete_multipart: false + # Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse xml bodies. + use_default_xmlns: false # Set timeout between whitespace transmissions during CompleteMultipartUpload processing. complete_multipart_keepalive: 10s # Use this flag to be able to use chunked upload approach without having `aws-chunked` value in `Content-Encoding` header. bypass_content_encoding_check_in_chunks: false runtime: - soft_memory_limit: 1gb \ No newline at end of file + soft_memory_limit: 1gb diff --git a/docs/configuration.md b/docs/configuration.md index 486259414..208c75b78 100644 --- a/docs/configuration.md +++ b/docs/configuration.md @@ -540,16 +540,16 @@ Workarounds for non-standard use cases. ```yaml kludge: - use_default_xmlns_for_complete_multipart: false + use_default_xmlns: false complete_multipart_keepalive: 10s bypass_content_encoding_check_in_chunks: false ``` -| Parameter | Type | SIGHUP reload | Default value | Description | -|--------------------------------------------|------------|---------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| `use_default_xmlns_for_complete_multipart` | `bool` | yes | false | Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse `CompleteMultipartUpload` xml body. | -| `complete_multipart_keepalive` | `duration` | no | 10s | Set timeout between whitespace transmissions during CompleteMultipartUpload processing. | -| `bypass_content_encoding_check_in_chunks` | `bool` | yes | false | Use this flag to be able to use [chunked upload approach](https://docs.aws.amazon.com/AmazonS3/latest/API/sigv4-streaming.html) without having `aws-chunked` value in `Content-Encoding` header. | +| Parameter | Type | SIGHUP reload | Default value | Description | +|-------------------------------------------|------------|---------------|---------------|---------------------------------------------------------------------------------------------------------------------------------| +| `use_default_xmlns` | `bool` | yes | false | Enable using default xml namespace `http://s3.amazonaws.com/doc/2006-03-01/` when parse xml bodies. | +| `complete_multipart_keepalive` | `duration` | no | 10s | Set timeout between whitespace transmissions during CompleteMultipartUpload processing. | +| `bypass_content_encoding_check_in_chunks` | `bool` | yes | false | Use this flag to be able to use [chunked upload approach](https://docs.aws.amazon.com/AmazonS3/latest/API/sigv4-streaming.html) without having `aws-chunked` value in `Content-Encoding` header. | # `runtime` section Contains runtime parameters. @@ -561,4 +561,4 @@ runtime: | Parameter | Type | SIGHUP reload | Default value | Description | |---------------------|--------|---------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| `soft_memory_limit` | `size` | yes | maxint64 | Soft memory limit for the runtime. Zero or no value stands for no limit. If `GOMEMLIMIT` environment variable is set, the value from the configuration file will be ignored. | \ No newline at end of file +| `soft_memory_limit` | `size` | yes | maxint64 | Soft memory limit for the runtime. Zero or no value stands for no limit. If `GOMEMLIMIT` environment variable is set, the value from the configuration file will be ignored. | diff --git a/docs/release_instructions.md b/docs/release_instructions.md index 2199e28bb..4127c8594 100644 --- a/docs/release_instructions.md +++ b/docs/release_instructions.md @@ -123,4 +123,4 @@ not exist yet. $ git checkout $ git checkout -b support/ $ git push support/ -``` \ No newline at end of file +```