com.azure.resourcemanager.storage.models.UpdateHistoryProperty Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-resourcemanager-storage Show documentation
Show all versions of azure-resourcemanager-storage Show documentation
This package contains Microsoft Azure Storage Management SDK.
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.
package com.azure.resourcemanager.storage.models;
import com.azure.core.annotation.Fluent;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.time.OffsetDateTime;
/** An update history of the ImmutabilityPolicy of a blob container. */
@Fluent
public final class UpdateHistoryProperty {
/*
* The ImmutabilityPolicy update type of a blob container, possible values include: put, lock and extend.
*/
@JsonProperty(value = "update", access = JsonProperty.Access.WRITE_ONLY)
private ImmutabilityPolicyUpdateType update;
/*
* The immutability period for the blobs in the container since the policy creation, in days.
*/
@JsonProperty(value = "immutabilityPeriodSinceCreationInDays", access = JsonProperty.Access.WRITE_ONLY)
private Integer immutabilityPeriodSinceCreationInDays;
/*
* Returns the date and time the ImmutabilityPolicy was updated.
*/
@JsonProperty(value = "timestamp", access = JsonProperty.Access.WRITE_ONLY)
private OffsetDateTime timestamp;
/*
* Returns the Object ID of the user who updated the ImmutabilityPolicy.
*/
@JsonProperty(value = "objectIdentifier", access = JsonProperty.Access.WRITE_ONLY)
private String objectIdentifier;
/*
* Returns the Tenant ID that issued the token for the user who updated the ImmutabilityPolicy.
*/
@JsonProperty(value = "tenantId", access = JsonProperty.Access.WRITE_ONLY)
private String tenantId;
/*
* Returns the User Principal Name of the user who updated the ImmutabilityPolicy.
*/
@JsonProperty(value = "upn", access = JsonProperty.Access.WRITE_ONLY)
private String upn;
/*
* This property can only be changed for unlocked time-based retention policies. When enabled, new blocks can be
* written to an append blob while maintaining immutability protection and compliance. Only new blocks can be added
* and any existing blocks cannot be modified or deleted. This property cannot be changed with
* ExtendImmutabilityPolicy API.
*/
@JsonProperty(value = "allowProtectedAppendWrites")
private Boolean allowProtectedAppendWrites;
/*
* This property can only be changed for unlocked time-based retention policies. When enabled, new blocks can be
* written to both 'Append and Bock Blobs' while maintaining immutability protection and compliance. Only new
* blocks can be added and any existing blocks cannot be modified or deleted. This property cannot be changed with
* ExtendImmutabilityPolicy API. The 'allowProtectedAppendWrites' and 'allowProtectedAppendWritesAll' properties
* are mutually exclusive.
*/
@JsonProperty(value = "allowProtectedAppendWritesAll")
private Boolean allowProtectedAppendWritesAll;
/**
* Get the update property: The ImmutabilityPolicy update type of a blob container, possible values include: put,
* lock and extend.
*
* @return the update value.
*/
public ImmutabilityPolicyUpdateType update() {
return this.update;
}
/**
* Get the immutabilityPeriodSinceCreationInDays property: The immutability period for the blobs in the container
* since the policy creation, in days.
*
* @return the immutabilityPeriodSinceCreationInDays value.
*/
public Integer immutabilityPeriodSinceCreationInDays() {
return this.immutabilityPeriodSinceCreationInDays;
}
/**
* Get the timestamp property: Returns the date and time the ImmutabilityPolicy was updated.
*
* @return the timestamp value.
*/
public OffsetDateTime timestamp() {
return this.timestamp;
}
/**
* Get the objectIdentifier property: Returns the Object ID of the user who updated the ImmutabilityPolicy.
*
* @return the objectIdentifier value.
*/
public String objectIdentifier() {
return this.objectIdentifier;
}
/**
* Get the tenantId property: Returns the Tenant ID that issued the token for the user who updated the
* ImmutabilityPolicy.
*
* @return the tenantId value.
*/
public String tenantId() {
return this.tenantId;
}
/**
* Get the upn property: Returns the User Principal Name of the user who updated the ImmutabilityPolicy.
*
* @return the upn value.
*/
public String upn() {
return this.upn;
}
/**
* Get the allowProtectedAppendWrites property: This property can only be changed for unlocked time-based retention
* policies. When enabled, new blocks can be written to an append blob while maintaining immutability protection and
* compliance. Only new blocks can be added and any existing blocks cannot be modified or deleted. This property
* cannot be changed with ExtendImmutabilityPolicy API.
*
* @return the allowProtectedAppendWrites value.
*/
public Boolean allowProtectedAppendWrites() {
return this.allowProtectedAppendWrites;
}
/**
* Set the allowProtectedAppendWrites property: This property can only be changed for unlocked time-based retention
* policies. When enabled, new blocks can be written to an append blob while maintaining immutability protection and
* compliance. Only new blocks can be added and any existing blocks cannot be modified or deleted. This property
* cannot be changed with ExtendImmutabilityPolicy API.
*
* @param allowProtectedAppendWrites the allowProtectedAppendWrites value to set.
* @return the UpdateHistoryProperty object itself.
*/
public UpdateHistoryProperty withAllowProtectedAppendWrites(Boolean allowProtectedAppendWrites) {
this.allowProtectedAppendWrites = allowProtectedAppendWrites;
return this;
}
/**
* Get the allowProtectedAppendWritesAll property: This property can only be changed for unlocked time-based
* retention policies. When enabled, new blocks can be written to both 'Append and Bock Blobs' while maintaining
* immutability protection and compliance. Only new blocks can be added and any existing blocks cannot be modified
* or deleted. This property cannot be changed with ExtendImmutabilityPolicy API. The 'allowProtectedAppendWrites'
* and 'allowProtectedAppendWritesAll' properties are mutually exclusive.
*
* @return the allowProtectedAppendWritesAll value.
*/
public Boolean allowProtectedAppendWritesAll() {
return this.allowProtectedAppendWritesAll;
}
/**
* Set the allowProtectedAppendWritesAll property: This property can only be changed for unlocked time-based
* retention policies. When enabled, new blocks can be written to both 'Append and Bock Blobs' while maintaining
* immutability protection and compliance. Only new blocks can be added and any existing blocks cannot be modified
* or deleted. This property cannot be changed with ExtendImmutabilityPolicy API. The 'allowProtectedAppendWrites'
* and 'allowProtectedAppendWritesAll' properties are mutually exclusive.
*
* @param allowProtectedAppendWritesAll the allowProtectedAppendWritesAll value to set.
* @return the UpdateHistoryProperty object itself.
*/
public UpdateHistoryProperty withAllowProtectedAppendWritesAll(Boolean allowProtectedAppendWritesAll) {
this.allowProtectedAppendWritesAll = allowProtectedAppendWritesAll;
return this;
}
/**
* Validates the instance.
*
* @throws IllegalArgumentException thrown if the instance is not valid.
*/
public void validate() {
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy