com.microsoft.azure.storage.file.FileProperties Maven / Gradle / Ivy
/**
* Copyright Microsoft Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.microsoft.azure.storage.file;
import java.util.Date;
import java.util.EnumSet;
import com.microsoft.azure.storage.AccessCondition;
/**
* Represents the system properties for a file.
*/
public final class FileProperties {
/**
* Represents the cache-control value stored for the file.
*/
private String cacheControl;
/**
* Represents the content-disposition value stored for the file. If this field has not been set for the file, the
* field returns null
.
*/
private String contentDisposition;
/**
* Represents the content-encoding value stored for the file. If this field has not been set for the file, the field
* returns null
.
*/
private String contentEncoding;
/**
* Represents the content-language value stored for the file. If this field has not been set for the file, the field
* returns null
.
*/
private String contentLanguage;
/**
* Represents the content MD5 value stored for the file.
*/
private String contentMD5;
/**
* Represents the content type value stored for the file. If this field has not been set for the file, the field
* returns null
.
*/
private String contentType;
/**
* Represents the state of the most recent or pending copy operation.
*/
private CopyState copyState;
/**
* Represents the size, in bytes, of the file.
*/
private long length;
/**
* Represents the file's ETag value.
*/
private String etag;
/**
* Represents the last-modified time for the file.
*/
private Date lastModified;
/**
* Represents the file's server-side encryption status.
*/
private boolean serverEncrypted;
/**
* The following package private properties are set-able file SMB properties. This is by design.
* There are two variables - one normal variable and one toSet variable to account for the statefulness of our
* objects and the fact that the service requires each SMB property header.
*
* When a user wants to set a new SMB property, they call the setter method, which sets the toSet variable.
* Upon calling the File.Create or File.SetProperties methods, the toSet variable is checked and set if it has been set to a value.
* The service then returns the properties, that are then populated in the normal variable when updating SMB properties
* and each of the toSet variables are set back to null.
*/
/**
* Represents the file's permission key.
*/
String filePermissionKey;
/**
* Represents the file's permission key to be set.
*/
String filePermissionKeyToSet;
/**
* Represents the file system attributes for files and directories.
* If not set, indicates preservation of existing values.
*/
EnumSet ntfsAttributes;
/**
* Represents the file system attributes for files and directories to be set.
* If not set, indicates preservation of existing values.
*/
EnumSet ntfsAttributesToSet;
/**
* Represents the creation time for the file.
*/
String creationTime;
/**
* Represents the creation time for the file to be set.
*/
String creationTimeToSet;
/**
* Represents the last-write time for the file.
*/
String lastWriteTime;
/**
* Represents the last-write time for the file to set.
*/
String lastWriteTimeToSet;
/**
* Represents the change time for the file.
*/
private String changeTime;
/**
* Represents the file's id.
*/
private String fileId;
/**
* Represents the file's parent id.
*/
private String parentId;
/**
* Creates an instance of the FileProperties
class.
*/
public FileProperties() {
// No op
}
/**
* Creates an instance of the FileProperties
class by copying values from another instance of the
* FileProperties
class.
*
* @param other
* A FileProperties
object which represents the file properties to copy.
*/
public FileProperties(final FileProperties other) {
this.cacheControl = other.cacheControl;
this.contentDisposition = other.contentDisposition;
this.contentEncoding = other.contentEncoding;
this.contentLanguage = other.contentLanguage;
this.contentMD5 = other.contentMD5;
this.contentType = other.contentType;
this.etag = other.etag;
this.length = other.length;
this.lastModified = other.lastModified;
this.serverEncrypted = other.serverEncrypted;
this.filePermissionKey = other.filePermissionKey;
this.filePermissionKeyToSet = other.filePermissionKeyToSet;
this.ntfsAttributes = other.ntfsAttributes;
this.ntfsAttributesToSet = other.ntfsAttributesToSet;
this.creationTime = other.creationTime;
this.creationTimeToSet = other.creationTimeToSet;
this.lastWriteTime = other.lastWriteTime;
this.lastWriteTimeToSet = other.lastWriteTimeToSet;
}
/**
* Gets the cache control value for the file.
*
* @return A String
which represents the content cache control value for the file.
*/
public String getCacheControl() {
return this.cacheControl;
}
/**
* Gets the content disposition value for the file.
*
* @return A String
which represents the content disposition, or null
if content
* disposition has not been set on the file.
*/
public String getContentDisposition() {
return this.contentDisposition;
}
/**
* Gets the content encoding value for the file.
*
* @return A String
which represents the content encoding, or null
if content encoding has
* not been set on the file.
*/
public String getContentEncoding() {
return this.contentEncoding;
}
/**
* Gets the content language value for the file.
*
* @return A String
which represents the content language, or null
if content language
* has not been set on the file.
*/
public String getContentLanguage() {
return this.contentLanguage;
}
/**
* Gets the content MD5 value for the file.
*
* @return A String
which represents the content MD5 value.
*/
public String getContentMD5() {
return this.contentMD5;
}
/**
* Gets the content type value for the file.
*
* @return A String
which represents the content type, or null
if the content type has not
* be set for the file.
*/
public String getContentType() {
return this.contentType;
}
/**
* Gets the file's copy state.
*
* @return A {@link CopyState} object which represents the copy state of the file.
*/
public CopyState getCopyState() {
return this.copyState;
}
/**
* Gets the ETag value for the file.
*
* The ETag value is a unique identifier that is updated when a write operation is performed against the file. It
* may be used to perform operations conditionally, providing concurrency control and improved efficiency.
*
* The {@link AccessCondition#generateIfMatchCondition(String)} and
* {@link AccessCondition#generateIfNoneMatchCondition(String)} methods take an ETag value and return an
* {@link AccessCondition} object that may be specified on the request.
*
* @return A String
which represents the ETag value.
*/
public String getEtag() {
return this.etag;
}
/**
* Gets the last modified time for the file.
*
* @return A {@link java.util.Date} object which represents the last modified time.
*/
public Date getLastModified() {
return this.lastModified;
}
/**
* Gets the size, in bytes, of the file.
*
* @return A long
which represents the length of the file.
*/
public long getLength() {
return this.length;
}
/**
* Gets the file's server-side encryption status.
*
* @return A boolean
which specifies the file's encryption status.
*/
public boolean isServerEncrypted() {
return this.serverEncrypted;
}
/**
* Gets the file's permission key.
*
* @return A String
which specifies the file's permission key.
*/
public String getFilePermissionKey() {
return this.filePermissionKeyToSet == null ? this.filePermissionKey : this.filePermissionKeyToSet;
}
/**
* Gets the file system attributes for files and directories.
* If not set, indicates preservation of existing values.
*
* @return A {@link NtfsAttributes} object which represents the file system attributes.
*/
public EnumSet getNtfsAttributes() {
return this.ntfsAttributesToSet == null ? this.ntfsAttributes : this.ntfsAttributesToSet;
}
/**
* Gets the creation time for the file.
*
* @return A String
object which represents the creation time.
*/
public String getCreationTime() {
return this.creationTimeToSet == null ? this.creationTime : this.creationTimeToSet;
}
/**
* Gets the last write time for the file.
*
* @return A String
object which represents the last write time.
*/
public String getLastWriteTime() {
return this.lastWriteTimeToSet == null ? this.lastWriteTime : this.lastWriteTimeToSet;
}
/**
* Gets the change time for the file.
*
* @return A String
object which represents the change time.
*/
public String getChangeTime() {
return this.changeTime;
}
/**
* Gets the file's id.
*
* @return A String
which specifies the file's id.
*/
public String getFileId() {
return this.fileId;
}
/**
* Gets the file's parent id.
*
* @return A String
which specifies the file's parent id.
*/
public String getParentId() {
return this.parentId;
}
/**
* Sets the cache control value for the file.
*
* @param cacheControl
* A String
which specifies the cache control value to set.
*/
public void setCacheControl(final String cacheControl) {
this.cacheControl = cacheControl;
}
/**
* Sets the content disposition value for the file.
*
* @param contentDisposition
* A String
which specifies the content disposition value to set.
*/
public void setContentDisposition(final String contentDisposition) {
this.contentDisposition = contentDisposition;
}
/**
* Sets the content encoding value for the file.
*
* @param contentEncoding
* A String
which specifies the content encoding value to set.
*/
public void setContentEncoding(final String contentEncoding) {
this.contentEncoding = contentEncoding;
}
/**
* Sets the content language for the file.
*
* @param contentLanguage
* A String
which specifies the content language value to set.
*/
public void setContentLanguage(final String contentLanguage) {
this.contentLanguage = contentLanguage;
}
/**
* Sets the content MD5 value for the file.
*
* @param contentMD5
* A String
which specifies the content MD5 value to set.
*/
public void setContentMD5(final String contentMD5) {
this.contentMD5 = contentMD5;
}
/**
* Sets the content type value for the file.
*
* @param contentType
* A String
which specifies the content type value to set.
*/
public void setContentType(final String contentType) {
this.contentType = contentType;
}
/**
* Sets the file's server-side encryption status.
*
* @param serverEncrypted
* A boolean
which specifies the encryption status to set.
*/
protected void setServerEncrypted(boolean serverEncrypted) {
this.serverEncrypted = serverEncrypted;
}
/**
* Sets the copy state value for the file.
*
* @param copyState
* A {@link CopyState} object which specifies the copy state value to set.
*/
protected void setCopyState(final CopyState copyState) {
this.copyState = copyState;
}
/**
* Sets the ETag value for the file.
*
* @param etag
* A String
which specifies the ETag value to set.
*/
protected void setEtag(final String etag) {
this.etag = etag;
}
/**
* Sets the last modified time for the file.
*
* @param lastModified
* A {@link java.util.Date} object which specifies the last modified time to set.
*/
protected void setLastModified(final Date lastModified) {
this.lastModified = lastModified;
}
/**
* Sets the content length, in bytes, for the file.
*
* @param length
* A long
which specifies the length to set.
*/
protected void setLength(final long length) {
this.length = length;
}
/**
* Sets the file's permission key.
*
* @param filePermissionKey
* A String
which specifies the file permission key to set.
*/
public void setFilePermissionKey(String filePermissionKey) {
this.filePermissionKeyToSet = filePermissionKey;
}
/**
* Sets the file system attributes for files and directories.
* If not set, indicates preservation of existing values.
*
* @param ntfsAttributes
* A {@link NtfsAttributes} which specifies the file system attributes to set.
*/
public void setNtfsAttributes(EnumSet ntfsAttributes) {
this.ntfsAttributesToSet = ntfsAttributes;
}
/**
* Sets the creation time to set for the file.
*
* @param creationTime
* A String
object which specifies the creation time to set.
*/
public void setCreationTime(String creationTime) {
this.creationTimeToSet = creationTime;
}
/**
* Sets the last write time for the file.
*
* @param lastWriteTime
* A String
object which specifies the last write time to set.
*/
protected void setLastWriteTime(String lastWriteTime) {
this.lastWriteTimeToSet = lastWriteTime;
}
/**
* Sets the change time for the file.
*
* @param changeTime
* A String
object which specifies the change time to set.
*/
protected void setChangeTime(String changeTime) {
this.changeTime = changeTime;
}
/**
* Sets the file's id.
*
* @param fileId
* A String
which specifies the id to set.
*/
protected void setFileId(String fileId) {
this.fileId = fileId;
}
/**
* Sets the file's parent id.
*
* @param parentId
* A String
which specifies the parent id to set.
*/
protected void setParentId(String parentId) {
this.parentId = parentId;
}
}