Class FilesystemStorageStrategyImpl
java.lang.Object
org.jclouds.filesystem.strategy.internal.FilesystemStorageStrategyImpl
- All Implemented Interfaces:
- LocalStorageStrategy
FilesystemStorageStrategyImpl implements a blob store that stores objects
 on the file system. Content metadata and user attributes are stored in
 extended attributes if the file system supports them. Directory blobs
 (blobs that end with a /) cannot have content, but otherwise appear in
 LIST like normal blobs.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final booleanprotected final Stringprotected final javax.inject.Provider<BlobBuilder> protected final FilesystemBlobKeyValidatorprotected final FilesystemContainerNameValidatorprotected Logger
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedFilesystemStorageStrategyImpl(javax.inject.Provider<BlobBuilder> blobBuilders, String baseDir, boolean autoDetectContentType, FilesystemContainerNameValidator filesystemContainerNameValidator, FilesystemBlobKeyValidator filesystemBlobKeyValidator, com.google.common.base.Supplier<Location> defaultLocation) 
- 
Method SummaryModifier and TypeMethodDescriptionbooleanblobExists(String container, String key) Return true if a blob named by key existsprotected StringbuildPathStartingFromBaseDir(String... pathTokens) Facility method used to concatenate path tokens normalizing separatorsvoidclearContainer(String container) Empty the container of its content (files and subdirectories), but doesn't delete the container itselfvoidclearContainer(String container, ListContainerOptions options) LikeLocalStorageStrategy.clearContainer(String)except you can use options to do things like recursive deletes, or clear at a different path than root.booleancontainerExists(String container) Checks if a container existslongcountBlobs(String container, ListContainerOptions options) booleancreateContainer(String container) booleancreateContainerInLocation(String container, Location location, CreateContainerOptions options) Creates a new containervoidcreateDirectory(String container, String directory) protected booleancreateDirectoryWithResult(String container, String directory) Creates a directory and returns the resultvoiddeleteContainer(String container) Deletes a container and all its contentvoiddeleteDirectory(String container, String directory) booleandirectoryExists(String container, String directory) Return an iterator that reports all the containers under base pathLoad the blob with the given key belonging to the container with the given name.getBlobAccess(String containerName, String blobName) getBlobKeysInsideContainer(String container, String prefix) Returns all the blobs key inside a containergetContainerAccess(String container) getContainerMetadata(String container) getFileForBlobKey(String container, String blobKey) Returns aFileobject that links to the blobgetLocation(String containerName) protected UserDefinedFileAttributeViewputBlob(String containerName, Blob blob, BlobAccess access) Write aBlobinto a filevoidremoveBlob(String container, String blobKey) Remove blob named by the given keyvoidsetBlobAccess(String container, String name, BlobAccess access) voidsetContainerAccess(String container, ContainerAccess access) 
- 
Field Details- 
logger
- 
blobBuilders
- 
baseDirectory
- 
autoDetectContentTypeprotected final boolean autoDetectContentType
- 
filesystemContainerNameValidator
- 
filesystemBlobKeyValidator
 
- 
- 
Constructor Details- 
FilesystemStorageStrategyImpl@Inject protected FilesystemStorageStrategyImpl(javax.inject.Provider<BlobBuilder> blobBuilders, @Named("jclouds.filesystem.basedir") String baseDir, @Named("jclouds.filesystem.auto-detect-content-type") boolean autoDetectContentType, FilesystemContainerNameValidator filesystemContainerNameValidator, FilesystemBlobKeyValidator filesystemBlobKeyValidator, com.google.common.base.Supplier<Location> defaultLocation) 
 
- 
- 
Method Details- 
containerExistsDescription copied from interface:LocalStorageStrategyChecks if a container exists- Specified by:
- containerExistsin interface- LocalStorageStrategy
- Parameters:
- container-
- Returns:
 
- 
getAllContainerNamesDescription copied from interface:LocalStorageStrategyReturn an iterator that reports all the containers under base path- Specified by:
- getAllContainerNamesin interface- LocalStorageStrategy
- Returns:
 
