Class GCSFileIO
- java.lang.Object
- 
- org.apache.iceberg.gcp.gcs.GCSFileIO
 
- 
- All Implemented Interfaces:
- java.io.Closeable,- java.io.Serializable,- java.lang.AutoCloseable,- DelegateFileIO,- FileIO,- SupportsBulkOperations,- SupportsPrefixOperations
 
 public class GCSFileIO extends java.lang.Object implements DelegateFileIO FileIO Implementation backed by Google Cloud Storage (GCS)Locations follow the conventions used by BlobId.fromGsUtilUrithat follow the conventiongs://<bucket>/<blob_path>- See Also:
- Serialized Form
 
- 
- 
Constructor SummaryConstructors Constructor Description GCSFileIO()No-arg constructor to load the FileIO dynamically.GCSFileIO(SerializableSupplier<com.google.cloud.storage.Storage> storageSupplier, GCPProperties gcpProperties)Constructor with custom storage supplier and GCP properties.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description com.google.cloud.storage.Storageclient()voidclose()Close File IO to release underlying resources.voiddeleteFile(java.lang.String path)Delete the file at the given path.voiddeleteFiles(java.lang.Iterable<java.lang.String> pathsToDelete)Delete the files at the given paths.voiddeletePrefix(java.lang.String prefix)Delete all files under a prefix.voidinitialize(java.util.Map<java.lang.String,java.lang.String> props)Initialize File IO from catalog properties.java.lang.Iterable<FileInfo>listPrefix(java.lang.String prefix)Return an iterable of all files under a prefix.InputFilenewInputFile(java.lang.String path)Get aInputFileinstance to read bytes from the file at the given path.InputFilenewInputFile(java.lang.String path, long length)Get aInputFileinstance to read bytes from the file at the given path, with a known file length.OutputFilenewOutputFile(java.lang.String path)Get aOutputFileinstance to write bytes to the file at the given path.java.util.Map<java.lang.String,java.lang.String>properties()Returns the property map used to configure this FileIO- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.iceberg.io.FileIOdeleteFile, deleteFile
 
- 
 
- 
- 
- 
Constructor Detail- 
GCSFileIOpublic GCSFileIO() No-arg constructor to load the FileIO dynamically.All fields are initialized by calling initialize(Map)later.
 - 
GCSFileIOpublic GCSFileIO(SerializableSupplier<com.google.cloud.storage.Storage> storageSupplier, GCPProperties gcpProperties) Constructor with custom storage supplier and GCP properties.Calling initialize(Map)will overwrite information set in this constructor.- Parameters:
- storageSupplier- storage supplier
- gcpProperties- gcp properties
 
 
- 
 - 
Method Detail- 
newInputFilepublic InputFile newInputFile(java.lang.String path) Description copied from interface:FileIOGet aInputFileinstance to read bytes from the file at the given path.- Specified by:
- newInputFilein interface- FileIO
 
 - 
newInputFilepublic InputFile newInputFile(java.lang.String path, long length) Description copied from interface:FileIOGet aInputFileinstance to read bytes from the file at the given path, with a known file length.- Specified by:
- newInputFilein interface- FileIO
 
 - 
newOutputFilepublic OutputFile newOutputFile(java.lang.String path) Description copied from interface:FileIOGet aOutputFileinstance to write bytes to the file at the given path.- Specified by:
- newOutputFilein interface- FileIO
 
 - 
deleteFilepublic void deleteFile(java.lang.String path) Description copied from interface:FileIODelete the file at the given path.- Specified by:
- deleteFilein interface- FileIO
 
 - 
propertiespublic java.util.Map<java.lang.String,java.lang.String> properties() Description copied from interface:FileIOReturns the property map used to configure this FileIO- Specified by:
- propertiesin interface- FileIO
 
 - 
clientpublic com.google.cloud.storage.Storage client() 
 - 
initializepublic void initialize(java.util.Map<java.lang.String,java.lang.String> props) Description copied from interface:FileIOInitialize File IO from catalog properties.- Specified by:
- initializein interface- FileIO
- Parameters:
- props- catalog properties
 
 - 
closepublic void close() Description copied from interface:FileIOClose File IO to release underlying resources.Calling this method is only required when this FileIO instance is no longer expected to be used, and the resources it holds need to be explicitly released to avoid resource leaks. 
 - 
listPrefixpublic java.lang.Iterable<FileInfo> listPrefix(java.lang.String prefix) Description copied from interface:SupportsPrefixOperationsReturn an iterable of all files under a prefix.Hierarchical file systems (e.g. HDFS) may impose additional restrictions like the prefix must fully match a directory whereas key/value object stores may allow for arbitrary prefixes. - Specified by:
- listPrefixin interface- SupportsPrefixOperations
- Parameters:
- prefix- prefix to list
- Returns:
- iterable of file information
 
 - 
deletePrefixpublic void deletePrefix(java.lang.String prefix) Description copied from interface:SupportsPrefixOperationsDelete all files under a prefix.Hierarchical file systems (e.g. HDFS) may impose additional restrictions like the prefix must fully match a directory whereas key/value object stores may allow for arbitrary prefixes. - Specified by:
- deletePrefixin interface- SupportsPrefixOperations
- Parameters:
- prefix- prefix to delete
 
 - 
deleteFilespublic void deleteFiles(java.lang.Iterable<java.lang.String> pathsToDelete) throws BulkDeletionFailureExceptionDescription copied from interface:SupportsBulkOperationsDelete the files at the given paths.- Specified by:
- deleteFilesin interface- SupportsBulkOperations
- Parameters:
- pathsToDelete- The paths to delete
- Throws:
- BulkDeletionFailureException- in case of failure to delete at least 1 file
 
 
- 
 
-