• 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.RegionCommitmentsClient.AggregatedListPagedResponse;
20 import static com.google.cloud.compute.v1.RegionCommitmentsClient.ListPagedResponse;
21 
22 import com.google.api.core.ApiFunction;
23 import com.google.api.core.BetaApi;
24 import com.google.api.gax.core.GoogleCredentialsProvider;
25 import com.google.api.gax.core.InstantiatingExecutorProvider;
26 import com.google.api.gax.httpjson.InstantiatingHttpJsonChannelProvider;
27 import com.google.api.gax.rpc.ApiClientHeaderProvider;
28 import com.google.api.gax.rpc.ClientContext;
29 import com.google.api.gax.rpc.ClientSettings;
30 import com.google.api.gax.rpc.OperationCallSettings;
31 import com.google.api.gax.rpc.PagedCallSettings;
32 import com.google.api.gax.rpc.TransportChannelProvider;
33 import com.google.api.gax.rpc.UnaryCallSettings;
34 import com.google.cloud.compute.v1.stub.RegionCommitmentsStubSettings;
35 import java.io.IOException;
36 import java.util.List;
37 import javax.annotation.Generated;
38 
39 // AUTO-GENERATED DOCUMENTATION AND CLASS.
40 /**
41  * Settings class to configure an instance of {@link RegionCommitmentsClient}.
42  *
43  * <p>The default instance has everything set to sensible defaults:
44  *
45  * <ul>
46  *   <li>The default service address (compute.googleapis.com) and default port (443) are used.
47  *   <li>Credentials are acquired automatically through Application Default Credentials.
48  *   <li>Retries are configured for idempotent methods but not for non-idempotent methods.
49  * </ul>
50  *
51  * <p>The builder of this class is recursive, so contained classes are themselves builders. When
52  * build() is called, the tree of builders is called to create the complete settings object.
53  *
54  * <p>For example, to set the total timeout of get to 30 seconds:
55  *
56  * <pre>{@code
57  * // This snippet has been automatically generated and should be regarded as a code template only.
58  * // It will require modifications to work:
59  * // - It may require correct/in-range values for request initialization.
60  * // - It may require specifying regional endpoints when creating the service client as shown in
61  * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
62  * RegionCommitmentsSettings.Builder regionCommitmentsSettingsBuilder =
63  *     RegionCommitmentsSettings.newBuilder();
64  * regionCommitmentsSettingsBuilder
65  *     .getSettings()
66  *     .setRetrySettings(
67  *         regionCommitmentsSettingsBuilder
68  *             .getSettings()
69  *             .getRetrySettings()
70  *             .toBuilder()
71  *             .setTotalTimeout(Duration.ofSeconds(30))
72  *             .build());
73  * RegionCommitmentsSettings regionCommitmentsSettings = regionCommitmentsSettingsBuilder.build();
74  * }</pre>
75  */
76 @Generated("by gapic-generator-java")
77 public class RegionCommitmentsSettings extends ClientSettings<RegionCommitmentsSettings> {
78 
79   /** Returns the object with the settings used for calls to aggregatedList. */
80   public PagedCallSettings<
81           AggregatedListRegionCommitmentsRequest,
82           CommitmentAggregatedList,
83           AggregatedListPagedResponse>
aggregatedListSettings()84       aggregatedListSettings() {
85     return ((RegionCommitmentsStubSettings) getStubSettings()).aggregatedListSettings();
86   }
87 
88   /** Returns the object with the settings used for calls to get. */
getSettings()89   public UnaryCallSettings<GetRegionCommitmentRequest, Commitment> getSettings() {
90     return ((RegionCommitmentsStubSettings) getStubSettings()).getSettings();
91   }
92 
93   /** Returns the object with the settings used for calls to insert. */
insertSettings()94   public UnaryCallSettings<InsertRegionCommitmentRequest, Operation> insertSettings() {
95     return ((RegionCommitmentsStubSettings) getStubSettings()).insertSettings();
96   }
97 
98   /** Returns the object with the settings used for calls to insert. */
99   public OperationCallSettings<InsertRegionCommitmentRequest, Operation, Operation>
insertOperationSettings()100       insertOperationSettings() {
101     return ((RegionCommitmentsStubSettings) getStubSettings()).insertOperationSettings();
102   }
103 
104   /** Returns the object with the settings used for calls to list. */
105   public PagedCallSettings<ListRegionCommitmentsRequest, CommitmentList, ListPagedResponse>
listSettings()106       listSettings() {
107     return ((RegionCommitmentsStubSettings) getStubSettings()).listSettings();
108   }
109 
110   /** Returns the object with the settings used for calls to update. */
updateSettings()111   public UnaryCallSettings<UpdateRegionCommitmentRequest, Operation> updateSettings() {
112     return ((RegionCommitmentsStubSettings) getStubSettings()).updateSettings();
113   }
114 
115   /** Returns the object with the settings used for calls to update. */
116   public OperationCallSettings<UpdateRegionCommitmentRequest, Operation, Operation>
updateOperationSettings()117       updateOperationSettings() {
118     return ((RegionCommitmentsStubSettings) getStubSettings()).updateOperationSettings();
119   }
120 
create(RegionCommitmentsStubSettings stub)121   public static final RegionCommitmentsSettings create(RegionCommitmentsStubSettings stub)
122       throws IOException {
123     return new RegionCommitmentsSettings.Builder(stub.toBuilder()).build();
124   }
125 
126   /** Returns a builder for the default ExecutorProvider for this service. */
defaultExecutorProviderBuilder()127   public static InstantiatingExecutorProvider.Builder defaultExecutorProviderBuilder() {
128     return RegionCommitmentsStubSettings.defaultExecutorProviderBuilder();
129   }
130 
131   /** Returns the default service endpoint. */
getDefaultEndpoint()132   public static String getDefaultEndpoint() {
133     return RegionCommitmentsStubSettings.getDefaultEndpoint();
134   }
135 
136   /** Returns the default service scopes. */
getDefaultServiceScopes()137   public static List<String> getDefaultServiceScopes() {
138     return RegionCommitmentsStubSettings.getDefaultServiceScopes();
139   }
140 
141   /** Returns a builder for the default credentials for this service. */
defaultCredentialsProviderBuilder()142   public static GoogleCredentialsProvider.Builder defaultCredentialsProviderBuilder() {
143     return RegionCommitmentsStubSettings.defaultCredentialsProviderBuilder();
144   }
145 
146   /** Returns a builder for the default ChannelProvider for this service. */
147   public static InstantiatingHttpJsonChannelProvider.Builder
defaultHttpJsonTransportProviderBuilder()148       defaultHttpJsonTransportProviderBuilder() {
149     return RegionCommitmentsStubSettings.defaultHttpJsonTransportProviderBuilder();
150   }
151 
defaultTransportChannelProvider()152   public static TransportChannelProvider defaultTransportChannelProvider() {
153     return RegionCommitmentsStubSettings.defaultTransportChannelProvider();
154   }
155 
156   @BetaApi("The surface for customizing headers is not stable yet and may change in the future.")
defaultApiClientHeaderProviderBuilder()157   public static ApiClientHeaderProvider.Builder defaultApiClientHeaderProviderBuilder() {
158     return RegionCommitmentsStubSettings.defaultApiClientHeaderProviderBuilder();
159   }
160 
161   /** Returns a new builder for this class. */
newBuilder()162   public static Builder newBuilder() {
163     return Builder.createDefault();
164   }
165 
166   /** Returns a new builder for this class. */
newBuilder(ClientContext clientContext)167   public static Builder newBuilder(ClientContext clientContext) {
168     return new Builder(clientContext);
169   }
170 
171   /** Returns a builder containing all the values of this settings class. */
toBuilder()172   public Builder toBuilder() {
173     return new Builder(this);
174   }
175 
RegionCommitmentsSettings(Builder settingsBuilder)176   protected RegionCommitmentsSettings(Builder settingsBuilder) throws IOException {
177     super(settingsBuilder);
178   }
179 
180   /** Builder for RegionCommitmentsSettings. */
181   public static class Builder extends ClientSettings.Builder<RegionCommitmentsSettings, Builder> {
182 
Builder()183     protected Builder() throws IOException {
184       this(((ClientContext) null));
185     }
186 
Builder(ClientContext clientContext)187     protected Builder(ClientContext clientContext) {
188       super(RegionCommitmentsStubSettings.newBuilder(clientContext));
189     }
190 
Builder(RegionCommitmentsSettings settings)191     protected Builder(RegionCommitmentsSettings settings) {
192       super(settings.getStubSettings().toBuilder());
193     }
194 
Builder(RegionCommitmentsStubSettings.Builder stubSettings)195     protected Builder(RegionCommitmentsStubSettings.Builder stubSettings) {
196       super(stubSettings);
197     }
198 
createDefault()199     private static Builder createDefault() {
200       return new Builder(RegionCommitmentsStubSettings.newBuilder());
201     }
202 
getStubSettingsBuilder()203     public RegionCommitmentsStubSettings.Builder getStubSettingsBuilder() {
204       return ((RegionCommitmentsStubSettings.Builder) getStubSettings());
205     }
206 
207     /**
208      * Applies the given settings updater function to all of the unary API methods in this service.
209      *
210      * <p>Note: This method does not support applying settings to streaming methods.
211      */
applyToAllUnaryMethods( ApiFunction<UnaryCallSettings.Builder<?, ?>, Void> settingsUpdater)212     public Builder applyToAllUnaryMethods(
213         ApiFunction<UnaryCallSettings.Builder<?, ?>, Void> settingsUpdater) {
214       super.applyToAllUnaryMethods(
215           getStubSettingsBuilder().unaryMethodSettingsBuilders(), settingsUpdater);
216       return this;
217     }
218 
219     /** Returns the builder for the settings used for calls to aggregatedList. */
220     public PagedCallSettings.Builder<
221             AggregatedListRegionCommitmentsRequest,
222             CommitmentAggregatedList,
223             AggregatedListPagedResponse>
aggregatedListSettings()224         aggregatedListSettings() {
225       return getStubSettingsBuilder().aggregatedListSettings();
226     }
227 
228     /** Returns the builder for the settings used for calls to get. */
getSettings()229     public UnaryCallSettings.Builder<GetRegionCommitmentRequest, Commitment> getSettings() {
230       return getStubSettingsBuilder().getSettings();
231     }
232 
233     /** Returns the builder for the settings used for calls to insert. */
insertSettings()234     public UnaryCallSettings.Builder<InsertRegionCommitmentRequest, Operation> insertSettings() {
235       return getStubSettingsBuilder().insertSettings();
236     }
237 
238     /** Returns the builder for the settings used for calls to insert. */
239     public OperationCallSettings.Builder<InsertRegionCommitmentRequest, Operation, Operation>
insertOperationSettings()240         insertOperationSettings() {
241       return getStubSettingsBuilder().insertOperationSettings();
242     }
243 
244     /** Returns the builder for the settings used for calls to list. */
245     public PagedCallSettings.Builder<
246             ListRegionCommitmentsRequest, CommitmentList, ListPagedResponse>
listSettings()247         listSettings() {
248       return getStubSettingsBuilder().listSettings();
249     }
250 
251     /** Returns the builder for the settings used for calls to update. */
updateSettings()252     public UnaryCallSettings.Builder<UpdateRegionCommitmentRequest, Operation> updateSettings() {
253       return getStubSettingsBuilder().updateSettings();
254     }
255 
256     /** Returns the builder for the settings used for calls to update. */
257     public OperationCallSettings.Builder<UpdateRegionCommitmentRequest, Operation, Operation>
updateOperationSettings()258         updateOperationSettings() {
259       return getStubSettingsBuilder().updateOperationSettings();
260     }
261 
262     @Override
build()263     public RegionCommitmentsSettings build() throws IOException {
264       return new RegionCommitmentsSettings(this);
265     }
266   }
267 }
268