- 
createContainerInLocationpublic boolean createContainerInLocation(String container, Location location, CreateContainerOptions options) Description copied from interface:LocalStorageStrategyCreates a new container- Specified by:
- createContainerInLocationin interface- LocalStorageStrategy
- Parameters:
- container-
- Returns:
 
- 
getContainerAccess- Specified by:
- getContainerAccessin interface- LocalStorageStrategy
 
- 
setContainerAccess- Specified by:
- setContainerAccessin interface- LocalStorageStrategy
 
- 
deleteContainerDescription copied from interface:LocalStorageStrategyDeletes a container and all its content- Specified by:
- deleteContainerin interface- LocalStorageStrategy
- Parameters:
- container-
 
- 
clearContainerDescription copied from interface:LocalStorageStrategyEmpty the container of its content (files and subdirectories), but doesn't delete the container itself- Specified by:
- clearContainerin interface- LocalStorageStrategy
- Parameters:
- container-
 
- 
clearContainerDescription copied from interface:LocalStorageStrategyLikeLocalStorageStrategy.clearContainer(String)except you can use options to do things like recursive deletes, or clear at a different path than root.- Specified by:
- clearContainerin interface- LocalStorageStrategy
- Parameters:
- container- what to clear
- options- recursion and path to clear
 
- 
getContainerMetadata- Specified by:
- getContainerMetadatain interface- LocalStorageStrategy
- Returns:
- StorageMetadata associated with a container name, e.g., creation date and location, or null if container does not exist
 
- 
blobExistsDescription copied from interface:LocalStorageStrategyReturn true if a blob named by key exists- Specified by:
- blobExistsin interface- LocalStorageStrategy
- Parameters:
- container-
- key-
- Returns:
 
- 
getBlobKeysInsideContainerpublic Iterable<String> getBlobKeysInsideContainer(String container, String prefix) throws IOException Returns all the blobs key inside a container- Specified by:
- getBlobKeysInsideContainerin interface- LocalStorageStrategy
- Parameters:
- container-
- Returns:
- Throws:
- IOException
 
- 
getBlobDescription copied from interface:LocalStorageStrategyLoad the blob with the given key belonging to the container with the given name. There must exist a resource on the file system whose complete name is given concatenating the container name and the key- Specified by:
- getBlobin interface- LocalStorageStrategy
- Returns:
- the blob belonging to the given container with the given key
 
- 
putBlob- Specified by:
- putBlobin interface- LocalStorageStrategy
- Throws:
- IOException
 
- 
putBlobDescription copied from interface:LocalStorageStrategyWrite aBlobinto a file- Specified by:
- putBlobin interface- LocalStorageStrategy
- Parameters:
- blob-
- access-
- Returns:
- etag of blob
- Throws:
- IOException
 
- 
removeBlobDescription copied from interface:LocalStorageStrategyRemove blob named by the given key- Specified by:
- removeBlobin interface- LocalStorageStrategy
- Parameters:
- container-
- blobKey-
 
- 
getBlobAccess- Specified by:
- getBlobAccessin interface- LocalStorageStrategy
 
- 
setBlobAccess- Specified by:
- setBlobAccessin interface- LocalStorageStrategy
 
- 
getLocation- Specified by:
- getLocationin interface- LocalStorageStrategy
- Parameters:
- containerName- name of container
- Returns:
- Location of container or null
 
- 
getSeparator- Specified by:
- getSeparatorin interface- LocalStorageStrategy
- Returns:
- path separator, either / or \
 
- 
createContainer
- 
newBlob
- 
getFileForBlobKeyReturns aFileobject that links to the blob- Parameters:
- container-
- blobKey-
- Returns:
 
- 
directoryExists
- 
createDirectory
- 
deleteDirectory
- 
countBlobs
- 
getUserDefinedFileAttributeViewprotected UserDefinedFileAttributeView getUserDefinedFileAttributeView(Path path) throws IOException - Throws:
- IOException
 
- 
buildPathStartingFromBaseDirFacility method used to concatenate path tokens normalizing separators- Parameters:
- pathTokens- all the string in the proper order that must be concatenated in order to obtain the filename
- Returns:
- the resulting string
 
- 
createDirectoryWithResultCreates a directory and returns the result- Parameters:
- container-
- directory-
- Returns:
- true if the directory was created, otherwise false
 
 
-