Class RegionScopedSwiftBlobStore
java.lang.Object
org.jclouds.openstack.swift.v1.blobstore.RegionScopedSwiftBlobStore
- All Implemented Interfaces:
- BlobStore
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final com.google.common.cache.LoadingCache<String, com.google.common.base.Optional<Container>> protected Loggerprotected intprotected final PayloadSlicerprotected final com.google.common.util.concurrent.ListeningExecutorService
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedRegionScopedSwiftBlobStore(com.google.inject.Injector baseGraph, BlobStoreContext context, SwiftApi api, com.google.common.base.Supplier<Set<? extends Location>> locations, String regionId, PayloadSlicer slicer, com.google.common.util.concurrent.ListeningExecutorService userExecutor) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidblobBuilder(String name) booleanblobExists(String container, String name) Determines if a blob existsblobMetadata(String container, String name) Retrieves the metadata of aBlobat locationcontainer/namevoidclearContainer(String containerName) This will delete the contents of a container at its root path without deleting the containervoidclearContainer(String containerName, ListContainerOptions options) LikeBlobStore.clearContainer(String)except you can use options to do things like recursive deletes, or clear at a different path than root.completeMultipartUpload(MultipartUpload mpu, List<MultipartPart> parts) booleancontainerExists(String container) determines if a service-level container existscopyBlob(String fromContainer, String fromName, String toContainer, String toName, CopyOptions options) Copy blob from one container to another.longcountBlobs(String containerName) longcountBlobs(String containerName, ListContainerOptions options) booleancreateContainerInLocation(Location location, String container) Creates a namespace for your blobsbooleancreateContainerInLocation(Location location, String container, CreateContainerOptions options) voidcreateDirectory(String containerName, String directory) Creates a folder or a directory marker depending on the servicevoiddeleteContainer(String container) This will delete everything inside a container recursively.booleandeleteContainerIfEmpty(String container) Deletes a container if it is empty.voiddeleteDirectory(String containerName, String directory) Deletes a folder or a directory marker depending on the servicebooleandirectoryExists(String containerName, String directory) Determines if a directory existsvoiddownloadBlob(String container, String name, File destination) voiddownloadBlob(String container, String name, File destination, ExecutorService executor) Retrieves aBlobrepresenting the data at locationcontainer/namegetBlob(String container, String name, GetOptions options) Retrieves aBlobrepresenting the data at locationcontainer/namegetBlobAccess(String container, String name) getContainerAccess(String name) longintlonginitiateMultipartUpload(String container, BlobMetadata blobMetadata, PutOptions options) PageSet<? extends StorageMetadata> list()Lists all root-level resources available to the identity.PageSet<? extends StorageMetadata> Lists all resources in a container non-recursive.PageSet<? extends StorageMetadata> list(String container, ListContainerOptions options) LikeBlobStore.list(String)except you can control the size, recursion, and context of the list usingoptionsThe get locations command returns all the valid locations for containers.listMultipartUploads(String container) Adds aBlobrepresenting the data at locationcontainer/blob.metadata.nameputBlob(String container, Blob blob, PutOptions options) Adds aBlobrepresenting the data at locationcontainer/blob.metadata.nameoptions using multipart strategies.protected StringputMultipartBlob(String container, Blob blob, PutOptions overrides) Upload using a user-provided executor, or the jclouds userExecutorprotected StringputMultipartBlob(String container, Blob blob, PutOptions overrides, com.google.common.util.concurrent.ListeningExecutorService executor) voidremoveBlob(String container, String name) Deletes aBlobrepresenting the data at locationcontainer/namevoidremoveBlobs(String container, Iterable<String> names) Delete multiple single-part objects.voidsetBlobAccess(String container, String name, BlobAccess access) voidsetContainerAccess(String name, ContainerAccess access) streamBlob(String container, String name) streamBlob(String container, String name, ExecutorService executor) protected com.google.common.base.Function<SwiftObject, MutableBlobMetadata> toBlobMetadata(String container) uploadMultipartPart(MultipartUpload mpu, int partNumber, Payload payload) 
- 
Field Details- 
slicer
- 
userExecutorprotected final com.google.common.util.concurrent.ListeningExecutorService userExecutor
- 
logger
- 
containerCache
- 
retryCountLimit@Inject(optional=true) @Named("jclouds.max-retries") protected int retryCountLimit
 
