mirror of
https://github.com/minio/minio.git
synced 2025-04-02 19:00:38 -04:00
lifecycle: Support old BucketLifecycleConfiguration tag (#11828)
Some old AWS SDKs send BucketLifecycleConfiguration as the root tag in the bucket lifecycle document. This PR will support both LifecycleConfiguration and BucketLifecycleConfiguration.
This commit is contained in:
parent
61a1ea60c2
commit
0843280dc3
@ -66,6 +66,40 @@ type Lifecycle struct {
|
|||||||
Rules []Rule `xml:"Rule"`
|
Rules []Rule `xml:"Rule"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UnmarshalXML - decodes XML data.
|
||||||
|
func (lc *Lifecycle) UnmarshalXML(d *xml.Decoder, start xml.StartElement) (err error) {
|
||||||
|
switch start.Name.Local {
|
||||||
|
case "LifecycleConfiguration", "BucketLifecycleConfiguration":
|
||||||
|
default:
|
||||||
|
return errUnknownXMLTag
|
||||||
|
}
|
||||||
|
for {
|
||||||
|
// Read tokens from the XML document in a stream.
|
||||||
|
t, err := d.Token()
|
||||||
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
switch se := t.(type) {
|
||||||
|
case xml.StartElement:
|
||||||
|
switch se.Name.Local {
|
||||||
|
case "Rule":
|
||||||
|
var r Rule
|
||||||
|
if err = d.DecodeElement(&r, &se); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
lc.Rules = append(lc.Rules, r)
|
||||||
|
default:
|
||||||
|
return errUnknownXMLTag
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// HasActiveRules - returns whether policy has active rules for.
|
// HasActiveRules - returns whether policy has active rules for.
|
||||||
// Optionally a prefix can be supplied.
|
// Optionally a prefix can be supplied.
|
||||||
// If recursive is specified the function will also return true if any level below the
|
// If recursive is specified the function will also return true if any level below the
|
||||||
|
@ -336,6 +336,13 @@ func TestComputeActions(t *testing.T) {
|
|||||||
objectModTime: time.Now().UTC().Add(-24 * time.Hour), // Created 1 day ago
|
objectModTime: time.Now().UTC().Add(-24 * time.Hour), // Created 1 day ago
|
||||||
expectedAction: DeleteAction,
|
expectedAction: DeleteAction,
|
||||||
},
|
},
|
||||||
|
// Should accept BucketLifecycleConfiguration root tag
|
||||||
|
{
|
||||||
|
inputConfig: `<BucketLifecycleConfiguration><Rule><Filter><Prefix>foodir/</Prefix></Filter><Status>Enabled</Status><Expiration><Date>` + time.Now().Truncate(24*time.Hour).UTC().Add(-24*time.Hour).Format(time.RFC3339) + `</Date></Expiration></Rule></BucketLifecycleConfiguration>`,
|
||||||
|
objectName: "foodir/fooobject",
|
||||||
|
objectModTime: time.Now().UTC().Add(-24 * time.Hour), // Created 1 day ago
|
||||||
|
expectedAction: DeleteAction,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tc := range testCases {
|
for _, tc := range testCases {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user