public class GcsUtil
extends java.lang.Object
| Modifier and Type | Class and Description | 
|---|---|
| static class  | GcsUtil.CreateOptions | 
| static class  | GcsUtil.GcsCountersOptions | 
| static class  | GcsUtil.GcsUtilFactoryThis is a  DefaultValueFactoryable to create aGcsUtilusing any transport
 flags specified on thePipelineOptions. | 
| static class  | GcsUtil.StorageObjectOrIOExceptionA class that holds either a  StorageObjector anIOException. | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | bucketAccessible(GcsPath path)Returns whether the GCS bucket exists and is accessible. | 
| long | bucketOwner(GcsPath path)Returns the project number of the project which owns this bucket. | 
| void | copy(java.lang.Iterable<java.lang.String> srcFilenames,
    java.lang.Iterable<java.lang.String> destFilenames) | 
| java.nio.channels.WritableByteChannel | create(GcsPath path,
      GcsUtil.CreateOptions options)Creates an object in GCS and prepares for uploading its contents. | 
| java.nio.channels.WritableByteChannel | create(GcsPath path,
      java.lang.String type)Deprecated. 
 Use  create(GcsPath, CreateOptions)instead. | 
| java.nio.channels.WritableByteChannel | create(GcsPath path,
      java.lang.String type,
      java.lang.Integer uploadBufferSizeBytes)Deprecated. 
 Use  create(GcsPath, CreateOptions)instead. | 
| void | createBucket(java.lang.String projectId,
            Bucket bucket)Creates a  Bucketunder the specified project in Cloud Storage or propagates an
 exception. | 
| java.util.List<GcsPath> | expand(GcsPath gcsPattern)Expands a pattern into matched paths. | 
| long | fileSize(GcsPath path)Returns the file size from GCS or throws  FileNotFoundExceptionif the resource does not
 exist. | 
| @Nullable Bucket | getBucket(GcsPath path)Get the  Bucketfrom Cloud Storage path or propagates an exception. | 
| static java.lang.String | getNonWildcardPrefix(java.lang.String globExp)Returns the prefix portion of the glob that doesn't contain wildcards. | 
| StorageObject | getObject(GcsPath gcsPath)Returns the  StorageObjectfor the givenGcsPath. | 
| java.util.List<GcsUtil.StorageObjectOrIOException> | getObjects(java.util.List<GcsPath> gcsPaths)Returns  StorageObjectOrIOExceptionsfor the givenGcsPaths. | 
| static boolean | isWildcard(GcsPath spec)Returns true if the given  speccontains wildcard. | 
| Objects | listObjects(java.lang.String bucket,
           java.lang.String prefix,
           @Nullable java.lang.String pageToken) | 
| Objects | listObjects(java.lang.String bucket,
           java.lang.String prefix,
           @Nullable java.lang.String pageToken,
           @Nullable java.lang.String delimiter) | 
| java.nio.channels.SeekableByteChannel | open(GcsPath path)Opens an object in GCS. | 
| void | remove(java.util.Collection<java.lang.String> filenames) | 
| void | removeBucket(Bucket bucket)Remove an empty  Bucketin Cloud Storage or propagates an exception. | 
| void | rename(java.lang.Iterable<java.lang.String> srcFilenames,
      java.lang.Iterable<java.lang.String> destFilenames,
      MoveOptions... moveOptions) | 
| protected void | setBatchRequestSupplier(java.util.function.Supplier<org.apache.beam.sdk.extensions.gcp.util.GcsUtil.BatchInterface> supplier) | 
| protected void | setStorageClient(Storage storageClient) | 
| void | verifyBucketAccessible(GcsPath path)Checks whether the GCS bucket exists. | 
public static java.lang.String getNonWildcardPrefix(java.lang.String globExp)
public static boolean isWildcard(GcsPath spec)
spec contains wildcard.protected void setStorageClient(Storage storageClient)
protected void setBatchRequestSupplier(java.util.function.Supplier<org.apache.beam.sdk.extensions.gcp.util.GcsUtil.BatchInterface> supplier)
public java.util.List<GcsPath> expand(GcsPath gcsPattern) throws java.io.IOException
java.io.IOExceptionpublic long fileSize(GcsPath path) throws java.io.IOException
FileNotFoundException if the resource does not
 exist.java.io.IOExceptionpublic StorageObject getObject(GcsPath gcsPath) throws java.io.IOException
StorageObject for the given GcsPath.java.io.IOExceptionpublic java.util.List<GcsUtil.StorageObjectOrIOException> getObjects(java.util.List<GcsPath> gcsPaths) throws java.io.IOException
StorageObjectOrIOExceptions for the given GcsPaths.java.io.IOExceptionpublic Objects listObjects(java.lang.String bucket, java.lang.String prefix, @Nullable java.lang.String pageToken) throws java.io.IOException
java.io.IOExceptionpublic Objects listObjects(java.lang.String bucket, java.lang.String prefix, @Nullable java.lang.String pageToken, @Nullable java.lang.String delimiter) throws java.io.IOException
Objects given the bucket, prefix, pageToken.
 For more details, see https://cloud.google.com/storage/docs/json_api/v1/objects/list.
java.io.IOExceptionpublic java.nio.channels.SeekableByteChannel open(GcsPath path) throws java.io.IOException
Returns a SeekableByteChannel that provides access to data in the bucket.
path - the GCS filename to read fromjava.io.IOException@Deprecated public java.nio.channels.WritableByteChannel create(GcsPath path, java.lang.String type) throws java.io.IOException
create(GcsPath, CreateOptions) instead.java.io.IOException@Deprecated public java.nio.channels.WritableByteChannel create(GcsPath path, java.lang.String type, java.lang.Integer uploadBufferSizeBytes) throws java.io.IOException
create(GcsPath, CreateOptions) instead.java.io.IOExceptionpublic java.nio.channels.WritableByteChannel create(GcsPath path, GcsUtil.CreateOptions options) throws java.io.IOException
path - the GCS file to write tooptions - to be used for creating and configuring file uploadjava.io.IOExceptionpublic void verifyBucketAccessible(GcsPath path) throws java.io.IOException
bucketAccessible(GcsPath), but throws
 exception if the bucket is inaccessible due to permissions or does not exist.java.io.IOExceptionpublic boolean bucketAccessible(GcsPath path) throws java.io.IOException
java.io.IOExceptionpublic long bucketOwner(GcsPath path) throws java.io.IOException
java.io.IOExceptionpublic void createBucket(java.lang.String projectId,
                         Bucket bucket)
                  throws java.io.IOException
Bucket under the specified project in Cloud Storage or propagates an
 exception.java.io.IOExceptionpublic @Nullable Bucket getBucket(GcsPath path) throws java.io.IOException
Bucket from Cloud Storage path or propagates an exception.java.io.IOExceptionpublic void removeBucket(Bucket bucket) throws java.io.IOException
Bucket in Cloud Storage or propagates an exception.java.io.IOExceptionpublic void copy(java.lang.Iterable<java.lang.String> srcFilenames,
                 java.lang.Iterable<java.lang.String> destFilenames)
          throws java.io.IOException
java.io.IOExceptionpublic void rename(java.lang.Iterable<java.lang.String> srcFilenames,
                   java.lang.Iterable<java.lang.String> destFilenames,
                   MoveOptions... moveOptions)
            throws java.io.IOException
java.io.IOExceptionpublic void remove(java.util.Collection<java.lang.String> filenames)
            throws java.io.IOException
java.io.IOException