- 
- 
Constructor Details- 
RegionScopedSwiftBlobStore@Inject protected RegionScopedSwiftBlobStore(com.google.inject.Injector baseGraph, BlobStoreContext context, SwiftApi api, com.google.common.base.Supplier<Set<? extends Location>> locations, String regionId, PayloadSlicer slicer, @Named("jclouds.user-threads") com.google.common.util.concurrent.ListeningExecutorService userExecutor) 
 
- 
- 
Method Details- 
listAssignableLocationsDescription copied from interface:BlobStoreThe get locations command returns all the valid locations for containers. A location has a scope, which is typically region or zone. A region is a general area, like eu-west, where a zone is similar to a datacenter. If a location has a parent, that implies it is within that location. For example a location can be a rack, whose parent is likely to be a zone.- Specified by:
- listAssignableLocationsin interface- BlobStore
 
- 
listDescription copied from interface:BlobStoreLists all root-level resources available to the identity.
- 
containerExistsDescription copied from interface:BlobStoredetermines if a service-level container exists- Specified by:
- containerExistsin interface- BlobStore
 
- 
createContainerInLocationDescription copied from interface:BlobStoreCreates a namespace for your blobs A container is a namespace for your objects. Depending on the service, the scope can be global, identity, or sub-identity scoped. For example, in Amazon S3, containers are called buckets, and they must be uniquely named such that no-one else in the world conflicts. In other blobstores, the naming convention of the container is less strict. All blobstores allow you to list your containers and also the contents within them. These contents can either be blobs, folders, or virtual paths.- Specified by:
- createContainerInLocationin interface- BlobStore
- Parameters:
- location- some blobstores allow you to specify a location, such as US-EAST, for where this container will exist. null will choose a default location
- container- namespace. Typically constrained to lowercase alpha-numeric and hyphens.
- Returns:
- true if the container was created, false if it already existed.
 
- 
createContainerInLocationpublic boolean createContainerInLocation(Location location, String container, CreateContainerOptions options) - Specified by:
- createContainerInLocationin interface- BlobStore
- Parameters:
- options- controls default access control
- See Also:
 
- 
getContainerAccess- Specified by:
- getContainerAccessin interface- BlobStore
 
- 
setContainerAccess- Specified by:
- setContainerAccessin interface- BlobStore
 
- 
listDescription copied from interface:BlobStoreLists all resources in a container non-recursive.
- 
listDescription copied from interface:BlobStoreLikeBlobStore.list(String)except you can control the size, recursion, and context of the list usingoptions
- 
blobExistsDescription copied from interface:BlobStoreDetermines if a blob exists- Specified by:
- blobExistsin interface- BlobStore
- Parameters:
- container- container where the blob resides
 
- 
putBlobDescription copied from interface:BlobStoreAdds aBlobrepresenting the data at locationcontainer/blob.metadata.name
- 
putBlobDescription copied from interface:BlobStoreAdds aBlobrepresenting the data at locationcontainer/blob.metadata.nameoptions using multipart strategies.
- 
copyBlobpublic String copyBlob(String fromContainer, String fromName, String toContainer, String toName, CopyOptions options) Description copied from interface:BlobStoreCopy blob from one container to another. Some providers implement this more efficiently than corresponding getBlob and putBlob operations. Note: options are currently ignored
- 
blobMetadataDescription copied from interface:BlobStoreRetrieves the metadata of aBlobat locationcontainer/name- Specified by:
- blobMetadatain interface- BlobStore
- Parameters:
- container- container where this exists.
- name- fully qualified name relative to the container.
- Returns:
- null if name isn't present or the blob you intended to receive.
 
- 
getBlobDescription copied from interface:BlobStoreRetrieves aBlobrepresenting the data at locationcontainer/name
- 
getBlobDescription copied from interface:BlobStoreRetrieves aBlobrepresenting the data at locationcontainer/name
- 
removeBlobDescription copied from interface:BlobStoreDeletes aBlobrepresenting the data at locationcontainer/name- Specified by:
- removeBlobin interface- BlobStore
- Parameters:
- container- container where this exists.
- name- fully qualified name relative to the container.
 
- 
removeBlobsDelete multiple single-part objects. Note that this does not remove the subobjects of a multi-part upload.- Specified by:
- removeBlobsin interface- BlobStore
- Parameters:
- container- container where this exists.
- names- fully qualified names relative to the container.
 
- 
getBlobAccess- Specified by:
- getBlobAccessin interface- BlobStore
 
