All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.cloud.storage.contrib.nio.package-info Maven / Gradle / Ivy

/*
 * Copyright 2016 Google LLC
 *
 * 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.
 */

/**
 * Java 7 nio FileSystem client library for Google Cloud Storage.
 *
 * 

This client library allows you to easily interact with Google Cloud Storage, using Java's * standard file system API, introduced in Java 7. * *

How It Works

* * The simplest way to get started is with {@code Paths} and {@code Files}: * *
{@code
 * Path path = Paths.get(URI.create("gs://bucket/lolcat.csv"));
 * List lines = Files.readAllLines(path, StandardCharsets.UTF_8);
 * }
* *

For the complete source code see * ReadAllLines.java. * *

If you want to configure the bucket per-environment, it might make more sense to use the * {@code FileSystem} API: * *

{@code
 * FileSystem fs = FileSystems.getFileSystem(URI.create("gs://bucket"));
 * byte[] data = "hello world".getBytes(StandardCharsets.UTF_8);
 * Path path = fs.getPath("/object");
 * Files.write(path, data);
 * List lines = Files.readAllLines(path, StandardCharsets.UTF_8);
 * }
* *

For the complete source code see * GetFileSystem.java. * *

You can also use {@code InputStream} and {@code OutputStream} for streaming: * *

 *   Path path = Paths.get(URI.create("gs://bucket/lolcat.csv"));
 *   try (InputStream input = Files.newInputStream(path)) {
 *     // use input stream
 *   }
 * 
* *

For the complete source code see * CreateInputStream.java. * *

You can set various attributes using {@link * com.google.cloud.storage.contrib.nio.CloudStorageOptions CloudStorageOptions} static helpers: * *

 *   Path path = Paths.get(URI.create("gs://bucket/lolcat.csv"));
 *   Files.write(path, csvLines, StandardCharsets.UTF_8,
 *       withMimeType("text/csv; charset=UTF-8"),
 *       withoutCaching());
 * 
* *

For the complete source code see * WriteFileWithAttributes.java. * *

NOTE: Cloud Storage uses a flat namespace and therefore doesn't support real * directories. So this library supports what's known as "pseudo-directories". Any path that * includes a trailing slash, will be considered a directory. It will always be assumed to exist, * without performing any I/O. This allows you to do path manipulation in the same manner as you * would with the normal UNIX file system implementation. You can disable this feature with {@link * com.google.cloud.storage.contrib.nio.CloudStorageConfiguration#usePseudoDirectories()}. * *

Non-SPI Interface

* *

If you don't want to rely on Java SPI, which requires a META-INF file in your jar generated by * Google Auto, you can instantiate this file system directly as follows: * *

 *   CloudStorageFileSystem fs = CloudStorageFileSystem.forBucket("bucket");
 *   byte[] data = "hello world".getBytes(StandardCharsets.UTF_8);
 *   Path path = fs.getPath("/object");
 *   Files.write(path, data);
 *   data = Files.readAllBytes(path);
 * 
* *

For the complete source code see * CreateCloudStorageFileSystem.java. */ @javax.annotation.ParametersAreNonnullByDefault package com.google.cloud.storage.contrib.nio;





© 2015 - 2025 Weber Informatics LLC | Privacy Policy