diff --git a/gcloud-java-pubsub/README.md b/gcloud-java-pubsub/README.md
new file mode 100644
index 000000000000..70393a4b7998
--- /dev/null
+++ b/gcloud-java-pubsub/README.md
@@ -0,0 +1,84 @@
+Google Cloud Java Client for Pub/Sub
+====================================
+
+Java idiomatic client for [Google Cloud Pub/Sub] (https://cloud.google.com/pubsub/).
+
+[![Build Status](https://travis-ci.org/GoogleCloudPlatform/gcloud-java.svg?branch=master)](https://travis-ci.org/GoogleCloudPlatform/gcloud-java)
+[![Coverage Status](https://coveralls.io/repos/GoogleCloudPlatform/gcloud-java/badge.svg?branch=master)](https://coveralls.io/r/GoogleCloudPlatform/gcloud-java?branch=master)
+[![Maven](https://img.shields.io/maven-central/v/com.google.gcloud/gcloud-java-pubsub.svg)]( https://img.shields.io/maven-central/v/com.google.gcloud/gcloud-java-pubsub.svg)
+
+- [Homepage] (https://googlecloudplatform.github.io/gcloud-java/)
+- [API Documentation] (http://googlecloudplatform.github.io/gcloud-java/apidocs)
+
+> Note: This client is a work-in-progress, and may occasionally
+> make backwards-incompatible changes.
+
+Quickstart
+----------
+Add this to your pom.xml file
+```xml
+
+ com.google.gcloud
+ gcloud-java-pubsub
+ 0.0.10
+
+```
+
+Example Application
+-------------------
+TODO
+
+Authentication
+--------------
+
+See the [Authentication](https://github.com/GoogleCloudPlatform/gcloud-java#authentication) section in the base directory's README.
+
+About Google Cloud Pub/Sub
+--------------------------
+
+[Google Cloud Pub/Sub][cloud-pubsub] is designed to provide reliable,
+many-to-many, asynchronous messaging between applications. Publisher
+applications can send messages to a ``topic`` and other applications can
+subscribe to that topic to receive the messages. By decoupling senders and
+receivers, Google Cloud Pub/Sub allows developers to communicate between
+independently written applications.
+
+TODO: link to docs on activating Pub/Sub, high-level documentation on
+the API, and code snippet
+
+Java Versions
+-------------
+
+Java 7 or above is required for using this client.
+
+Testing
+-------
+
+TODO
+
+Versioning
+----------
+
+This library follows [Semantic Versioning] (http://semver.org/).
+
+It is currently in major version zero (``0.y.z``), which means that anything
+may change at any time and the public API should not be considered
+stable.
+
+Contributing
+------------
+
+Contributions to this library are always welcome and highly encouraged.
+
+See [CONTRIBUTING] for more information on how to get started.
+
+License
+-------
+
+Apache 2.0 - See [LICENSE] for more information.
+
+
+[CONTRIBUTING]:https://github.com/GoogleCloudPlatform/gcloud-java/blob/master/CONTRIBUTING.md
+[LICENSE]: https://github.com/GoogleCloudPlatform/gcloud-java/blob/master/LICENSE
+
+[cloud-pubsub]: https://cloud.google.com/storage/
diff --git a/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java
new file mode 100644
index 000000000000..886945e0504e
--- /dev/null
+++ b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java
@@ -0,0 +1,533 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.grpc.ApiCallable;
+import com.google.api.gax.protobuf.PathTemplate;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.DeleteTopicRequest;
+import com.google.pubsub.v1.GetTopicRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsResponse;
+import com.google.pubsub.v1.ListTopicsRequest;
+import com.google.pubsub.v1.ListTopicsResponse;
+import com.google.pubsub.v1.PublishRequest;
+import com.google.pubsub.v1.PublishResponse;
+import com.google.pubsub.v1.PubsubMessage;
+import com.google.pubsub.v1.Topic;
+import io.grpc.ManagedChannel;
+import java.io.Closeable;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND SERVICE - see instructions at the top of the file for editing.
+/**
+ * Service Description: The service that an application uses to manipulate topics, and to send
+ * messages to a topic.
+ *
+ *
+ *
+ */
+@javax.annotation.Generated("by GAPIC")
+public class PublisherApi implements AutoCloseable {
+ private final ManagedChannel channel;
+ private final List closeables = new ArrayList<>();
+
+ private final ApiCallable createTopicCallable;
+ private final ApiCallable publishCallable;
+ private final ApiCallable getTopicCallable;
+ private final ApiCallable listTopicsCallable;
+ private final ApiCallable> listTopicsIterableCallable;
+ private final ApiCallable
+ listTopicSubscriptionsCallable;
+ private final ApiCallable>
+ listTopicSubscriptionsIterableCallable;
+ private final ApiCallable deleteTopicCallable;
+
+ private static final PathTemplate PROJECT_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}");
+
+ private static final PathTemplate TOPIC_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}/topics/{topic}");
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a project resource.
+ *
+ *
+ *
+ */
+ public static final String formatProjectName(String project) {
+ return PROJECT_PATH_TEMPLATE.instantiate("project", project);
+ }
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a topic resource.
+ *
+ *
+ *
+ */
+ public static final String formatTopicName(String project, String topic) {
+ return TOPIC_PATH_TEMPLATE.instantiate("project", project, "topic", topic);
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a project resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromProjectName(String projectName) {
+ return PROJECT_PATH_TEMPLATE.parse(projectName).get("project");
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a topic resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromTopicName(String topicName) {
+ return TOPIC_PATH_TEMPLATE.parse(topicName).get("project");
+ }
+
+ /**
+ * Parses the topic from the given fully-qualified path which
+ * represents a topic resource.
+ *
+ *
+ *
+ */
+ public static final String parseTopicFromTopicName(String topicName) {
+ return TOPIC_PATH_TEMPLATE.parse(topicName).get("topic");
+ }
+
+ /**
+ * Constructs an instance of PublisherApi with default settings.
+ *
+ *
+ *
+ */
+ public static final PublisherApi defaultInstance() throws IOException {
+ return create(PublisherSettings.defaultInstance());
+ }
+
+ /**
+ * Constructs an instance of PublisherApi, using the given settings.
+ * The channels are created based on the settings passed in, or defaults for any
+ * settings that are not set.
+ *
+ *
+ *
+ */
+ public static final PublisherApi create(PublisherSettings settings) throws IOException {
+ return new PublisherApi(settings);
+ }
+
+ /**
+ * Constructs an instance of PublisherApi, using the given settings.
+ * This is protected so that it easy to make a subclass, but otherwise, the static
+ * factory methods should be preferred.
+ *
+ *
+ *
+ */
+ protected PublisherApi(PublisherSettings settings) throws IOException {
+ this.channel = settings.getChannel();
+
+ this.createTopicCallable = ApiCallable.create(settings.createTopicSettings(), settings);
+ this.publishCallable = ApiCallable.create(settings.publishSettings(), settings);
+ if (settings.publishSettings().getBundlerFactory() != null) {
+ closeables.add(settings.publishSettings().getBundlerFactory());
+ }
+ this.getTopicCallable = ApiCallable.create(settings.getTopicSettings(), settings);
+ this.listTopicsCallable = ApiCallable.create(settings.listTopicsSettings(), settings);
+ this.listTopicsIterableCallable =
+ ApiCallable.createIterable(settings.listTopicsSettings(), settings);
+ this.listTopicSubscriptionsCallable =
+ ApiCallable.create(settings.listTopicSubscriptionsSettings(), settings);
+ this.listTopicSubscriptionsIterableCallable =
+ ApiCallable.createIterable(settings.listTopicSubscriptionsSettings(), settings);
+ this.deleteTopicCallable = ApiCallable.create(settings.deleteTopicSettings(), settings);
+
+ if (settings.shouldAutoCloseChannel()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ channel.shutdown();
+ }
+ });
+ }
+ }
+
+ // ----- createTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ *
+ * @param name The name of the topic. It must have the format
+ * `"projects/{project}/topics/{topic}"`. `{topic}` must start with a letter,
+ * and contain only letters (`[A-Za-z]`), numbers (`[0-9]`), dashes (`-`),
+ * underscores (`_`), periods (`.`), tildes (`~`), plus (`+`) or percent
+ * signs (`%`). It must be between 3 and 255 characters in length, and it
+ * must not start with `"goog"`.
+ * @throws ApiException if the remote call fails
+ */
+ public final Topic createTopic(String name) {
+ Topic request = Topic.newBuilder().setName(name).build();
+
+ return createTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Topic createTopic(Topic request) {
+ return createTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable createTopicCallable() {
+ return createTopicCallable;
+ }
+
+ // ----- publish -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ *
+ * @param topic The messages in the request will be published on this topic.
+ * @param messages The messages to publish.
+ * @throws ApiException if the remote call fails
+ */
+ public final PublishResponse publish(String topic, List messages) {
+ PublishRequest request =
+ PublishRequest.newBuilder().setTopic(topic).addAllMessages(messages).build();
+
+ return publish(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public PublishResponse publish(PublishRequest request) {
+ return publishCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable publishCallable() {
+ return publishCallable;
+ }
+
+ // ----- getTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ *
+ * @param topic The name of the topic to get.
+ * @throws ApiException if the remote call fails
+ */
+ public final Topic getTopic(String topic) {
+ GetTopicRequest request = GetTopicRequest.newBuilder().setTopic(topic).build();
+
+ return getTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Topic getTopic(GetTopicRequest request) {
+ return getTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable getTopicCallable() {
+ return getTopicCallable;
+ }
+
+ // ----- listTopics -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ *
+ * @param project The name of the cloud project that topics belong to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopics(String project) {
+ ListTopicsRequest request = ListTopicsRequest.newBuilder().setProject(project).build();
+ return listTopics(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopics(ListTopicsRequest request) {
+ return listTopicsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable> listTopicsIterableCallable() {
+ return listTopicsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable listTopicsCallable() {
+ return listTopicsCallable;
+ }
+
+ // ----- listTopicSubscriptions -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ *
+ * @param topic The name of the topic that subscriptions are attached to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopicSubscriptions(String topic) {
+ ListTopicSubscriptionsRequest request =
+ ListTopicSubscriptionsRequest.newBuilder().setTopic(topic).build();
+ return listTopicSubscriptions(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopicSubscriptions(ListTopicSubscriptionsRequest request) {
+ return listTopicSubscriptionsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable>
+ listTopicSubscriptionsIterableCallable() {
+ return listTopicSubscriptionsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable
+ listTopicSubscriptionsCallable() {
+ return listTopicSubscriptionsCallable;
+ }
+
+ // ----- deleteTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param topic Name of the topic to delete.
+ * @throws ApiException if the remote call fails
+ */
+ public final void deleteTopic(String topic) {
+ DeleteTopicRequest request = DeleteTopicRequest.newBuilder().setTopic(topic).build();
+
+ deleteTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private void deleteTopic(DeleteTopicRequest request) {
+ deleteTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable deleteTopicCallable() {
+ return deleteTopicCallable;
+ }
+
+ /**
+ * Initiates an orderly shutdown in which preexisting calls continue but new calls are immediately
+ * cancelled.
+ *
+ *
+ *
+ */
+ @Override
+ public final void close() throws Exception {
+ for (AutoCloseable closeable : closeables) {
+ closeable.close();
+ }
+ }
+
+ // ========
+ // Manually-added methods: add custom (non-generated) methods after this point.
+ // ========
+
+}
diff --git a/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java
new file mode 100644
index 000000000000..72d24404d87a
--- /dev/null
+++ b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java
@@ -0,0 +1,480 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.core.ConnectionSettings;
+import com.google.api.gax.core.RetrySettings;
+import com.google.api.gax.grpc.ApiCallSettings;
+import com.google.api.gax.grpc.BundlingCallSettings;
+import com.google.api.gax.grpc.BundlingDescriptor;
+import com.google.api.gax.grpc.BundlingSettings;
+import com.google.api.gax.grpc.PageStreamingCallSettings;
+import com.google.api.gax.grpc.PageStreamingDescriptor;
+import com.google.api.gax.grpc.RequestIssuer;
+import com.google.api.gax.grpc.ServiceApiSettings;
+import com.google.api.gax.grpc.SimpleCallSettings;
+import com.google.common.collect.ImmutableList;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Sets;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.DeleteTopicRequest;
+import com.google.pubsub.v1.GetTopicRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsResponse;
+import com.google.pubsub.v1.ListTopicsRequest;
+import com.google.pubsub.v1.ListTopicsResponse;
+import com.google.pubsub.v1.PublishRequest;
+import com.google.pubsub.v1.PublishResponse;
+import com.google.pubsub.v1.PublisherGrpc;
+import com.google.pubsub.v1.PubsubMessage;
+import com.google.pubsub.v1.Topic;
+import io.grpc.ManagedChannel;
+import io.grpc.Status;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.List;
+import java.util.concurrent.ScheduledExecutorService;
+import org.joda.time.Duration;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS - see instructions at the top of the file for editing.
+@javax.annotation.Generated("by GAPIC")
+public class PublisherSettings extends ServiceApiSettings {
+
+ /**
+ * The default address of the service.
+ *
+ *
+ *
+ */
+ public static final String DEFAULT_SERVICE_ADDRESS = "pubsub-experimental.googleapis.com";
+
+ /**
+ * The default port of the service.
+ *
+ *
+ *
+ */
+ public static final int DEFAULT_SERVICE_PORT = 443;
+
+ /**
+ * The default scopes of the service.
+ */
+ public static final ImmutableList DEFAULT_SERVICE_SCOPES =
+ ImmutableList.builder()
+ .add("https://www.googleapis.com/auth/pubsub")
+ .add("https://www.googleapis.com/auth/cloud-platform")
+ .build();
+
+ private final SimpleCallSettings createTopicSettings;
+ private final BundlingCallSettings publishSettings;
+ private final SimpleCallSettings getTopicSettings;
+ private final PageStreamingCallSettings
+ listTopicsSettings;
+
+ private final PageStreamingCallSettings<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings;
+
+ private final SimpleCallSettings deleteTopicSettings;
+
+ public SimpleCallSettings createTopicSettings() {
+ return createTopicSettings;
+ }
+
+ public BundlingCallSettings publishSettings() {
+ return publishSettings;
+ }
+
+ public SimpleCallSettings getTopicSettings() {
+ return getTopicSettings;
+ }
+
+ public PageStreamingCallSettings
+ listTopicsSettings() {
+ return listTopicsSettings;
+ }
+
+ public PageStreamingCallSettings<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings() {
+ return listTopicSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings deleteTopicSettings() {
+ return deleteTopicSettings;
+ }
+
+ public static PublisherSettings defaultInstance() throws IOException {
+ return newBuilder().build();
+ }
+
+ public static Builder newBuilder() {
+ return new Builder();
+ }
+
+ public Builder toBuilder() {
+ return new Builder(this);
+ }
+
+ private PublisherSettings(Builder settingsBuilder) throws IOException {
+ super(
+ settingsBuilder.getOrBuildChannel(),
+ settingsBuilder.shouldAutoCloseChannel(),
+ settingsBuilder.getOrBuildExecutor(),
+ settingsBuilder.getConnectionSettings(),
+ settingsBuilder.getGeneratorName(),
+ settingsBuilder.getGeneratorVersion(),
+ settingsBuilder.getClientLibName(),
+ settingsBuilder.getClientLibVersion());
+
+ createTopicSettings = settingsBuilder.createTopicSettings().build();
+ publishSettings = settingsBuilder.publishSettings().build();
+ getTopicSettings = settingsBuilder.getTopicSettings().build();
+ listTopicsSettings = settingsBuilder.listTopicsSettings().build();
+ listTopicSubscriptionsSettings = settingsBuilder.listTopicSubscriptionsSettings().build();
+ deleteTopicSettings = settingsBuilder.deleteTopicSettings().build();
+ }
+
+ private static PageStreamingDescriptor
+ LIST_TOPICS_PAGE_STR_DESC =
+ new PageStreamingDescriptor() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListTopicsRequest injectToken(ListTopicsRequest payload, Object token) {
+ return ListTopicsRequest.newBuilder(payload).setPageToken((String) token).build();
+ }
+
+ @Override
+ public Object extractNextToken(ListTopicsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListTopicsResponse payload) {
+ return payload.getTopicsList();
+ }
+ };
+
+ private static PageStreamingDescriptor<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ LIST_TOPIC_SUBSCRIPTIONS_PAGE_STR_DESC =
+ new PageStreamingDescriptor<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListTopicSubscriptionsRequest injectToken(
+ ListTopicSubscriptionsRequest payload, Object token) {
+ return ListTopicSubscriptionsRequest.newBuilder(payload)
+ .setPageToken((String) token)
+ .build();
+ }
+
+ @Override
+ public Object extractNextToken(ListTopicSubscriptionsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListTopicSubscriptionsResponse payload) {
+ return payload.getSubscriptionsList();
+ }
+ };
+
+ private static BundlingDescriptor PUBLISH_BUNDLING_DESC =
+ new BundlingDescriptor() {
+ @Override
+ public String getBundlePartitionKey(PublishRequest request) {
+ return request.getTopic();
+ }
+
+ @Override
+ public PublishRequest mergeRequests(Collection requests) {
+ PublishRequest firstRequest = requests.iterator().next();
+
+ List elements = new ArrayList<>();
+ for (PublishRequest request : requests) {
+ elements.addAll(request.getMessagesList());
+ }
+
+ PublishRequest bundleRequest =
+ PublishRequest.newBuilder()
+ .setTopic(firstRequest.getTopic())
+ .addAllMessages(elements)
+ .build();
+ return bundleRequest;
+ }
+
+ @Override
+ public void splitResponse(
+ PublishResponse bundleResponse,
+ Collection extends RequestIssuer> bundle) {
+ int bundleMessageIndex = 0;
+ for (RequestIssuer responder : bundle) {
+ List subresponseElements = new ArrayList<>();
+ int subresponseCount = responder.getRequest().getMessagesCount();
+ for (int i = 0; i < subresponseCount; i++) {
+ subresponseElements.add(bundleResponse.getMessageIds(bundleMessageIndex));
+ bundleMessageIndex += 1;
+ }
+ PublishResponse response =
+ PublishResponse.newBuilder().addAllMessageIds(subresponseElements).build();
+ responder.setResponse(response);
+ }
+ }
+
+ @Override
+ public void splitException(
+ Throwable throwable,
+ Collection extends RequestIssuer> bundle) {
+ for (RequestIssuer responder : bundle) {
+ responder.setException(throwable);
+ }
+ }
+
+ @Override
+ public long countElements(PublishRequest request) {
+ return request.getMessagesCount();
+ }
+
+ @Override
+ public long countBytes(PublishRequest request) {
+ return request.getSerializedSize();
+ }
+ };
+
+ public static class Builder extends ServiceApiSettings.Builder {
+ private final ImmutableList methodSettingsBuilders;
+
+ private SimpleCallSettings.Builder createTopicSettings;
+ private BundlingCallSettings.Builder publishSettings;
+ private SimpleCallSettings.Builder getTopicSettings;
+ private PageStreamingCallSettings.Builder
+ listTopicsSettings;
+ private PageStreamingCallSettings.Builder<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings;
+ private SimpleCallSettings.Builder deleteTopicSettings;
+
+ private static final ImmutableMap> RETRYABLE_CODE_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder> definitions = ImmutableMap.builder();
+ definitions.put(
+ "idempotent",
+ Sets.immutableEnumSet(
+ Lists.newArrayList(
+ Status.Code.DEADLINE_EXCEEDED, Status.Code.UNAVAILABLE)));
+ definitions.put("non_idempotent", Sets.immutableEnumSet(Lists.newArrayList()));
+ RETRYABLE_CODE_DEFINITIONS = definitions.build();
+ }
+
+ private static final ImmutableMap RETRY_PARAM_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder definitions = ImmutableMap.builder();
+ RetrySettings.Builder settingsBuilder = null;
+ settingsBuilder =
+ RetrySettings.newBuilder()
+ .setInitialRetryDelay(Duration.millis(100L))
+ .setRetryDelayMultiplier(1.2)
+ .setMaxRetryDelay(Duration.millis(1000L))
+ .setInitialRpcTimeout(Duration.millis(2000L))
+ .setRpcTimeoutMultiplier(1.5)
+ .setMaxRpcTimeout(Duration.millis(30000L))
+ .setTotalTimeout(Duration.millis(45000L));
+ definitions.put("default", settingsBuilder);
+ RETRY_PARAM_DEFINITIONS = definitions.build();
+ }
+
+ private Builder() {
+ super(
+ ConnectionSettings.builder()
+ .setServiceAddress(DEFAULT_SERVICE_ADDRESS)
+ .setPort(DEFAULT_SERVICE_PORT)
+ .provideCredentialsWith(DEFAULT_SERVICE_SCOPES)
+ .build());
+
+ createTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_CREATE_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ BundlingSettings.Builder publishBundlingSettingsBuilder =
+ BundlingSettings.newBuilder()
+ .setElementCountThreshold(800)
+ .setElementCountLimit(1000)
+ .setRequestByteThreshold(8388608)
+ .setRequestByteLimit(10485760)
+ .setDelayThreshold(Duration.millis(100))
+ .setBlockingCallCountThreshold(1);
+ publishSettings =
+ BundlingCallSettings.newBuilder(PublisherGrpc.METHOD_PUBLISH, PUBLISH_BUNDLING_DESC)
+ .setBundlingSettingsBuilder(publishBundlingSettingsBuilder)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ getTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_GET_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listTopicsSettings =
+ PageStreamingCallSettings.newBuilder(
+ PublisherGrpc.METHOD_LIST_TOPICS, LIST_TOPICS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listTopicSubscriptionsSettings =
+ PageStreamingCallSettings.newBuilder(
+ PublisherGrpc.METHOD_LIST_TOPIC_SUBSCRIPTIONS,
+ LIST_TOPIC_SUBSCRIPTIONS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ deleteTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_DELETE_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createTopicSettings,
+ publishSettings,
+ getTopicSettings,
+ listTopicsSettings,
+ listTopicSubscriptionsSettings,
+ deleteTopicSettings);
+ }
+
+ private Builder(PublisherSettings settings) {
+ super(settings);
+
+ createTopicSettings = settings.createTopicSettings.toBuilder();
+ publishSettings = settings.publishSettings.toBuilder();
+ getTopicSettings = settings.getTopicSettings.toBuilder();
+ listTopicsSettings = settings.listTopicsSettings.toBuilder();
+ listTopicSubscriptionsSettings = settings.listTopicSubscriptionsSettings.toBuilder();
+ deleteTopicSettings = settings.deleteTopicSettings.toBuilder();
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createTopicSettings,
+ publishSettings,
+ getTopicSettings,
+ listTopicsSettings,
+ listTopicSubscriptionsSettings,
+ deleteTopicSettings);
+ }
+
+ @Override
+ public Builder provideChannelWith(ManagedChannel channel, boolean shouldAutoClose) {
+ super.provideChannelWith(channel, shouldAutoClose);
+ return this;
+ }
+
+ @Override
+ public Builder provideChannelWith(ConnectionSettings settings) {
+ super.provideChannelWith(settings);
+ return this;
+ }
+
+ @Override
+ public Builder setExecutor(ScheduledExecutorService executor) {
+ super.setExecutor(executor);
+ return this;
+ }
+
+ @Override
+ public Builder setGeneratorHeader(String name, String version) {
+ super.setGeneratorHeader(name, version);
+ return this;
+ }
+
+ @Override
+ public Builder setClientLibHeader(String name, String version) {
+ super.setClientLibHeader(name, version);
+ return this;
+ }
+
+ public Builder applyToAllApiMethods(ApiCallSettings.Builder apiCallSettings) throws Exception {
+ super.applyToAllApiMethods(methodSettingsBuilders, apiCallSettings);
+ return this;
+ }
+
+ public SimpleCallSettings.Builder createTopicSettings() {
+ return createTopicSettings;
+ }
+
+ public BundlingCallSettings.Builder publishSettings() {
+ return publishSettings;
+ }
+
+ public SimpleCallSettings.Builder getTopicSettings() {
+ return getTopicSettings;
+ }
+
+ public PageStreamingCallSettings.Builder
+ listTopicsSettings() {
+ return listTopicsSettings;
+ }
+
+ public PageStreamingCallSettings.Builder<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings() {
+ return listTopicSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings.Builder deleteTopicSettings() {
+ return deleteTopicSettings;
+ }
+
+ @Override
+ public PublisherSettings build() throws IOException {
+ return new PublisherSettings(this);
+ }
+ }
+}
diff --git a/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java
new file mode 100644
index 000000000000..2bfafd62ef0e
--- /dev/null
+++ b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java
@@ -0,0 +1,759 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.grpc.ApiCallable;
+import com.google.api.gax.protobuf.PathTemplate;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.AcknowledgeRequest;
+import com.google.pubsub.v1.DeleteSubscriptionRequest;
+import com.google.pubsub.v1.GetSubscriptionRequest;
+import com.google.pubsub.v1.ListSubscriptionsRequest;
+import com.google.pubsub.v1.ListSubscriptionsResponse;
+import com.google.pubsub.v1.ModifyAckDeadlineRequest;
+import com.google.pubsub.v1.ModifyPushConfigRequest;
+import com.google.pubsub.v1.PullRequest;
+import com.google.pubsub.v1.PullResponse;
+import com.google.pubsub.v1.PushConfig;
+import com.google.pubsub.v1.Subscription;
+import io.grpc.ManagedChannel;
+import java.io.Closeable;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND SERVICE - see instructions at the top of the file for editing.
+/**
+ * Service Description: The service that an application uses to manipulate subscriptions and to
+ * consume messages from a subscription via the `Pull` method.
+ *
+ *
+ *
+ */
+@javax.annotation.Generated("by GAPIC")
+public class SubscriberApi implements AutoCloseable {
+ private final ManagedChannel channel;
+ private final List closeables = new ArrayList<>();
+
+ private final ApiCallable createSubscriptionCallable;
+ private final ApiCallable getSubscriptionCallable;
+ private final ApiCallable
+ listSubscriptionsCallable;
+ private final ApiCallable>
+ listSubscriptionsIterableCallable;
+ private final ApiCallable deleteSubscriptionCallable;
+ private final ApiCallable modifyAckDeadlineCallable;
+ private final ApiCallable acknowledgeCallable;
+ private final ApiCallable pullCallable;
+ private final ApiCallable modifyPushConfigCallable;
+
+ private static final PathTemplate PROJECT_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}");
+
+ private static final PathTemplate SUBSCRIPTION_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}/subscriptions/{subscription}");
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a project resource.
+ *
+ *
+ *
+ */
+ public static final String formatProjectName(String project) {
+ return PROJECT_PATH_TEMPLATE.instantiate("project", project);
+ }
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String formatSubscriptionName(String project, String subscription) {
+ return SUBSCRIPTION_PATH_TEMPLATE.instantiate("project", project, "subscription", subscription);
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a project resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromProjectName(String projectName) {
+ return PROJECT_PATH_TEMPLATE.parse(projectName).get("project");
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromSubscriptionName(String subscriptionName) {
+ return SUBSCRIPTION_PATH_TEMPLATE.parse(subscriptionName).get("project");
+ }
+
+ /**
+ * Parses the subscription from the given fully-qualified path which
+ * represents a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String parseSubscriptionFromSubscriptionName(String subscriptionName) {
+ return SUBSCRIPTION_PATH_TEMPLATE.parse(subscriptionName).get("subscription");
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi with default settings.
+ *
+ *
+ *
+ */
+ public static final SubscriberApi defaultInstance() throws IOException {
+ return create(SubscriberSettings.defaultInstance());
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi, using the given settings.
+ * The channels are created based on the settings passed in, or defaults for any
+ * settings that are not set.
+ *
+ *
+ *
+ */
+ public static final SubscriberApi create(SubscriberSettings settings) throws IOException {
+ return new SubscriberApi(settings);
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi, using the given settings.
+ * This is protected so that it easy to make a subclass, but otherwise, the static
+ * factory methods should be preferred.
+ *
+ *
+ *
+ */
+ protected SubscriberApi(SubscriberSettings settings) throws IOException {
+ this.channel = settings.getChannel();
+
+ this.createSubscriptionCallable =
+ ApiCallable.create(settings.createSubscriptionSettings(), settings);
+ this.getSubscriptionCallable = ApiCallable.create(settings.getSubscriptionSettings(), settings);
+ this.listSubscriptionsCallable =
+ ApiCallable.create(settings.listSubscriptionsSettings(), settings);
+ this.listSubscriptionsIterableCallable =
+ ApiCallable.createIterable(settings.listSubscriptionsSettings(), settings);
+ this.deleteSubscriptionCallable =
+ ApiCallable.create(settings.deleteSubscriptionSettings(), settings);
+ this.modifyAckDeadlineCallable =
+ ApiCallable.create(settings.modifyAckDeadlineSettings(), settings);
+ this.acknowledgeCallable = ApiCallable.create(settings.acknowledgeSettings(), settings);
+ this.pullCallable = ApiCallable.create(settings.pullSettings(), settings);
+ this.modifyPushConfigCallable =
+ ApiCallable.create(settings.modifyPushConfigSettings(), settings);
+
+ if (settings.shouldAutoCloseChannel()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ channel.shutdown();
+ }
+ });
+ }
+ }
+
+ // ----- createSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ *
+ * @param name The name of the subscription. It must have the format
+ * `"projects/{project}/subscriptions/{subscription}"`. `{subscription}` must
+ * start with a letter, and contain only letters (`[A-Za-z]`), numbers
+ * (`[0-9]`), dashes (`-`), underscores (`_`), periods (`.`), tildes (`~`),
+ * plus (`+`) or percent signs (`%`). It must be between 3 and 255 characters
+ * in length, and it must not start with `"goog"`.
+ * @param topic The name of the topic from which this subscription is receiving messages.
+ * @param pushConfig If push delivery is used with this subscription, this field is
+ * used to configure it. An empty `pushConfig` signifies that the subscriber
+ * will pull and ack messages using API methods.
+ * @param ackDeadlineSeconds This value is the maximum time after a subscriber receives a message
+ * before the subscriber should acknowledge the message. After message
+ * delivery but before the ack deadline expires and before the message is
+ * acknowledged, it is an outstanding message and will not be delivered
+ * again during that time (on a best-effort basis).
+ *
+ * For pull subscriptions, this value is used as the initial value for the ack
+ * deadline. To override this value for a given message, call
+ * `ModifyAckDeadline` with the corresponding `ack_id` if using
+ * pull.
+ *
+ * For push delivery, this value is also used to set the request timeout for
+ * the call to the push endpoint.
+ *
+ * If the subscriber never acknowledges the message, the Pub/Sub
+ * system will eventually redeliver the message.
+ *
+ * If this parameter is not set, the default value of 10 seconds is used.
+ * @throws ApiException if the remote call fails
+ */
+ public final Subscription createSubscription(
+ String name, String topic, PushConfig pushConfig, int ackDeadlineSeconds) {
+ Subscription request =
+ Subscription.newBuilder()
+ .setName(name)
+ .setTopic(topic)
+ .setPushConfig(pushConfig)
+ .setAckDeadlineSeconds(ackDeadlineSeconds)
+ .build();
+
+ return createSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public Subscription createSubscription(Subscription request) {
+ return createSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable createSubscriptionCallable() {
+ return createSubscriptionCallable;
+ }
+
+ // ----- getSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription to get.
+ * @throws ApiException if the remote call fails
+ */
+ public final Subscription getSubscription(String subscription) {
+ GetSubscriptionRequest request =
+ GetSubscriptionRequest.newBuilder().setSubscription(subscription).build();
+
+ return getSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Subscription getSubscription(GetSubscriptionRequest request) {
+ return getSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable getSubscriptionCallable() {
+ return getSubscriptionCallable;
+ }
+
+ // ----- listSubscriptions -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param project The name of the cloud project that subscriptions belong to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listSubscriptions(String project) {
+ ListSubscriptionsRequest request =
+ ListSubscriptionsRequest.newBuilder().setProject(project).build();
+ return listSubscriptions(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listSubscriptions(ListSubscriptionsRequest request) {
+ return listSubscriptionsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable>
+ listSubscriptionsIterableCallable() {
+ return listSubscriptionsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable
+ listSubscriptionsCallable() {
+ return listSubscriptionsCallable;
+ }
+
+ // ----- deleteSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription to delete.
+ * @throws ApiException if the remote call fails
+ */
+ public final void deleteSubscription(String subscription) {
+ DeleteSubscriptionRequest request =
+ DeleteSubscriptionRequest.newBuilder().setSubscription(subscription).build();
+
+ deleteSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private void deleteSubscription(DeleteSubscriptionRequest request) {
+ deleteSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable deleteSubscriptionCallable() {
+ return deleteSubscriptionCallable;
+ }
+
+ // ----- modifyAckDeadline -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription.
+ * @param ackIds List of acknowledgment IDs.
+ * @param ackDeadlineSeconds The new ack deadline with respect to the time this request was sent to
+ * the Pub/Sub system. Must be >= 0. For example, if the value is 10, the new
+ * ack deadline will expire 10 seconds after the `ModifyAckDeadline` call
+ * was made. Specifying zero may immediately make the message available for
+ * another pull request.
+ * @throws ApiException if the remote call fails
+ */
+ public final void modifyAckDeadline(
+ String subscription, List ackIds, int ackDeadlineSeconds) {
+ ModifyAckDeadlineRequest request =
+ ModifyAckDeadlineRequest.newBuilder()
+ .setSubscription(subscription)
+ .addAllAckIds(ackIds)
+ .setAckDeadlineSeconds(ackDeadlineSeconds)
+ .build();
+
+ modifyAckDeadline(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void modifyAckDeadline(ModifyAckDeadlineRequest request) {
+ modifyAckDeadlineCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable modifyAckDeadlineCallable() {
+ return modifyAckDeadlineCallable;
+ }
+
+ // ----- acknowledge -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription whose message is being acknowledged.
+ * @param ackIds The acknowledgment ID for the messages being acknowledged that was returned
+ * by the Pub/Sub system in the `Pull` response. Must not be empty.
+ * @throws ApiException if the remote call fails
+ */
+ public final void acknowledge(String subscription, List ackIds) {
+ AcknowledgeRequest request =
+ AcknowledgeRequest.newBuilder().setSubscription(subscription).addAllAckIds(ackIds).build();
+
+ acknowledge(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void acknowledge(AcknowledgeRequest request) {
+ acknowledgeCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable acknowledgeCallable() {
+ return acknowledgeCallable;
+ }
+
+ // ----- pull -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription from which messages should be pulled.
+ * @param returnImmediately If this is specified as true the system will respond immediately even if
+ * it is not able to return a message in the `Pull` response. Otherwise the
+ * system is allowed to wait until at least one message is available rather
+ * than returning no messages.
+ * @param maxMessages The maximum number of messages returned for this request. The Pub/Sub
+ * system may return fewer than the number specified.
+ * @throws ApiException if the remote call fails
+ */
+ public final PullResponse pull(String subscription, boolean returnImmediately, int maxMessages) {
+ PullRequest request =
+ PullRequest.newBuilder()
+ .setSubscription(subscription)
+ .setReturnImmediately(returnImmediately)
+ .setMaxMessages(maxMessages)
+ .build();
+
+ return pull(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public PullResponse pull(PullRequest request) {
+ return pullCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable pullCallable() {
+ return pullCallable;
+ }
+
+ // ----- modifyPushConfig -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription.
+ * @param pushConfig The push configuration for future deliveries.
+ *
+ * An empty `pushConfig` indicates that the Pub/Sub system should
+ * stop pushing messages from the given subscription and allow
+ * messages to be pulled and acknowledged - effectively pausing
+ * the subscription if `Pull` is not called.
+ * @throws ApiException if the remote call fails
+ */
+ public final void modifyPushConfig(String subscription, PushConfig pushConfig) {
+ ModifyPushConfigRequest request =
+ ModifyPushConfigRequest.newBuilder()
+ .setSubscription(subscription)
+ .setPushConfig(pushConfig)
+ .build();
+
+ modifyPushConfig(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void modifyPushConfig(ModifyPushConfigRequest request) {
+ modifyPushConfigCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable modifyPushConfigCallable() {
+ return modifyPushConfigCallable;
+ }
+
+ /**
+ * Initiates an orderly shutdown in which preexisting calls continue but new calls are immediately
+ * cancelled.
+ *
+ *
+ *
+ */
+ @Override
+ public final void close() throws Exception {
+ for (AutoCloseable closeable : closeables) {
+ closeable.close();
+ }
+ }
+
+ // ========
+ // Manually-added methods: add custom (non-generated) methods after this point.
+ // ========
+
+}
diff --git a/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java
new file mode 100644
index 000000000000..a46c956ae29d
--- /dev/null
+++ b/gcloud-java-pubsub/baseline/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java
@@ -0,0 +1,412 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.core.ConnectionSettings;
+import com.google.api.gax.core.RetrySettings;
+import com.google.api.gax.grpc.ApiCallSettings;
+import com.google.api.gax.grpc.PageStreamingCallSettings;
+import com.google.api.gax.grpc.PageStreamingDescriptor;
+import com.google.api.gax.grpc.ServiceApiSettings;
+import com.google.api.gax.grpc.SimpleCallSettings;
+import com.google.common.collect.ImmutableList;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Sets;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.AcknowledgeRequest;
+import com.google.pubsub.v1.DeleteSubscriptionRequest;
+import com.google.pubsub.v1.GetSubscriptionRequest;
+import com.google.pubsub.v1.ListSubscriptionsRequest;
+import com.google.pubsub.v1.ListSubscriptionsResponse;
+import com.google.pubsub.v1.ModifyAckDeadlineRequest;
+import com.google.pubsub.v1.ModifyPushConfigRequest;
+import com.google.pubsub.v1.PullRequest;
+import com.google.pubsub.v1.PullResponse;
+import com.google.pubsub.v1.SubscriberGrpc;
+import com.google.pubsub.v1.Subscription;
+import io.grpc.ManagedChannel;
+import io.grpc.Status;
+import java.io.IOException;
+import java.util.concurrent.ScheduledExecutorService;
+import org.joda.time.Duration;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS - see instructions at the top of the file for editing.
+@javax.annotation.Generated("by GAPIC")
+public class SubscriberSettings extends ServiceApiSettings {
+
+ /**
+ * The default address of the service.
+ *
+ *
+ *
+ */
+ public static final String DEFAULT_SERVICE_ADDRESS = "pubsub-experimental.googleapis.com";
+
+ /**
+ * The default port of the service.
+ *
+ *
+ *
+ */
+ public static final int DEFAULT_SERVICE_PORT = 443;
+
+ /**
+ * The default scopes of the service.
+ */
+ public static final ImmutableList DEFAULT_SERVICE_SCOPES =
+ ImmutableList.builder()
+ .add("https://www.googleapis.com/auth/pubsub")
+ .add("https://www.googleapis.com/auth/cloud-platform")
+ .build();
+
+ private final SimpleCallSettings createSubscriptionSettings;
+ private final SimpleCallSettings getSubscriptionSettings;
+ private final PageStreamingCallSettings<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings;
+
+ private final SimpleCallSettings deleteSubscriptionSettings;
+ private final SimpleCallSettings modifyAckDeadlineSettings;
+ private final SimpleCallSettings acknowledgeSettings;
+ private final SimpleCallSettings pullSettings;
+ private final SimpleCallSettings modifyPushConfigSettings;
+
+ public SimpleCallSettings createSubscriptionSettings() {
+ return createSubscriptionSettings;
+ }
+
+ public SimpleCallSettings getSubscriptionSettings() {
+ return getSubscriptionSettings;
+ }
+
+ public PageStreamingCallSettings<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings() {
+ return listSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings deleteSubscriptionSettings() {
+ return deleteSubscriptionSettings;
+ }
+
+ public SimpleCallSettings modifyAckDeadlineSettings() {
+ return modifyAckDeadlineSettings;
+ }
+
+ public SimpleCallSettings acknowledgeSettings() {
+ return acknowledgeSettings;
+ }
+
+ public SimpleCallSettings pullSettings() {
+ return pullSettings;
+ }
+
+ public SimpleCallSettings modifyPushConfigSettings() {
+ return modifyPushConfigSettings;
+ }
+
+ public static SubscriberSettings defaultInstance() throws IOException {
+ return newBuilder().build();
+ }
+
+ public static Builder newBuilder() {
+ return new Builder();
+ }
+
+ public Builder toBuilder() {
+ return new Builder(this);
+ }
+
+ private SubscriberSettings(Builder settingsBuilder) throws IOException {
+ super(
+ settingsBuilder.getOrBuildChannel(),
+ settingsBuilder.shouldAutoCloseChannel(),
+ settingsBuilder.getOrBuildExecutor(),
+ settingsBuilder.getConnectionSettings(),
+ settingsBuilder.getGeneratorName(),
+ settingsBuilder.getGeneratorVersion(),
+ settingsBuilder.getClientLibName(),
+ settingsBuilder.getClientLibVersion());
+
+ createSubscriptionSettings = settingsBuilder.createSubscriptionSettings().build();
+ getSubscriptionSettings = settingsBuilder.getSubscriptionSettings().build();
+ listSubscriptionsSettings = settingsBuilder.listSubscriptionsSettings().build();
+ deleteSubscriptionSettings = settingsBuilder.deleteSubscriptionSettings().build();
+ modifyAckDeadlineSettings = settingsBuilder.modifyAckDeadlineSettings().build();
+ acknowledgeSettings = settingsBuilder.acknowledgeSettings().build();
+ pullSettings = settingsBuilder.pullSettings().build();
+ modifyPushConfigSettings = settingsBuilder.modifyPushConfigSettings().build();
+ }
+
+ private static PageStreamingDescriptor<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ LIST_SUBSCRIPTIONS_PAGE_STR_DESC =
+ new PageStreamingDescriptor<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListSubscriptionsRequest injectToken(
+ ListSubscriptionsRequest payload, Object token) {
+ return ListSubscriptionsRequest.newBuilder(payload)
+ .setPageToken((String) token)
+ .build();
+ }
+
+ @Override
+ public Object extractNextToken(ListSubscriptionsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListSubscriptionsResponse payload) {
+ return payload.getSubscriptionsList();
+ }
+ };
+
+ public static class Builder extends ServiceApiSettings.Builder {
+ private final ImmutableList methodSettingsBuilders;
+
+ private SimpleCallSettings.Builder createSubscriptionSettings;
+ private SimpleCallSettings.Builder
+ getSubscriptionSettings;
+ private PageStreamingCallSettings.Builder<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings;
+ private SimpleCallSettings.Builder deleteSubscriptionSettings;
+ private SimpleCallSettings.Builder modifyAckDeadlineSettings;
+ private SimpleCallSettings.Builder acknowledgeSettings;
+ private SimpleCallSettings.Builder pullSettings;
+ private SimpleCallSettings.Builder modifyPushConfigSettings;
+
+ private static final ImmutableMap> RETRYABLE_CODE_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder> definitions = ImmutableMap.builder();
+ definitions.put(
+ "idempotent",
+ Sets.immutableEnumSet(
+ Lists.newArrayList(
+ Status.Code.DEADLINE_EXCEEDED, Status.Code.UNAVAILABLE)));
+ definitions.put("non_idempotent", Sets.immutableEnumSet(Lists.newArrayList()));
+ RETRYABLE_CODE_DEFINITIONS = definitions.build();
+ }
+
+ private static final ImmutableMap RETRY_PARAM_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder definitions = ImmutableMap.builder();
+ RetrySettings.Builder settingsBuilder = null;
+ settingsBuilder =
+ RetrySettings.newBuilder()
+ .setInitialRetryDelay(Duration.millis(100L))
+ .setRetryDelayMultiplier(1.2)
+ .setMaxRetryDelay(Duration.millis(1000L))
+ .setInitialRpcTimeout(Duration.millis(2000L))
+ .setRpcTimeoutMultiplier(1.5)
+ .setMaxRpcTimeout(Duration.millis(30000L))
+ .setTotalTimeout(Duration.millis(45000L));
+ definitions.put("default", settingsBuilder);
+ RETRY_PARAM_DEFINITIONS = definitions.build();
+ }
+
+ private Builder() {
+ super(
+ ConnectionSettings.builder()
+ .setServiceAddress(DEFAULT_SERVICE_ADDRESS)
+ .setPort(DEFAULT_SERVICE_PORT)
+ .provideCredentialsWith(DEFAULT_SERVICE_SCOPES)
+ .build());
+
+ createSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_CREATE_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ getSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_GET_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listSubscriptionsSettings =
+ PageStreamingCallSettings.newBuilder(
+ SubscriberGrpc.METHOD_LIST_SUBSCRIPTIONS, LIST_SUBSCRIPTIONS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ deleteSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_DELETE_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ modifyAckDeadlineSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_MODIFY_ACK_DEADLINE)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ acknowledgeSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_ACKNOWLEDGE)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ pullSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_PULL)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ modifyPushConfigSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_MODIFY_PUSH_CONFIG)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createSubscriptionSettings,
+ getSubscriptionSettings,
+ listSubscriptionsSettings,
+ deleteSubscriptionSettings,
+ modifyAckDeadlineSettings,
+ acknowledgeSettings,
+ pullSettings,
+ modifyPushConfigSettings);
+ }
+
+ private Builder(SubscriberSettings settings) {
+ super(settings);
+
+ createSubscriptionSettings = settings.createSubscriptionSettings.toBuilder();
+ getSubscriptionSettings = settings.getSubscriptionSettings.toBuilder();
+ listSubscriptionsSettings = settings.listSubscriptionsSettings.toBuilder();
+ deleteSubscriptionSettings = settings.deleteSubscriptionSettings.toBuilder();
+ modifyAckDeadlineSettings = settings.modifyAckDeadlineSettings.toBuilder();
+ acknowledgeSettings = settings.acknowledgeSettings.toBuilder();
+ pullSettings = settings.pullSettings.toBuilder();
+ modifyPushConfigSettings = settings.modifyPushConfigSettings.toBuilder();
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createSubscriptionSettings,
+ getSubscriptionSettings,
+ listSubscriptionsSettings,
+ deleteSubscriptionSettings,
+ modifyAckDeadlineSettings,
+ acknowledgeSettings,
+ pullSettings,
+ modifyPushConfigSettings);
+ }
+
+ @Override
+ public Builder provideChannelWith(ManagedChannel channel, boolean shouldAutoClose) {
+ super.provideChannelWith(channel, shouldAutoClose);
+ return this;
+ }
+
+ @Override
+ public Builder provideChannelWith(ConnectionSettings settings) {
+ super.provideChannelWith(settings);
+ return this;
+ }
+
+ @Override
+ public Builder setExecutor(ScheduledExecutorService executor) {
+ super.setExecutor(executor);
+ return this;
+ }
+
+ @Override
+ public Builder setGeneratorHeader(String name, String version) {
+ super.setGeneratorHeader(name, version);
+ return this;
+ }
+
+ @Override
+ public Builder setClientLibHeader(String name, String version) {
+ super.setClientLibHeader(name, version);
+ return this;
+ }
+
+ public Builder applyToAllApiMethods(ApiCallSettings.Builder apiCallSettings) throws Exception {
+ super.applyToAllApiMethods(methodSettingsBuilders, apiCallSettings);
+ return this;
+ }
+
+ public SimpleCallSettings.Builder createSubscriptionSettings() {
+ return createSubscriptionSettings;
+ }
+
+ public SimpleCallSettings.Builder
+ getSubscriptionSettings() {
+ return getSubscriptionSettings;
+ }
+
+ public PageStreamingCallSettings.Builder<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings() {
+ return listSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings.Builder
+ deleteSubscriptionSettings() {
+ return deleteSubscriptionSettings;
+ }
+
+ public SimpleCallSettings.Builder modifyAckDeadlineSettings() {
+ return modifyAckDeadlineSettings;
+ }
+
+ public SimpleCallSettings.Builder acknowledgeSettings() {
+ return acknowledgeSettings;
+ }
+
+ public SimpleCallSettings.Builder pullSettings() {
+ return pullSettings;
+ }
+
+ public SimpleCallSettings.Builder modifyPushConfigSettings() {
+ return modifyPushConfigSettings;
+ }
+
+ @Override
+ public SubscriberSettings build() throws IOException {
+ return new SubscriberSettings(this);
+ }
+ }
+}
diff --git a/gcloud-java-pubsub/pom.xml b/gcloud-java-pubsub/pom.xml
new file mode 100644
index 000000000000..16a82879b9f4
--- /dev/null
+++ b/gcloud-java-pubsub/pom.xml
@@ -0,0 +1,109 @@
+
+
+ 4.0.0
+ com.google.gcloud
+ 0.1.5
+ gcloud-java-pubsub
+ jar
+ GCloud Java Pub/Sub
+
+ Java idiomatic client for Google Cloud Pub/Sub.
+
+
+ com.google.gcloud
+ gcloud-java-pom
+ 0.1.5
+
+
+ gcloud-java-pubsub
+
+
+
+ com.google.api
+ gax
+ 0.0.9
+
+
+ com.google.api.grpc
+ grpc-pubsub-v1
+ 0.0.2
+
+
+ io.grpc
+ grpc-all
+ 0.12.0
+
+
+ com.google.auto.value
+ auto-value
+ 1.1
+
+
+ junit
+ junit
+ 4.12
+ test
+
+
+
+
+ doclint-java8-disable
+
+ [1.8,)
+
+
+
+ -Xdoclint:none
+
+
+
+
+
+
+ org.codehaus.mojo
+ build-helper-maven-plugin
+ 1.9.1
+
+
+ generate-sources
+ add-source
+
+
+
+
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-javadoc-plugin
+ 2.10.3
+
+
+ attach-javadocs
+
+ jar
+
+
+ ${javadoc.opts}
+
+
+
+
+
+ maven-compiler-plugin
+
+
+
+ 3.1
+
+
+ 1.7
+ UTF-8
+ -Xlint:unchecked
+
+
+
+
+
diff --git a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java
new file mode 100644
index 000000000000..886945e0504e
--- /dev/null
+++ b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherApi.java
@@ -0,0 +1,533 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.grpc.ApiCallable;
+import com.google.api.gax.protobuf.PathTemplate;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.DeleteTopicRequest;
+import com.google.pubsub.v1.GetTopicRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsResponse;
+import com.google.pubsub.v1.ListTopicsRequest;
+import com.google.pubsub.v1.ListTopicsResponse;
+import com.google.pubsub.v1.PublishRequest;
+import com.google.pubsub.v1.PublishResponse;
+import com.google.pubsub.v1.PubsubMessage;
+import com.google.pubsub.v1.Topic;
+import io.grpc.ManagedChannel;
+import java.io.Closeable;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND SERVICE - see instructions at the top of the file for editing.
+/**
+ * Service Description: The service that an application uses to manipulate topics, and to send
+ * messages to a topic.
+ *
+ *
+ *
+ */
+@javax.annotation.Generated("by GAPIC")
+public class PublisherApi implements AutoCloseable {
+ private final ManagedChannel channel;
+ private final List closeables = new ArrayList<>();
+
+ private final ApiCallable createTopicCallable;
+ private final ApiCallable publishCallable;
+ private final ApiCallable getTopicCallable;
+ private final ApiCallable listTopicsCallable;
+ private final ApiCallable> listTopicsIterableCallable;
+ private final ApiCallable
+ listTopicSubscriptionsCallable;
+ private final ApiCallable>
+ listTopicSubscriptionsIterableCallable;
+ private final ApiCallable deleteTopicCallable;
+
+ private static final PathTemplate PROJECT_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}");
+
+ private static final PathTemplate TOPIC_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}/topics/{topic}");
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a project resource.
+ *
+ *
+ *
+ */
+ public static final String formatProjectName(String project) {
+ return PROJECT_PATH_TEMPLATE.instantiate("project", project);
+ }
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a topic resource.
+ *
+ *
+ *
+ */
+ public static final String formatTopicName(String project, String topic) {
+ return TOPIC_PATH_TEMPLATE.instantiate("project", project, "topic", topic);
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a project resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromProjectName(String projectName) {
+ return PROJECT_PATH_TEMPLATE.parse(projectName).get("project");
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a topic resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromTopicName(String topicName) {
+ return TOPIC_PATH_TEMPLATE.parse(topicName).get("project");
+ }
+
+ /**
+ * Parses the topic from the given fully-qualified path which
+ * represents a topic resource.
+ *
+ *
+ *
+ */
+ public static final String parseTopicFromTopicName(String topicName) {
+ return TOPIC_PATH_TEMPLATE.parse(topicName).get("topic");
+ }
+
+ /**
+ * Constructs an instance of PublisherApi with default settings.
+ *
+ *
+ *
+ */
+ public static final PublisherApi defaultInstance() throws IOException {
+ return create(PublisherSettings.defaultInstance());
+ }
+
+ /**
+ * Constructs an instance of PublisherApi, using the given settings.
+ * The channels are created based on the settings passed in, or defaults for any
+ * settings that are not set.
+ *
+ *
+ *
+ */
+ public static final PublisherApi create(PublisherSettings settings) throws IOException {
+ return new PublisherApi(settings);
+ }
+
+ /**
+ * Constructs an instance of PublisherApi, using the given settings.
+ * This is protected so that it easy to make a subclass, but otherwise, the static
+ * factory methods should be preferred.
+ *
+ *
+ *
+ */
+ protected PublisherApi(PublisherSettings settings) throws IOException {
+ this.channel = settings.getChannel();
+
+ this.createTopicCallable = ApiCallable.create(settings.createTopicSettings(), settings);
+ this.publishCallable = ApiCallable.create(settings.publishSettings(), settings);
+ if (settings.publishSettings().getBundlerFactory() != null) {
+ closeables.add(settings.publishSettings().getBundlerFactory());
+ }
+ this.getTopicCallable = ApiCallable.create(settings.getTopicSettings(), settings);
+ this.listTopicsCallable = ApiCallable.create(settings.listTopicsSettings(), settings);
+ this.listTopicsIterableCallable =
+ ApiCallable.createIterable(settings.listTopicsSettings(), settings);
+ this.listTopicSubscriptionsCallable =
+ ApiCallable.create(settings.listTopicSubscriptionsSettings(), settings);
+ this.listTopicSubscriptionsIterableCallable =
+ ApiCallable.createIterable(settings.listTopicSubscriptionsSettings(), settings);
+ this.deleteTopicCallable = ApiCallable.create(settings.deleteTopicSettings(), settings);
+
+ if (settings.shouldAutoCloseChannel()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ channel.shutdown();
+ }
+ });
+ }
+ }
+
+ // ----- createTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ *
+ * @param name The name of the topic. It must have the format
+ * `"projects/{project}/topics/{topic}"`. `{topic}` must start with a letter,
+ * and contain only letters (`[A-Za-z]`), numbers (`[0-9]`), dashes (`-`),
+ * underscores (`_`), periods (`.`), tildes (`~`), plus (`+`) or percent
+ * signs (`%`). It must be between 3 and 255 characters in length, and it
+ * must not start with `"goog"`.
+ * @throws ApiException if the remote call fails
+ */
+ public final Topic createTopic(String name) {
+ Topic request = Topic.newBuilder().setName(name).build();
+
+ return createTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Topic createTopic(Topic request) {
+ return createTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates the given topic with the given name.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable createTopicCallable() {
+ return createTopicCallable;
+ }
+
+ // ----- publish -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ *
+ * @param topic The messages in the request will be published on this topic.
+ * @param messages The messages to publish.
+ * @throws ApiException if the remote call fails
+ */
+ public final PublishResponse publish(String topic, List messages) {
+ PublishRequest request =
+ PublishRequest.newBuilder().setTopic(topic).addAllMessages(messages).build();
+
+ return publish(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public PublishResponse publish(PublishRequest request) {
+ return publishCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Adds one or more messages to the topic. Generates `NOT_FOUND` if the topic
+ * does not exist. The message payload must not be empty; it must contain
+ * either a non-empty data field, or at least one attribute.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable publishCallable() {
+ return publishCallable;
+ }
+
+ // ----- getTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ *
+ * @param topic The name of the topic to get.
+ * @throws ApiException if the remote call fails
+ */
+ public final Topic getTopic(String topic) {
+ GetTopicRequest request = GetTopicRequest.newBuilder().setTopic(topic).build();
+
+ return getTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Topic getTopic(GetTopicRequest request) {
+ return getTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration of a topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable getTopicCallable() {
+ return getTopicCallable;
+ }
+
+ // ----- listTopics -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ *
+ * @param project The name of the cloud project that topics belong to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopics(String project) {
+ ListTopicsRequest request = ListTopicsRequest.newBuilder().setProject(project).build();
+ return listTopics(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopics(ListTopicsRequest request) {
+ return listTopicsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable> listTopicsIterableCallable() {
+ return listTopicsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching topics.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable listTopicsCallable() {
+ return listTopicsCallable;
+ }
+
+ // ----- listTopicSubscriptions -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ *
+ * @param topic The name of the topic that subscriptions are attached to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopicSubscriptions(String topic) {
+ ListTopicSubscriptionsRequest request =
+ ListTopicSubscriptionsRequest.newBuilder().setTopic(topic).build();
+ return listTopicSubscriptions(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listTopicSubscriptions(ListTopicSubscriptionsRequest request) {
+ return listTopicSubscriptionsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable>
+ listTopicSubscriptionsIterableCallable() {
+ return listTopicSubscriptionsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists the name of the subscriptions for this topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable
+ listTopicSubscriptionsCallable() {
+ return listTopicSubscriptionsCallable;
+ }
+
+ // ----- deleteTopic -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param topic Name of the topic to delete.
+ * @throws ApiException if the remote call fails
+ */
+ public final void deleteTopic(String topic) {
+ DeleteTopicRequest request = DeleteTopicRequest.newBuilder().setTopic(topic).build();
+
+ deleteTopic(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private void deleteTopic(DeleteTopicRequest request) {
+ deleteTopicCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes the topic with the given name. Generates `NOT_FOUND` if the topic
+ * does not exist. After a topic is deleted, a new topic may be created with
+ * the same name; this is an entirely new topic with none of the old
+ * configuration or subscriptions. Existing subscriptions to this topic are
+ * not deleted, but their `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable deleteTopicCallable() {
+ return deleteTopicCallable;
+ }
+
+ /**
+ * Initiates an orderly shutdown in which preexisting calls continue but new calls are immediately
+ * cancelled.
+ *
+ *
+ *
+ */
+ @Override
+ public final void close() throws Exception {
+ for (AutoCloseable closeable : closeables) {
+ closeable.close();
+ }
+ }
+
+ // ========
+ // Manually-added methods: add custom (non-generated) methods after this point.
+ // ========
+
+}
diff --git a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java
new file mode 100644
index 000000000000..72d24404d87a
--- /dev/null
+++ b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/PublisherSettings.java
@@ -0,0 +1,480 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.core.ConnectionSettings;
+import com.google.api.gax.core.RetrySettings;
+import com.google.api.gax.grpc.ApiCallSettings;
+import com.google.api.gax.grpc.BundlingCallSettings;
+import com.google.api.gax.grpc.BundlingDescriptor;
+import com.google.api.gax.grpc.BundlingSettings;
+import com.google.api.gax.grpc.PageStreamingCallSettings;
+import com.google.api.gax.grpc.PageStreamingDescriptor;
+import com.google.api.gax.grpc.RequestIssuer;
+import com.google.api.gax.grpc.ServiceApiSettings;
+import com.google.api.gax.grpc.SimpleCallSettings;
+import com.google.common.collect.ImmutableList;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Sets;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.DeleteTopicRequest;
+import com.google.pubsub.v1.GetTopicRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsRequest;
+import com.google.pubsub.v1.ListTopicSubscriptionsResponse;
+import com.google.pubsub.v1.ListTopicsRequest;
+import com.google.pubsub.v1.ListTopicsResponse;
+import com.google.pubsub.v1.PublishRequest;
+import com.google.pubsub.v1.PublishResponse;
+import com.google.pubsub.v1.PublisherGrpc;
+import com.google.pubsub.v1.PubsubMessage;
+import com.google.pubsub.v1.Topic;
+import io.grpc.ManagedChannel;
+import io.grpc.Status;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.List;
+import java.util.concurrent.ScheduledExecutorService;
+import org.joda.time.Duration;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS - see instructions at the top of the file for editing.
+@javax.annotation.Generated("by GAPIC")
+public class PublisherSettings extends ServiceApiSettings {
+
+ /**
+ * The default address of the service.
+ *
+ *
+ *
+ */
+ public static final String DEFAULT_SERVICE_ADDRESS = "pubsub-experimental.googleapis.com";
+
+ /**
+ * The default port of the service.
+ *
+ *
+ *
+ */
+ public static final int DEFAULT_SERVICE_PORT = 443;
+
+ /**
+ * The default scopes of the service.
+ */
+ public static final ImmutableList DEFAULT_SERVICE_SCOPES =
+ ImmutableList.builder()
+ .add("https://www.googleapis.com/auth/pubsub")
+ .add("https://www.googleapis.com/auth/cloud-platform")
+ .build();
+
+ private final SimpleCallSettings createTopicSettings;
+ private final BundlingCallSettings publishSettings;
+ private final SimpleCallSettings getTopicSettings;
+ private final PageStreamingCallSettings
+ listTopicsSettings;
+
+ private final PageStreamingCallSettings<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings;
+
+ private final SimpleCallSettings deleteTopicSettings;
+
+ public SimpleCallSettings createTopicSettings() {
+ return createTopicSettings;
+ }
+
+ public BundlingCallSettings publishSettings() {
+ return publishSettings;
+ }
+
+ public SimpleCallSettings getTopicSettings() {
+ return getTopicSettings;
+ }
+
+ public PageStreamingCallSettings
+ listTopicsSettings() {
+ return listTopicsSettings;
+ }
+
+ public PageStreamingCallSettings<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings() {
+ return listTopicSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings deleteTopicSettings() {
+ return deleteTopicSettings;
+ }
+
+ public static PublisherSettings defaultInstance() throws IOException {
+ return newBuilder().build();
+ }
+
+ public static Builder newBuilder() {
+ return new Builder();
+ }
+
+ public Builder toBuilder() {
+ return new Builder(this);
+ }
+
+ private PublisherSettings(Builder settingsBuilder) throws IOException {
+ super(
+ settingsBuilder.getOrBuildChannel(),
+ settingsBuilder.shouldAutoCloseChannel(),
+ settingsBuilder.getOrBuildExecutor(),
+ settingsBuilder.getConnectionSettings(),
+ settingsBuilder.getGeneratorName(),
+ settingsBuilder.getGeneratorVersion(),
+ settingsBuilder.getClientLibName(),
+ settingsBuilder.getClientLibVersion());
+
+ createTopicSettings = settingsBuilder.createTopicSettings().build();
+ publishSettings = settingsBuilder.publishSettings().build();
+ getTopicSettings = settingsBuilder.getTopicSettings().build();
+ listTopicsSettings = settingsBuilder.listTopicsSettings().build();
+ listTopicSubscriptionsSettings = settingsBuilder.listTopicSubscriptionsSettings().build();
+ deleteTopicSettings = settingsBuilder.deleteTopicSettings().build();
+ }
+
+ private static PageStreamingDescriptor
+ LIST_TOPICS_PAGE_STR_DESC =
+ new PageStreamingDescriptor() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListTopicsRequest injectToken(ListTopicsRequest payload, Object token) {
+ return ListTopicsRequest.newBuilder(payload).setPageToken((String) token).build();
+ }
+
+ @Override
+ public Object extractNextToken(ListTopicsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListTopicsResponse payload) {
+ return payload.getTopicsList();
+ }
+ };
+
+ private static PageStreamingDescriptor<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ LIST_TOPIC_SUBSCRIPTIONS_PAGE_STR_DESC =
+ new PageStreamingDescriptor<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListTopicSubscriptionsRequest injectToken(
+ ListTopicSubscriptionsRequest payload, Object token) {
+ return ListTopicSubscriptionsRequest.newBuilder(payload)
+ .setPageToken((String) token)
+ .build();
+ }
+
+ @Override
+ public Object extractNextToken(ListTopicSubscriptionsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListTopicSubscriptionsResponse payload) {
+ return payload.getSubscriptionsList();
+ }
+ };
+
+ private static BundlingDescriptor PUBLISH_BUNDLING_DESC =
+ new BundlingDescriptor() {
+ @Override
+ public String getBundlePartitionKey(PublishRequest request) {
+ return request.getTopic();
+ }
+
+ @Override
+ public PublishRequest mergeRequests(Collection requests) {
+ PublishRequest firstRequest = requests.iterator().next();
+
+ List elements = new ArrayList<>();
+ for (PublishRequest request : requests) {
+ elements.addAll(request.getMessagesList());
+ }
+
+ PublishRequest bundleRequest =
+ PublishRequest.newBuilder()
+ .setTopic(firstRequest.getTopic())
+ .addAllMessages(elements)
+ .build();
+ return bundleRequest;
+ }
+
+ @Override
+ public void splitResponse(
+ PublishResponse bundleResponse,
+ Collection extends RequestIssuer> bundle) {
+ int bundleMessageIndex = 0;
+ for (RequestIssuer responder : bundle) {
+ List subresponseElements = new ArrayList<>();
+ int subresponseCount = responder.getRequest().getMessagesCount();
+ for (int i = 0; i < subresponseCount; i++) {
+ subresponseElements.add(bundleResponse.getMessageIds(bundleMessageIndex));
+ bundleMessageIndex += 1;
+ }
+ PublishResponse response =
+ PublishResponse.newBuilder().addAllMessageIds(subresponseElements).build();
+ responder.setResponse(response);
+ }
+ }
+
+ @Override
+ public void splitException(
+ Throwable throwable,
+ Collection extends RequestIssuer> bundle) {
+ for (RequestIssuer responder : bundle) {
+ responder.setException(throwable);
+ }
+ }
+
+ @Override
+ public long countElements(PublishRequest request) {
+ return request.getMessagesCount();
+ }
+
+ @Override
+ public long countBytes(PublishRequest request) {
+ return request.getSerializedSize();
+ }
+ };
+
+ public static class Builder extends ServiceApiSettings.Builder {
+ private final ImmutableList methodSettingsBuilders;
+
+ private SimpleCallSettings.Builder createTopicSettings;
+ private BundlingCallSettings.Builder publishSettings;
+ private SimpleCallSettings.Builder getTopicSettings;
+ private PageStreamingCallSettings.Builder
+ listTopicsSettings;
+ private PageStreamingCallSettings.Builder<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings;
+ private SimpleCallSettings.Builder deleteTopicSettings;
+
+ private static final ImmutableMap> RETRYABLE_CODE_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder> definitions = ImmutableMap.builder();
+ definitions.put(
+ "idempotent",
+ Sets.immutableEnumSet(
+ Lists.newArrayList(
+ Status.Code.DEADLINE_EXCEEDED, Status.Code.UNAVAILABLE)));
+ definitions.put("non_idempotent", Sets.immutableEnumSet(Lists.newArrayList()));
+ RETRYABLE_CODE_DEFINITIONS = definitions.build();
+ }
+
+ private static final ImmutableMap RETRY_PARAM_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder definitions = ImmutableMap.builder();
+ RetrySettings.Builder settingsBuilder = null;
+ settingsBuilder =
+ RetrySettings.newBuilder()
+ .setInitialRetryDelay(Duration.millis(100L))
+ .setRetryDelayMultiplier(1.2)
+ .setMaxRetryDelay(Duration.millis(1000L))
+ .setInitialRpcTimeout(Duration.millis(2000L))
+ .setRpcTimeoutMultiplier(1.5)
+ .setMaxRpcTimeout(Duration.millis(30000L))
+ .setTotalTimeout(Duration.millis(45000L));
+ definitions.put("default", settingsBuilder);
+ RETRY_PARAM_DEFINITIONS = definitions.build();
+ }
+
+ private Builder() {
+ super(
+ ConnectionSettings.builder()
+ .setServiceAddress(DEFAULT_SERVICE_ADDRESS)
+ .setPort(DEFAULT_SERVICE_PORT)
+ .provideCredentialsWith(DEFAULT_SERVICE_SCOPES)
+ .build());
+
+ createTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_CREATE_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ BundlingSettings.Builder publishBundlingSettingsBuilder =
+ BundlingSettings.newBuilder()
+ .setElementCountThreshold(800)
+ .setElementCountLimit(1000)
+ .setRequestByteThreshold(8388608)
+ .setRequestByteLimit(10485760)
+ .setDelayThreshold(Duration.millis(100))
+ .setBlockingCallCountThreshold(1);
+ publishSettings =
+ BundlingCallSettings.newBuilder(PublisherGrpc.METHOD_PUBLISH, PUBLISH_BUNDLING_DESC)
+ .setBundlingSettingsBuilder(publishBundlingSettingsBuilder)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ getTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_GET_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listTopicsSettings =
+ PageStreamingCallSettings.newBuilder(
+ PublisherGrpc.METHOD_LIST_TOPICS, LIST_TOPICS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listTopicSubscriptionsSettings =
+ PageStreamingCallSettings.newBuilder(
+ PublisherGrpc.METHOD_LIST_TOPIC_SUBSCRIPTIONS,
+ LIST_TOPIC_SUBSCRIPTIONS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ deleteTopicSettings =
+ SimpleCallSettings.newBuilder(PublisherGrpc.METHOD_DELETE_TOPIC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createTopicSettings,
+ publishSettings,
+ getTopicSettings,
+ listTopicsSettings,
+ listTopicSubscriptionsSettings,
+ deleteTopicSettings);
+ }
+
+ private Builder(PublisherSettings settings) {
+ super(settings);
+
+ createTopicSettings = settings.createTopicSettings.toBuilder();
+ publishSettings = settings.publishSettings.toBuilder();
+ getTopicSettings = settings.getTopicSettings.toBuilder();
+ listTopicsSettings = settings.listTopicsSettings.toBuilder();
+ listTopicSubscriptionsSettings = settings.listTopicSubscriptionsSettings.toBuilder();
+ deleteTopicSettings = settings.deleteTopicSettings.toBuilder();
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createTopicSettings,
+ publishSettings,
+ getTopicSettings,
+ listTopicsSettings,
+ listTopicSubscriptionsSettings,
+ deleteTopicSettings);
+ }
+
+ @Override
+ public Builder provideChannelWith(ManagedChannel channel, boolean shouldAutoClose) {
+ super.provideChannelWith(channel, shouldAutoClose);
+ return this;
+ }
+
+ @Override
+ public Builder provideChannelWith(ConnectionSettings settings) {
+ super.provideChannelWith(settings);
+ return this;
+ }
+
+ @Override
+ public Builder setExecutor(ScheduledExecutorService executor) {
+ super.setExecutor(executor);
+ return this;
+ }
+
+ @Override
+ public Builder setGeneratorHeader(String name, String version) {
+ super.setGeneratorHeader(name, version);
+ return this;
+ }
+
+ @Override
+ public Builder setClientLibHeader(String name, String version) {
+ super.setClientLibHeader(name, version);
+ return this;
+ }
+
+ public Builder applyToAllApiMethods(ApiCallSettings.Builder apiCallSettings) throws Exception {
+ super.applyToAllApiMethods(methodSettingsBuilders, apiCallSettings);
+ return this;
+ }
+
+ public SimpleCallSettings.Builder createTopicSettings() {
+ return createTopicSettings;
+ }
+
+ public BundlingCallSettings.Builder publishSettings() {
+ return publishSettings;
+ }
+
+ public SimpleCallSettings.Builder getTopicSettings() {
+ return getTopicSettings;
+ }
+
+ public PageStreamingCallSettings.Builder
+ listTopicsSettings() {
+ return listTopicsSettings;
+ }
+
+ public PageStreamingCallSettings.Builder<
+ ListTopicSubscriptionsRequest, ListTopicSubscriptionsResponse, String>
+ listTopicSubscriptionsSettings() {
+ return listTopicSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings.Builder deleteTopicSettings() {
+ return deleteTopicSettings;
+ }
+
+ @Override
+ public PublisherSettings build() throws IOException {
+ return new PublisherSettings(this);
+ }
+ }
+}
diff --git a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java
new file mode 100644
index 000000000000..2bfafd62ef0e
--- /dev/null
+++ b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberApi.java
@@ -0,0 +1,759 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.grpc.ApiCallable;
+import com.google.api.gax.protobuf.PathTemplate;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.AcknowledgeRequest;
+import com.google.pubsub.v1.DeleteSubscriptionRequest;
+import com.google.pubsub.v1.GetSubscriptionRequest;
+import com.google.pubsub.v1.ListSubscriptionsRequest;
+import com.google.pubsub.v1.ListSubscriptionsResponse;
+import com.google.pubsub.v1.ModifyAckDeadlineRequest;
+import com.google.pubsub.v1.ModifyPushConfigRequest;
+import com.google.pubsub.v1.PullRequest;
+import com.google.pubsub.v1.PullResponse;
+import com.google.pubsub.v1.PushConfig;
+import com.google.pubsub.v1.Subscription;
+import io.grpc.ManagedChannel;
+import java.io.Closeable;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND SERVICE - see instructions at the top of the file for editing.
+/**
+ * Service Description: The service that an application uses to manipulate subscriptions and to
+ * consume messages from a subscription via the `Pull` method.
+ *
+ *
+ *
+ */
+@javax.annotation.Generated("by GAPIC")
+public class SubscriberApi implements AutoCloseable {
+ private final ManagedChannel channel;
+ private final List closeables = new ArrayList<>();
+
+ private final ApiCallable createSubscriptionCallable;
+ private final ApiCallable getSubscriptionCallable;
+ private final ApiCallable
+ listSubscriptionsCallable;
+ private final ApiCallable>
+ listSubscriptionsIterableCallable;
+ private final ApiCallable deleteSubscriptionCallable;
+ private final ApiCallable modifyAckDeadlineCallable;
+ private final ApiCallable acknowledgeCallable;
+ private final ApiCallable pullCallable;
+ private final ApiCallable modifyPushConfigCallable;
+
+ private static final PathTemplate PROJECT_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}");
+
+ private static final PathTemplate SUBSCRIPTION_PATH_TEMPLATE =
+ PathTemplate.create("projects/{project}/subscriptions/{subscription}");
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a project resource.
+ *
+ *
+ *
+ */
+ public static final String formatProjectName(String project) {
+ return PROJECT_PATH_TEMPLATE.instantiate("project", project);
+ }
+
+ /**
+ * Formats a string containing the fully-qualified path to represent
+ * a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String formatSubscriptionName(String project, String subscription) {
+ return SUBSCRIPTION_PATH_TEMPLATE.instantiate("project", project, "subscription", subscription);
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a project resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromProjectName(String projectName) {
+ return PROJECT_PATH_TEMPLATE.parse(projectName).get("project");
+ }
+
+ /**
+ * Parses the project from the given fully-qualified path which
+ * represents a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String parseProjectFromSubscriptionName(String subscriptionName) {
+ return SUBSCRIPTION_PATH_TEMPLATE.parse(subscriptionName).get("project");
+ }
+
+ /**
+ * Parses the subscription from the given fully-qualified path which
+ * represents a subscription resource.
+ *
+ *
+ *
+ */
+ public static final String parseSubscriptionFromSubscriptionName(String subscriptionName) {
+ return SUBSCRIPTION_PATH_TEMPLATE.parse(subscriptionName).get("subscription");
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi with default settings.
+ *
+ *
+ *
+ */
+ public static final SubscriberApi defaultInstance() throws IOException {
+ return create(SubscriberSettings.defaultInstance());
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi, using the given settings.
+ * The channels are created based on the settings passed in, or defaults for any
+ * settings that are not set.
+ *
+ *
+ *
+ */
+ public static final SubscriberApi create(SubscriberSettings settings) throws IOException {
+ return new SubscriberApi(settings);
+ }
+
+ /**
+ * Constructs an instance of SubscriberApi, using the given settings.
+ * This is protected so that it easy to make a subclass, but otherwise, the static
+ * factory methods should be preferred.
+ *
+ *
+ *
+ */
+ protected SubscriberApi(SubscriberSettings settings) throws IOException {
+ this.channel = settings.getChannel();
+
+ this.createSubscriptionCallable =
+ ApiCallable.create(settings.createSubscriptionSettings(), settings);
+ this.getSubscriptionCallable = ApiCallable.create(settings.getSubscriptionSettings(), settings);
+ this.listSubscriptionsCallable =
+ ApiCallable.create(settings.listSubscriptionsSettings(), settings);
+ this.listSubscriptionsIterableCallable =
+ ApiCallable.createIterable(settings.listSubscriptionsSettings(), settings);
+ this.deleteSubscriptionCallable =
+ ApiCallable.create(settings.deleteSubscriptionSettings(), settings);
+ this.modifyAckDeadlineCallable =
+ ApiCallable.create(settings.modifyAckDeadlineSettings(), settings);
+ this.acknowledgeCallable = ApiCallable.create(settings.acknowledgeSettings(), settings);
+ this.pullCallable = ApiCallable.create(settings.pullSettings(), settings);
+ this.modifyPushConfigCallable =
+ ApiCallable.create(settings.modifyPushConfigSettings(), settings);
+
+ if (settings.shouldAutoCloseChannel()) {
+ closeables.add(
+ new Closeable() {
+ @Override
+ public void close() throws IOException {
+ channel.shutdown();
+ }
+ });
+ }
+ }
+
+ // ----- createSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ *
+ * @param name The name of the subscription. It must have the format
+ * `"projects/{project}/subscriptions/{subscription}"`. `{subscription}` must
+ * start with a letter, and contain only letters (`[A-Za-z]`), numbers
+ * (`[0-9]`), dashes (`-`), underscores (`_`), periods (`.`), tildes (`~`),
+ * plus (`+`) or percent signs (`%`). It must be between 3 and 255 characters
+ * in length, and it must not start with `"goog"`.
+ * @param topic The name of the topic from which this subscription is receiving messages.
+ * @param pushConfig If push delivery is used with this subscription, this field is
+ * used to configure it. An empty `pushConfig` signifies that the subscriber
+ * will pull and ack messages using API methods.
+ * @param ackDeadlineSeconds This value is the maximum time after a subscriber receives a message
+ * before the subscriber should acknowledge the message. After message
+ * delivery but before the ack deadline expires and before the message is
+ * acknowledged, it is an outstanding message and will not be delivered
+ * again during that time (on a best-effort basis).
+ *
+ * For pull subscriptions, this value is used as the initial value for the ack
+ * deadline. To override this value for a given message, call
+ * `ModifyAckDeadline` with the corresponding `ack_id` if using
+ * pull.
+ *
+ * For push delivery, this value is also used to set the request timeout for
+ * the call to the push endpoint.
+ *
+ * If the subscriber never acknowledges the message, the Pub/Sub
+ * system will eventually redeliver the message.
+ *
+ * If this parameter is not set, the default value of 10 seconds is used.
+ * @throws ApiException if the remote call fails
+ */
+ public final Subscription createSubscription(
+ String name, String topic, PushConfig pushConfig, int ackDeadlineSeconds) {
+ Subscription request =
+ Subscription.newBuilder()
+ .setName(name)
+ .setTopic(topic)
+ .setPushConfig(pushConfig)
+ .setAckDeadlineSeconds(ackDeadlineSeconds)
+ .build();
+
+ return createSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public Subscription createSubscription(Subscription request) {
+ return createSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Creates a subscription to a given topic for a given subscriber.
+ * If the subscription already exists, generates `ALREADY_EXISTS`.
+ * If the corresponding topic doesn't exist, generates `NOT_FOUND`.
+ *
+ * If the name is not provided in the request, the server will assign a random
+ * name for this subscription on the same project as the topic.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable createSubscriptionCallable() {
+ return createSubscriptionCallable;
+ }
+
+ // ----- getSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription to get.
+ * @throws ApiException if the remote call fails
+ */
+ public final Subscription getSubscription(String subscription) {
+ GetSubscriptionRequest request =
+ GetSubscriptionRequest.newBuilder().setSubscription(subscription).build();
+
+ return getSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private Subscription getSubscription(GetSubscriptionRequest request) {
+ return getSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Gets the configuration details of a subscription.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable getSubscriptionCallable() {
+ return getSubscriptionCallable;
+ }
+
+ // ----- listSubscriptions -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param project The name of the cloud project that subscriptions belong to.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listSubscriptions(String project) {
+ ListSubscriptionsRequest request =
+ ListSubscriptionsRequest.newBuilder().setProject(project).build();
+ return listSubscriptions(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public final Iterable listSubscriptions(ListSubscriptionsRequest request) {
+ return listSubscriptionsIterableCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable>
+ listSubscriptionsIterableCallable() {
+ return listSubscriptionsIterableCallable;
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Lists matching subscriptions.
+ *
+ * If the topic of a subscription has been deleted, the subscription itself is
+ * not deleted, but the value of the `topic` field is set to `_deleted-topic_`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable
+ listSubscriptionsCallable() {
+ return listSubscriptionsCallable;
+ }
+
+ // ----- deleteSubscription -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription to delete.
+ * @throws ApiException if the remote call fails
+ */
+ public final void deleteSubscription(String subscription) {
+ DeleteSubscriptionRequest request =
+ DeleteSubscriptionRequest.newBuilder().setSubscription(subscription).build();
+
+ deleteSubscription(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ private void deleteSubscription(DeleteSubscriptionRequest request) {
+ deleteSubscriptionCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Deletes an existing subscription. All pending messages in the subscription
+ * are immediately dropped. Calls to `Pull` after deletion will generate
+ * `NOT_FOUND`. After a subscription is deleted, a new one may be created with
+ * the same name, but the new one has no association with the old
+ * subscription, or its topic unless the same topic is specified.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable deleteSubscriptionCallable() {
+ return deleteSubscriptionCallable;
+ }
+
+ // ----- modifyAckDeadline -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription.
+ * @param ackIds List of acknowledgment IDs.
+ * @param ackDeadlineSeconds The new ack deadline with respect to the time this request was sent to
+ * the Pub/Sub system. Must be >= 0. For example, if the value is 10, the new
+ * ack deadline will expire 10 seconds after the `ModifyAckDeadline` call
+ * was made. Specifying zero may immediately make the message available for
+ * another pull request.
+ * @throws ApiException if the remote call fails
+ */
+ public final void modifyAckDeadline(
+ String subscription, List ackIds, int ackDeadlineSeconds) {
+ ModifyAckDeadlineRequest request =
+ ModifyAckDeadlineRequest.newBuilder()
+ .setSubscription(subscription)
+ .addAllAckIds(ackIds)
+ .setAckDeadlineSeconds(ackDeadlineSeconds)
+ .build();
+
+ modifyAckDeadline(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void modifyAckDeadline(ModifyAckDeadlineRequest request) {
+ modifyAckDeadlineCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the ack deadline for a specific message. This method is useful
+ * to indicate that more time is needed to process a message by the
+ * subscriber, or to make the message available for redelivery if the
+ * processing was interrupted.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable modifyAckDeadlineCallable() {
+ return modifyAckDeadlineCallable;
+ }
+
+ // ----- acknowledge -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription whose message is being acknowledged.
+ * @param ackIds The acknowledgment ID for the messages being acknowledged that was returned
+ * by the Pub/Sub system in the `Pull` response. Must not be empty.
+ * @throws ApiException if the remote call fails
+ */
+ public final void acknowledge(String subscription, List ackIds) {
+ AcknowledgeRequest request =
+ AcknowledgeRequest.newBuilder().setSubscription(subscription).addAllAckIds(ackIds).build();
+
+ acknowledge(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void acknowledge(AcknowledgeRequest request) {
+ acknowledgeCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Acknowledges the messages associated with the `ack_ids` in the
+ * `AcknowledgeRequest`. The Pub/Sub system can remove the relevant messages
+ * from the subscription.
+ *
+ * Acknowledging a message whose ack deadline has expired may succeed,
+ * but such a message may be redelivered later. Acknowledging a message more
+ * than once will not result in an error.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable acknowledgeCallable() {
+ return acknowledgeCallable;
+ }
+
+ // ----- pull -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ *
+ * @param subscription The subscription from which messages should be pulled.
+ * @param returnImmediately If this is specified as true the system will respond immediately even if
+ * it is not able to return a message in the `Pull` response. Otherwise the
+ * system is allowed to wait until at least one message is available rather
+ * than returning no messages.
+ * @param maxMessages The maximum number of messages returned for this request. The Pub/Sub
+ * system may return fewer than the number specified.
+ * @throws ApiException if the remote call fails
+ */
+ public final PullResponse pull(String subscription, boolean returnImmediately, int maxMessages) {
+ PullRequest request =
+ PullRequest.newBuilder()
+ .setSubscription(subscription)
+ .setReturnImmediately(returnImmediately)
+ .setMaxMessages(maxMessages)
+ .build();
+
+ return pull(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public PullResponse pull(PullRequest request) {
+ return pullCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Pulls messages from the server. Returns an empty list if there are no
+ * messages available in the backlog. The server may generate `UNAVAILABLE` if
+ * there are too many concurrent pull requests pending for the given
+ * subscription.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable pullCallable() {
+ return pullCallable;
+ }
+
+ // ----- modifyPushConfig -----
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ *
+ * @param subscription The name of the subscription.
+ * @param pushConfig The push configuration for future deliveries.
+ *
+ * An empty `pushConfig` indicates that the Pub/Sub system should
+ * stop pushing messages from the given subscription and allow
+ * messages to be pulled and acknowledged - effectively pausing
+ * the subscription if `Pull` is not called.
+ * @throws ApiException if the remote call fails
+ */
+ public final void modifyPushConfig(String subscription, PushConfig pushConfig) {
+ ModifyPushConfigRequest request =
+ ModifyPushConfigRequest.newBuilder()
+ .setSubscription(subscription)
+ .setPushConfig(pushConfig)
+ .build();
+
+ modifyPushConfig(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ *
+ * @param request The request object containing all of the parameters for the API call.
+ * @throws ApiException if the remote call fails
+ */
+ public void modifyPushConfig(ModifyPushConfigRequest request) {
+ modifyPushConfigCallable().call(request);
+ }
+
+ // AUTO-GENERATED DOCUMENTATION AND METHOD - see instructions at the top of the file for editing.
+ /**
+ * Modifies the `PushConfig` for a specified subscription.
+ *
+ * This may be used to change a push subscription to a pull one (signified by
+ * an empty `PushConfig`) or vice versa, or change the endpoint URL and other
+ * attributes of a push subscription. Messages will accumulate for delivery
+ * continuously through the call regardless of changes to the `PushConfig`.
+ *
+ *
+ *
+ * @throws ApiException if the remote call fails
+ */
+ public final ApiCallable modifyPushConfigCallable() {
+ return modifyPushConfigCallable;
+ }
+
+ /**
+ * Initiates an orderly shutdown in which preexisting calls continue but new calls are immediately
+ * cancelled.
+ *
+ *
+ *
+ */
+ @Override
+ public final void close() throws Exception {
+ for (AutoCloseable closeable : closeables) {
+ closeable.close();
+ }
+ }
+
+ // ========
+ // Manually-added methods: add custom (non-generated) methods after this point.
+ // ========
+
+}
diff --git a/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java
new file mode 100644
index 000000000000..a46c956ae29d
--- /dev/null
+++ b/gcloud-java-pubsub/src/main/java/com/google/cloud/pubsub/spi/v1/SubscriberSettings.java
@@ -0,0 +1,412 @@
+/*
+ * Copyright 2016 Google Inc. All Rights Reserved.
+ *
+ * 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.
+ */
+
+/*
+ * EDITING INSTRUCTIONS
+ * This file was generated from the file
+ * https://github.com/google/googleapis/blob/master/google/pubsub/v1/pubsub.proto
+ * and updates to that file get reflected here through a refresh process.
+ * For the short term, the refresh process will only be runnable by Google engineers.
+ * Manual additions are allowed because the refresh process performs
+ * a 3-way merge in order to preserve those manual additions. In order to not
+ * break the refresh process, only certain types of modifications are
+ * allowed.
+ *
+ * Allowed modifications - currently these are the only types allowed:
+ * 1. New methods (these should be added to the end of the class)
+ * 2. New imports
+ * 3. Additional documentation between "manual edit" demarcations
+ *
+ * Happy editing!
+ */
+
+package com.google.cloud.pubsub.spi.v1;
+
+import com.google.api.gax.core.ConnectionSettings;
+import com.google.api.gax.core.RetrySettings;
+import com.google.api.gax.grpc.ApiCallSettings;
+import com.google.api.gax.grpc.PageStreamingCallSettings;
+import com.google.api.gax.grpc.PageStreamingDescriptor;
+import com.google.api.gax.grpc.ServiceApiSettings;
+import com.google.api.gax.grpc.SimpleCallSettings;
+import com.google.common.collect.ImmutableList;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Sets;
+import com.google.protobuf.Empty;
+import com.google.pubsub.v1.AcknowledgeRequest;
+import com.google.pubsub.v1.DeleteSubscriptionRequest;
+import com.google.pubsub.v1.GetSubscriptionRequest;
+import com.google.pubsub.v1.ListSubscriptionsRequest;
+import com.google.pubsub.v1.ListSubscriptionsResponse;
+import com.google.pubsub.v1.ModifyAckDeadlineRequest;
+import com.google.pubsub.v1.ModifyPushConfigRequest;
+import com.google.pubsub.v1.PullRequest;
+import com.google.pubsub.v1.PullResponse;
+import com.google.pubsub.v1.SubscriberGrpc;
+import com.google.pubsub.v1.Subscription;
+import io.grpc.ManagedChannel;
+import io.grpc.Status;
+import java.io.IOException;
+import java.util.concurrent.ScheduledExecutorService;
+import org.joda.time.Duration;
+
+// Manually-added imports: add custom (non-generated) imports after this point.
+
+// AUTO-GENERATED DOCUMENTATION AND CLASS - see instructions at the top of the file for editing.
+@javax.annotation.Generated("by GAPIC")
+public class SubscriberSettings extends ServiceApiSettings {
+
+ /**
+ * The default address of the service.
+ *
+ *
+ *
+ */
+ public static final String DEFAULT_SERVICE_ADDRESS = "pubsub-experimental.googleapis.com";
+
+ /**
+ * The default port of the service.
+ *
+ *
+ *
+ */
+ public static final int DEFAULT_SERVICE_PORT = 443;
+
+ /**
+ * The default scopes of the service.
+ */
+ public static final ImmutableList DEFAULT_SERVICE_SCOPES =
+ ImmutableList.builder()
+ .add("https://www.googleapis.com/auth/pubsub")
+ .add("https://www.googleapis.com/auth/cloud-platform")
+ .build();
+
+ private final SimpleCallSettings createSubscriptionSettings;
+ private final SimpleCallSettings getSubscriptionSettings;
+ private final PageStreamingCallSettings<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings;
+
+ private final SimpleCallSettings deleteSubscriptionSettings;
+ private final SimpleCallSettings modifyAckDeadlineSettings;
+ private final SimpleCallSettings acknowledgeSettings;
+ private final SimpleCallSettings pullSettings;
+ private final SimpleCallSettings modifyPushConfigSettings;
+
+ public SimpleCallSettings createSubscriptionSettings() {
+ return createSubscriptionSettings;
+ }
+
+ public SimpleCallSettings getSubscriptionSettings() {
+ return getSubscriptionSettings;
+ }
+
+ public PageStreamingCallSettings<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings() {
+ return listSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings deleteSubscriptionSettings() {
+ return deleteSubscriptionSettings;
+ }
+
+ public SimpleCallSettings modifyAckDeadlineSettings() {
+ return modifyAckDeadlineSettings;
+ }
+
+ public SimpleCallSettings acknowledgeSettings() {
+ return acknowledgeSettings;
+ }
+
+ public SimpleCallSettings pullSettings() {
+ return pullSettings;
+ }
+
+ public SimpleCallSettings modifyPushConfigSettings() {
+ return modifyPushConfigSettings;
+ }
+
+ public static SubscriberSettings defaultInstance() throws IOException {
+ return newBuilder().build();
+ }
+
+ public static Builder newBuilder() {
+ return new Builder();
+ }
+
+ public Builder toBuilder() {
+ return new Builder(this);
+ }
+
+ private SubscriberSettings(Builder settingsBuilder) throws IOException {
+ super(
+ settingsBuilder.getOrBuildChannel(),
+ settingsBuilder.shouldAutoCloseChannel(),
+ settingsBuilder.getOrBuildExecutor(),
+ settingsBuilder.getConnectionSettings(),
+ settingsBuilder.getGeneratorName(),
+ settingsBuilder.getGeneratorVersion(),
+ settingsBuilder.getClientLibName(),
+ settingsBuilder.getClientLibVersion());
+
+ createSubscriptionSettings = settingsBuilder.createSubscriptionSettings().build();
+ getSubscriptionSettings = settingsBuilder.getSubscriptionSettings().build();
+ listSubscriptionsSettings = settingsBuilder.listSubscriptionsSettings().build();
+ deleteSubscriptionSettings = settingsBuilder.deleteSubscriptionSettings().build();
+ modifyAckDeadlineSettings = settingsBuilder.modifyAckDeadlineSettings().build();
+ acknowledgeSettings = settingsBuilder.acknowledgeSettings().build();
+ pullSettings = settingsBuilder.pullSettings().build();
+ modifyPushConfigSettings = settingsBuilder.modifyPushConfigSettings().build();
+ }
+
+ private static PageStreamingDescriptor<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ LIST_SUBSCRIPTIONS_PAGE_STR_DESC =
+ new PageStreamingDescriptor<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>() {
+ @Override
+ public Object emptyToken() {
+ return "";
+ }
+
+ @Override
+ public ListSubscriptionsRequest injectToken(
+ ListSubscriptionsRequest payload, Object token) {
+ return ListSubscriptionsRequest.newBuilder(payload)
+ .setPageToken((String) token)
+ .build();
+ }
+
+ @Override
+ public Object extractNextToken(ListSubscriptionsResponse payload) {
+ return payload.getNextPageToken();
+ }
+
+ @Override
+ public Iterable extractResources(ListSubscriptionsResponse payload) {
+ return payload.getSubscriptionsList();
+ }
+ };
+
+ public static class Builder extends ServiceApiSettings.Builder {
+ private final ImmutableList methodSettingsBuilders;
+
+ private SimpleCallSettings.Builder createSubscriptionSettings;
+ private SimpleCallSettings.Builder
+ getSubscriptionSettings;
+ private PageStreamingCallSettings.Builder<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings;
+ private SimpleCallSettings.Builder deleteSubscriptionSettings;
+ private SimpleCallSettings.Builder modifyAckDeadlineSettings;
+ private SimpleCallSettings.Builder acknowledgeSettings;
+ private SimpleCallSettings.Builder pullSettings;
+ private SimpleCallSettings.Builder modifyPushConfigSettings;
+
+ private static final ImmutableMap> RETRYABLE_CODE_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder> definitions = ImmutableMap.builder();
+ definitions.put(
+ "idempotent",
+ Sets.immutableEnumSet(
+ Lists.newArrayList(
+ Status.Code.DEADLINE_EXCEEDED, Status.Code.UNAVAILABLE)));
+ definitions.put("non_idempotent", Sets.immutableEnumSet(Lists.newArrayList()));
+ RETRYABLE_CODE_DEFINITIONS = definitions.build();
+ }
+
+ private static final ImmutableMap RETRY_PARAM_DEFINITIONS;
+
+ static {
+ ImmutableMap.Builder definitions = ImmutableMap.builder();
+ RetrySettings.Builder settingsBuilder = null;
+ settingsBuilder =
+ RetrySettings.newBuilder()
+ .setInitialRetryDelay(Duration.millis(100L))
+ .setRetryDelayMultiplier(1.2)
+ .setMaxRetryDelay(Duration.millis(1000L))
+ .setInitialRpcTimeout(Duration.millis(2000L))
+ .setRpcTimeoutMultiplier(1.5)
+ .setMaxRpcTimeout(Duration.millis(30000L))
+ .setTotalTimeout(Duration.millis(45000L));
+ definitions.put("default", settingsBuilder);
+ RETRY_PARAM_DEFINITIONS = definitions.build();
+ }
+
+ private Builder() {
+ super(
+ ConnectionSettings.builder()
+ .setServiceAddress(DEFAULT_SERVICE_ADDRESS)
+ .setPort(DEFAULT_SERVICE_PORT)
+ .provideCredentialsWith(DEFAULT_SERVICE_SCOPES)
+ .build());
+
+ createSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_CREATE_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ getSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_GET_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ listSubscriptionsSettings =
+ PageStreamingCallSettings.newBuilder(
+ SubscriberGrpc.METHOD_LIST_SUBSCRIPTIONS, LIST_SUBSCRIPTIONS_PAGE_STR_DESC)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ deleteSubscriptionSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_DELETE_SUBSCRIPTION)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ modifyAckDeadlineSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_MODIFY_ACK_DEADLINE)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ acknowledgeSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_ACKNOWLEDGE)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ pullSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_PULL)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ modifyPushConfigSettings =
+ SimpleCallSettings.newBuilder(SubscriberGrpc.METHOD_MODIFY_PUSH_CONFIG)
+ .setRetryableCodes(RETRYABLE_CODE_DEFINITIONS.get("non_idempotent"))
+ .setRetrySettingsBuilder(RETRY_PARAM_DEFINITIONS.get("default"));
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createSubscriptionSettings,
+ getSubscriptionSettings,
+ listSubscriptionsSettings,
+ deleteSubscriptionSettings,
+ modifyAckDeadlineSettings,
+ acknowledgeSettings,
+ pullSettings,
+ modifyPushConfigSettings);
+ }
+
+ private Builder(SubscriberSettings settings) {
+ super(settings);
+
+ createSubscriptionSettings = settings.createSubscriptionSettings.toBuilder();
+ getSubscriptionSettings = settings.getSubscriptionSettings.toBuilder();
+ listSubscriptionsSettings = settings.listSubscriptionsSettings.toBuilder();
+ deleteSubscriptionSettings = settings.deleteSubscriptionSettings.toBuilder();
+ modifyAckDeadlineSettings = settings.modifyAckDeadlineSettings.toBuilder();
+ acknowledgeSettings = settings.acknowledgeSettings.toBuilder();
+ pullSettings = settings.pullSettings.toBuilder();
+ modifyPushConfigSettings = settings.modifyPushConfigSettings.toBuilder();
+
+ methodSettingsBuilders =
+ ImmutableList.of(
+ createSubscriptionSettings,
+ getSubscriptionSettings,
+ listSubscriptionsSettings,
+ deleteSubscriptionSettings,
+ modifyAckDeadlineSettings,
+ acknowledgeSettings,
+ pullSettings,
+ modifyPushConfigSettings);
+ }
+
+ @Override
+ public Builder provideChannelWith(ManagedChannel channel, boolean shouldAutoClose) {
+ super.provideChannelWith(channel, shouldAutoClose);
+ return this;
+ }
+
+ @Override
+ public Builder provideChannelWith(ConnectionSettings settings) {
+ super.provideChannelWith(settings);
+ return this;
+ }
+
+ @Override
+ public Builder setExecutor(ScheduledExecutorService executor) {
+ super.setExecutor(executor);
+ return this;
+ }
+
+ @Override
+ public Builder setGeneratorHeader(String name, String version) {
+ super.setGeneratorHeader(name, version);
+ return this;
+ }
+
+ @Override
+ public Builder setClientLibHeader(String name, String version) {
+ super.setClientLibHeader(name, version);
+ return this;
+ }
+
+ public Builder applyToAllApiMethods(ApiCallSettings.Builder apiCallSettings) throws Exception {
+ super.applyToAllApiMethods(methodSettingsBuilders, apiCallSettings);
+ return this;
+ }
+
+ public SimpleCallSettings.Builder createSubscriptionSettings() {
+ return createSubscriptionSettings;
+ }
+
+ public SimpleCallSettings.Builder
+ getSubscriptionSettings() {
+ return getSubscriptionSettings;
+ }
+
+ public PageStreamingCallSettings.Builder<
+ ListSubscriptionsRequest, ListSubscriptionsResponse, Subscription>
+ listSubscriptionsSettings() {
+ return listSubscriptionsSettings;
+ }
+
+ public SimpleCallSettings.Builder
+ deleteSubscriptionSettings() {
+ return deleteSubscriptionSettings;
+ }
+
+ public SimpleCallSettings.Builder