- 
setBlobAccess- Specified by:
- setBlobAccessin interface- BlobStore
 
- 
getContext- Specified by:
- getContextin interface- BlobStore
- Returns:
- a reference to the context that created this BlobStore.
 
- 
blobBuilder- Specified by:
- blobBuilderin interface- BlobStore
- Returns:
- builder for creating new Blobs
 
- 
directoryExistsDescription copied from interface:BlobStoreDetermines if a directory exists- Specified by:
- directoryExistsin interface- BlobStore
- Parameters:
- containerName- container where the directory resides
- directory- full path to the directory
 
- 
createDirectoryDescription copied from interface:BlobStoreCreates a folder or a directory marker depending on the service- Specified by:
- createDirectoryin interface- BlobStore
- Parameters:
- containerName- container to create the directory in
- directory- full path to the directory
 
- 
deleteDirectoryDescription copied from interface:BlobStoreDeletes a folder or a directory marker depending on the service- Specified by:
- deleteDirectoryin interface- BlobStore
 
- 
countBlobs- Specified by:
- countBlobsin interface- BlobStore
- Returns:
- a count of all blobs in the container, excluding directory markers
 
- 
initiateMultipartUploadpublic MultipartUpload initiateMultipartUpload(String container, BlobMetadata blobMetadata, PutOptions options) - Specified by:
- initiateMultipartUploadin interface- BlobStore
 
- 
abortMultipartUpload- Specified by:
- abortMultipartUploadin interface- BlobStore
 
- 
completeMultipartUpload- Specified by:
- completeMultipartUploadin interface- BlobStore
 
- 
uploadMultipartPart- Specified by:
- uploadMultipartPartin interface- BlobStore
 
- 
listMultipartUpload- Specified by:
- listMultipartUploadin interface- BlobStore
 
- 
listMultipartUploads- Specified by:
- listMultipartUploadsin interface- BlobStore
 
- 
getMinimumMultipartPartSizepublic long getMinimumMultipartPartSize()- Specified by:
- getMinimumMultipartPartSizein interface- BlobStore
 
- 
getMaximumMultipartPartSizepublic long getMaximumMultipartPartSize()- Specified by:
- getMaximumMultipartPartSizein interface- BlobStore
 
- 
getMaximumNumberOfPartspublic int getMaximumNumberOfParts()- Specified by:
- getMaximumNumberOfPartsin interface- BlobStore
 
- 
clearContainerDescription copied from interface:BlobStoreThis will delete the contents of a container at its root path without deleting the container- Specified by:
- clearContainerin interface- BlobStore
- Parameters:
- containerName- what to clear
 
- 
clearContainerDescription copied from interface:BlobStoreLikeBlobStore.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- BlobStore
- Parameters:
- containerName- what to clear
- options- recursion and path to clear
 
- 
deleteContainerDescription copied from interface:BlobStoreThis will delete everything inside a container recursively.- Specified by:
- deleteContainerin interface- BlobStore
- Parameters:
- container- what to delete
 
- 
deleteContainerIfEmptyDescription copied from interface:BlobStoreDeletes a container if it is empty.- Specified by:
- deleteContainerIfEmptyin interface- BlobStore
- Parameters:
- container- name of the container to delete
- Returns:
- true if the container was deleted or does not exist
 
- 
toBlobMetadataprotected com.google.common.base.Function<SwiftObject,MutableBlobMetadata> toBlobMetadata(String container) 
- 
countBlobs- Specified by:
- countBlobsin interface- BlobStore
- Returns:
- a count of all blobs that are in a listing constrained by the options specified, excluding directory markers
 
- 
putMultipartBlobUpload using a user-provided executor, or the jclouds userExecutor- Parameters:
- container-
- blob-
- overrides-
- Returns:
- the multipart blob etag
 
- 
putMultipartBlob@Beta protected String putMultipartBlob(String container, Blob blob, PutOptions overrides, com.google.common.util.concurrent.ListeningExecutorService executor) 
- 
downloadBlob- Specified by:
- downloadBlobin interface- BlobStore
 
- 
downloadBlob@Beta public void downloadBlob(String container, String name, File destination, ExecutorService executor) - Specified by:
- downloadBlobin interface- BlobStore
 
- 
streamBlob- Specified by:
- streamBlobin interface- BlobStore
 
- 
streamBlob- Specified by:
- streamBlobin interface- BlobStore
 
 
-