Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

Lifecycle policy specification includes:

  • Cluster setting

  • Policy headers on domain and bucket objects

  • Bucket policies stored in Swarm storage (as headers) by the gateway

  • Relevant changes to the UIS for lifecycle policies

Cluster Setting Values

The CAStor cluster setting policy.lifecycle supports two values:

  • disabled – By default, the evaluation of all lifecycle policies is disabled in the cluster to provide legacy behavior.

  • enabled – Lifecycle policies are enabled at the domain level for domains where such policies are applied.

The policy.lifecycle setting can be set via Management API and SNMP.

Policy Header Values

Domain objects support a Policy-Lifecycle header that controls the behavior of lifecycle policies for buckets in the domain. The header supports either of the following values:

  • <unspecified> – The lack of a defined policy header means that lifecycle policies are only enabled for buckets in the domain when the policy.lifecycle setting is enabled.

  • enabled – The lifecycle policies are enabled for buckets in a domain when the policy.lifecycle cluster setting is enabled.

  • disabled – The lifecycle policies are disabled for buckets in a domain regardless of policy.lifecycle setting. The Policy-Lifecycle value is prefixed with a <cluster name>=, meaning that the policy only applies within the specified cluster. Multiple values are allowed if this feature is used.

Domain objects do not support policy specification applied to the tenanted content in the domain.

Bucket objects support a Policy-Lifecycle header with multiple values.

  • Each header value encodes one lifecycle policy.

  • Each Policy-Lifecycle complete rule value is suffixed with “:<cluster name>”, meaning that the policy applies within the specified cluster.

  • Each lifecycle rule is comprised of a number of optional attributes, expressed as <name>:<value> pairs separated by space. Extra spaces are allowed at the beginning, end, and before & after the colon.

Must to have

  • Duplicate names are not allowed within a rule.

  • Unsupported names or values result in a 400 on the bucket (or domain) write.

Supported Attributes

Attribute

Value

Definition

RuleId

<unique rule id>

A required, user-defined id of the rule. The quotes allow spaces in the id. Double quotes in the id must be backslash escaped.

Enabled

<true|false>

An optional indication to confirm whether the rule is enabled or not. The absence of attribute indicates the rule enabled.

NamePrefix

<prefix>

An optional prefix to be matched against the relative name of the object in question.

  • Quotes are required.

  • Never use slash as a first character for the prefix.

  • If the prefix is matched with the object name, then the rule is applied to the object.

  • The absence of this prefix indicates the rule is applied to all objects in the bucket.

  • The quotes allow vertical spaces in the prefix.

  • The value in quotes must be URL encoded.

ExpirationDays

<nonnegative integer>

The current version of an object is expired after the defined number of days.

ExpirationDate

<ISO 8601 date>

The current version of an object is expired after the defined date (midnight UTC time).

ObsoleteExpirationDays

<nonnegative integer>

A non-current version of an object is expired after the defind number of days when the object becomes non-current.

This rule impacts nothing if the versioning is not enabled on the bucket.

ObsoleteExpirationDate

<ISO 8601 date>

A non-current version of the object is expired after the defined date (midnight UTC time).

This rule impacts nothing if the versioning is not enabled on the bucket.

Rules with Attributes

Every rule;

  • Must have one or multiple expiration-related attributes.

  • Must have an action.

  • May or may not have ExpirationDays & ExpirationDate attributes and ObsoleteExpirationDays & ObsoleteExprirationDate attributes.

Expiration Time Rule

  • For expiration days,
    Expiration time = Creation time of the current version + Number of days indicated + Rounded up to the next midnight UTC

  • For obsolete expiration days,
    Expiration time = Create time of the next new object in the versioning chain + Number of days indicated + Rounded up to the next midnight UTC

  • ISO 8601 dates must unambiguously specify a calendar date. The (unspecified) expiration time is always midnight UTC of that date.

  • Expiration of a current version of an object (i.e. non-delete marker in the versioning enabled bucket) means creating a delete marker, pushing the current version down the versioning stack.

  • In all other cases, the object or object version is permanently deleted.

The gateway supports normal SCSP reads & writes of domain and bucket headers with those policies specified. Gateway S3 interface is modified to support GET, PUT, DELETE, and related permissions for bucket lifecycle policies as specified in the S3 documentation. Gateway validates policies against the S3 specification. On PUT or DELETE permission, the gateway translates the client-supplied bucket policy specifications into the appropriate CAStor bucket headers. Bucket lifecycle policies' features that Castor does not support, are dropped during this translation, such as storage class transitions. On the bucket lifecycle policy GET reply, Gateway performs reverse translation for any Policy-Lifecycle headers on the bucket object for its S3 response.

UIC provides appropriate editing methods for bucket lifecycle policies at the cluster, domain, and bucket levels.

Since lifecycle policies are part of the overall context-level policy framework, GET and HEAD requests on contexts and name objects (with the verbose query argument) return Policy-Lifecycle-Evaluated and Policy-Lifecycle-Evaluated-Constrained headers. They describe if the lifecycle policies are enforced at the various levels such as cluster, domain, and bucket.

  • No labels