• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2022 Google LLC
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      https://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.google.cloud.compute.v1;
18 
19 import static com.google.cloud.compute.v1.TargetGrpcProxiesClient.ListPagedResponse;
20 
21 import com.google.api.core.ApiFunction;
22 import com.google.api.core.BetaApi;
23 import com.google.api.gax.core.GoogleCredentialsProvider;
24 import com.google.api.gax.core.InstantiatingExecutorProvider;
25 import com.google.api.gax.httpjson.InstantiatingHttpJsonChannelProvider;
26 import com.google.api.gax.rpc.ApiClientHeaderProvider;
27 import com.google.api.gax.rpc.ClientContext;
28 import com.google.api.gax.rpc.ClientSettings;
29 import com.google.api.gax.rpc.OperationCallSettings;
30 import com.google.api.gax.rpc.PagedCallSettings;
31 import com.google.api.gax.rpc.TransportChannelProvider;
32 import com.google.api.gax.rpc.UnaryCallSettings;
33 import com.google.cloud.compute.v1.stub.TargetGrpcProxiesStubSettings;
34 import java.io.IOException;
35 import java.util.List;
36 import javax.annotation.Generated;
37 
38 // AUTO-GENERATED DOCUMENTATION AND CLASS.
39 /**
40  * Settings class to configure an instance of {@link TargetGrpcProxiesClient}.
41  *
42  * <p>The default instance has everything set to sensible defaults:
43  *
44  * <ul>
45  *   <li>The default service address (compute.googleapis.com) and default port (443) are used.
46  *   <li>Credentials are acquired automatically through Application Default Credentials.
47  *   <li>Retries are configured for idempotent methods but not for non-idempotent methods.
48  * </ul>
49  *
50  * <p>The builder of this class is recursive, so contained classes are themselves builders. When
51  * build() is called, the tree of builders is called to create the complete settings object.
52  *
53  * <p>For example, to set the total timeout of get to 30 seconds:
54  *
55  * <pre>{@code
56  * // This snippet has been automatically generated and should be regarded as a code template only.
57  * // It will require modifications to work:
58  * // - It may require correct/in-range values for request initialization.
59  * // - It may require specifying regional endpoints when creating the service client as shown in
60  * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
61  * TargetGrpcProxiesSettings.Builder targetGrpcProxiesSettingsBuilder =
62  *     TargetGrpcProxiesSettings.newBuilder();
63  * targetGrpcProxiesSettingsBuilder
64  *     .getSettings()
65  *     .setRetrySettings(
66  *         targetGrpcProxiesSettingsBuilder
67  *             .getSettings()
68  *             .getRetrySettings()
69  *             .toBuilder()
70  *             .setTotalTimeout(Duration.ofSeconds(30))
71  *             .build());
72  * TargetGrpcProxiesSettings targetGrpcProxiesSettings = targetGrpcProxiesSettingsBuilder.build();
73  * }</pre>
74  */
75 @Generated("by gapic-generator-java")
76 public class TargetGrpcProxiesSettings extends ClientSettings<TargetGrpcProxiesSettings> {
77 
78   /** Returns the object with the settings used for calls to delete. */
deleteSettings()79   public UnaryCallSettings<DeleteTargetGrpcProxyRequest, Operation> deleteSettings() {
80     return ((TargetGrpcProxiesStubSettings) getStubSettings()).deleteSettings();
81   }
82 
83   /** Returns the object with the settings used for calls to delete. */
84   public OperationCallSettings<DeleteTargetGrpcProxyRequest, Operation, Operation>
deleteOperationSettings()85       deleteOperationSettings() {
86     return ((TargetGrpcProxiesStubSettings) getStubSettings()).deleteOperationSettings();
87   }
88 
89   /** Returns the object with the settings used for calls to get. */
getSettings()90   public UnaryCallSettings<GetTargetGrpcProxyRequest, TargetGrpcProxy> getSettings() {
91     return ((TargetGrpcProxiesStubSettings) getStubSettings()).getSettings();
92   }
93 
94   /** Returns the object with the settings used for calls to insert. */
insertSettings()95   public UnaryCallSettings<InsertTargetGrpcProxyRequest, Operation> insertSettings() {
96     return ((TargetGrpcProxiesStubSettings) getStubSettings()).insertSettings();
97   }
98 
99   /** Returns the object with the settings used for calls to insert. */
100   public OperationCallSettings<InsertTargetGrpcProxyRequest, Operation, Operation>
insertOperationSettings()101       insertOperationSettings() {
102     return ((TargetGrpcProxiesStubSettings) getStubSettings()).insertOperationSettings();
103   }
104 
105   /** Returns the object with the settings used for calls to list. */
106   public PagedCallSettings<ListTargetGrpcProxiesRequest, TargetGrpcProxyList, ListPagedResponse>
listSettings()107       listSettings() {
108     return ((TargetGrpcProxiesStubSettings) getStubSettings()).listSettings();
109   }
110 
111   /** Returns the object with the settings used for calls to patch. */
patchSettings()112   public UnaryCallSettings<PatchTargetGrpcProxyRequest, Operation> patchSettings() {
113     return ((TargetGrpcProxiesStubSettings) getStubSettings()).patchSettings();
114   }
115 
116   /** Returns the object with the settings used for calls to patch. */
117   public OperationCallSettings<PatchTargetGrpcProxyRequest, Operation, Operation>
patchOperationSettings()118       patchOperationSettings() {
119     return ((TargetGrpcProxiesStubSettings) getStubSettings()).patchOperationSettings();
120   }
121 
create(TargetGrpcProxiesStubSettings stub)122   public static final TargetGrpcProxiesSettings create(TargetGrpcProxiesStubSettings stub)
123       throws IOException {
124     return new TargetGrpcProxiesSettings.Builder(stub.toBuilder()).build();
125   }
126 
127   /** Returns a builder for the default ExecutorProvider for this service. */
defaultExecutorProviderBuilder()128   public static InstantiatingExecutorProvider.Builder defaultExecutorProviderBuilder() {
129     return TargetGrpcProxiesStubSettings.defaultExecutorProviderBuilder();
130   }
131 
132   /** Returns the default service endpoint. */
getDefaultEndpoint()133   public static String getDefaultEndpoint() {
134     return TargetGrpcProxiesStubSettings.getDefaultEndpoint();
135   }
136 
137   /** Returns the default service scopes. */
getDefaultServiceScopes()138   public static List<String> getDefaultServiceScopes() {
139     return TargetGrpcProxiesStubSettings.getDefaultServiceScopes();
140   }
141 
142   /** Returns a builder for the default credentials for this service. */
defaultCredentialsProviderBuilder()143   public static GoogleCredentialsProvider.Builder defaultCredentialsProviderBuilder() {
144     return TargetGrpcProxiesStubSettings.defaultCredentialsProviderBuilder();
145   }
146 
147   /** Returns a builder for the default ChannelProvider for this service. */
148   public static InstantiatingHttpJsonChannelProvider.Builder
defaultHttpJsonTransportProviderBuilder()149       defaultHttpJsonTransportProviderBuilder() {
150     return TargetGrpcProxiesStubSettings.defaultHttpJsonTransportProviderBuilder();
151   }
152 
defaultTransportChannelProvider()153   public static TransportChannelProvider defaultTransportChannelProvider() {
154     return TargetGrpcProxiesStubSettings.defaultTransportChannelProvider();
155   }
156 
157   @BetaApi("The surface for customizing headers is not stable yet and may change in the future.")
defaultApiClientHeaderProviderBuilder()158   public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuilder() {
159     return TargetGrpcProxiesStubSettings.defaultApiClientHeaderProviderBuilder();
160   }
161 
162   /** Returns a new builder for this class. */
newBuilder()163   public static Builder newBuilder() {
164     return Builder.createDefault();
165   }
166 
167   /** Returns a new builder for this class. */
newBuilder(ClientContext clientContext)168   public static Builder newBuilder(ClientContext clientContext) {
169     return new Builder(clientContext);
170   }
171 
172   /** Returns a builder containing all the values of this settings class. */
toBuilder()173   public Builder toBuilder() {
174     return new Builder(this);
175   }
176 
TargetGrpcProxiesSettings(Builder settingsBuilder)177   protected TargetGrpcProxiesSettings(Builder settingsBuilder) throws IOException {
178     super(settingsBuilder);
179   }
180 
181   /** Builder for TargetGrpcProxiesSettings. */
182   public static class Builder extends ClientSettings.Builder<TargetGrpcProxiesSettings, Builder> {
183 
Builder()184     protected Builder() throws IOException {
185       this(((ClientContext) null));
186     }
187 
Builder(ClientContext clientContext)188     protected Builder(ClientContext clientContext) {
189       super(TargetGrpcProxiesStubSettings.newBuilder(clientContext));
190     }
191 
Builder(TargetGrpcProxiesSettings settings)192     protected Builder(TargetGrpcProxiesSettings settings) {
193       super(settings.getStubSettings().toBuilder());
194     }
195 
Builder(TargetGrpcProxiesStubSettings.Builder stubSettings)196     protected Builder(TargetGrpcProxiesStubSettings.Builder stubSettings) {
197       super(stubSettings);
198     }
199 
createDefault()200     private static Builder createDefault() {
201       return new Builder(TargetGrpcProxiesStubSettings.newBuilder());
202     }
203 
getStubSettingsBuilder()204     public TargetGrpcProxiesStubSettings.Builder getStubSettingsBuilder() {
205       return ((TargetGrpcProxiesStubSettings.Builder) getStubSettings());
206     }
207 
208     /**
209      * Applies the given settings updater function to all of the unary API methods in this service.
210      *
211      * <p>Note: This method does not support applying settings to streaming methods.
212      */
applyToAllUnaryMethods( ApiFunction<UnaryCallSettings.Builder<?, ?>, Void> settingsUpdater)213     public Builder applyToAllUnaryMethods(
214         ApiFunction<UnaryCallSettings.Builder<?, ?>, Void> settingsUpdater) {
215       super.applyToAllUnaryMethods(
216           getStubSettingsBuilder().unaryMethodSettingsBuilders(), settingsUpdater);
217       return this;
218     }
219 
220     /** Returns the builder for the settings used for calls to delete. */
deleteSettings()221     public UnaryCallSettings.Builder<DeleteTargetGrpcProxyRequest, Operation> deleteSettings() {
222       return getStubSettingsBuilder().deleteSettings();
223     }
224 
225     /** Returns the builder for the settings used for calls to delete. */
226     public OperationCallSettings.Builder<DeleteTargetGrpcProxyRequest, Operation, Operation>
deleteOperationSettings()227         deleteOperationSettings() {
228       return getStubSettingsBuilder().deleteOperationSettings();
229     }
230 
231     /** Returns the builder for the settings used for calls to get. */
getSettings()232     public UnaryCallSettings.Builder<GetTargetGrpcProxyRequest, TargetGrpcProxy> getSettings() {
233       return getStubSettingsBuilder().getSettings();
234     }
235 
236     /** Returns the builder for the settings used for calls to insert. */
insertSettings()237     public UnaryCallSettings.Builder<InsertTargetGrpcProxyRequest, Operation> insertSettings() {
238       return getStubSettingsBuilder().insertSettings();
239     }
240 
241     /** Returns the builder for the settings used for calls to insert. */
242     public OperationCallSettings.Builder<InsertTargetGrpcProxyRequest, Operation, Operation>
insertOperationSettings()243         insertOperationSettings() {
244       return getStubSettingsBuilder().insertOperationSettings();
245     }
246 
247     /** Returns the builder for the settings used for calls to list. */
248     public PagedCallSettings.Builder<
249             ListTargetGrpcProxiesRequest, TargetGrpcProxyList, ListPagedResponse>
listSettings()250         listSettings() {
251       return getStubSettingsBuilder().listSettings();
252     }
253 
254     /** Returns the builder for the settings used for calls to patch. */
patchSettings()255     public UnaryCallSettings.Builder<PatchTargetGrpcProxyRequest, Operation> patchSettings() {
256       return getStubSettingsBuilder().patchSettings();
257     }
258 
259     /** Returns the builder for the settings used for calls to patch. */
260     public OperationCallSettings.Builder<PatchTargetGrpcProxyRequest, Operation, Operation>
patchOperationSettings()261         patchOperationSettings() {
262       return getStubSettingsBuilder().patchOperationSettings();
263     }
264 
265     @Override
build()266     public TargetGrpcProxiesSettings build() throws IOException {
267       return new TargetGrpcProxiesSettings(this);
268     }
269   }
270 }
271