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

com.oracle.bmc.budget.BudgetAsyncClient Maven / Gradle / Ivy

There is a newer version: 3.54.0
Show newest version
/**
 * Copyright (c) 2016, 2024, Oracle and/or its affiliates.  All rights reserved.
 * This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
 */
package com.oracle.bmc.budget;

import com.oracle.bmc.util.internal.Validate;
import com.oracle.bmc.budget.requests.*;
import com.oracle.bmc.budget.responses.*;

import java.util.Objects;

/**
 * Async client implementation for Budget service. 
* There are two ways to use async client: 1. Use AsyncHandler: using AsyncHandler, if the response * to the call is an {@link java.io.InputStream}, like getObject Api in object storage service, * developers need to process the stream in AsyncHandler, and not anywhere else, because the stream * will be closed right after the AsyncHandler is invoked.
* 2. Use Java Future: using Java Future, developers need to close the stream after they are done * with the Java Future.
* Accessing the result should be done in a mutually exclusive manner, either through the Future or * the AsyncHandler, but not both. If the Future is used, the caller should pass in null as the * AsyncHandler. If the AsyncHandler is used, it is still safe to use the Future to determine * whether or not the request was completed via Future.isDone/isCancelled.
* Please refer to * https://github.com/oracle/oci-java-sdk/blob/master/bmc-examples/src/main/java/ResteasyClientWithObjectStorageExample.java */ @jakarta.annotation.Generated(value = "OracleSDKGenerator", comments = "API Version: 20190111") public class BudgetAsyncClient extends com.oracle.bmc.http.internal.BaseAsyncClient implements BudgetAsync { /** Service instance for Budget. */ public static final com.oracle.bmc.Service SERVICE = com.oracle.bmc.Services.serviceBuilder() .serviceName("BUDGET") .serviceEndpointPrefix("") .serviceEndpointTemplate("https://usage.{region}.oci.{secondLevelDomain}") .build(); private static final org.slf4j.Logger LOG = org.slf4j.LoggerFactory.getLogger(BudgetAsyncClient.class); BudgetAsyncClient( com.oracle.bmc.common.ClientBuilderBase builder, com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider) { super(builder, authenticationDetailsProvider); } /** * Create a builder for this client. * * @return builder */ public static Builder builder() { return new Builder(SERVICE); } /** * Builder class for this client. The "authenticationDetailsProvider" is required and must be * passed to the {@link #build(AbstractAuthenticationDetailsProvider)} method. */ public static class Builder extends com.oracle.bmc.common.RegionalClientBuilder { private Builder(com.oracle.bmc.Service service) { super(service); final String packageName = "budget"; com.oracle.bmc.internal.Alloy.throwDisabledServiceExceptionIfAppropriate(packageName); requestSignerFactory = new com.oracle.bmc.http.signing.internal.DefaultRequestSignerFactory( com.oracle.bmc.http.signing.SigningStrategy.STANDARD); } /** * Build the client. * * @param authenticationDetailsProvider authentication details provider * @return the client */ public BudgetAsyncClient build( @jakarta.annotation.Nonnull com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider) { return new BudgetAsyncClient(this, authenticationDetailsProvider); } } @Override public void setRegion(com.oracle.bmc.Region region) { super.setRegion(region); } @Override public void setRegion(String regionId) { super.setRegion(regionId); } @Override public java.util.concurrent.Future createAlertRule( CreateAlertRuleRequest request, final com.oracle.bmc.responses.AsyncHandler< CreateAlertRuleRequest, CreateAlertRuleResponse> handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); Objects.requireNonNull( request.getCreateAlertRuleDetails(), "createAlertRuleDetails is required"); return clientCall(request, CreateAlertRuleResponse::builder) .logger(LOG, "createAlertRule") .serviceDetails( "Budget", "CreateAlertRule", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/AlertRule/CreateAlertRule") .method(com.oracle.bmc.http.client.Method.POST) .requestBuilder(CreateAlertRuleRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .appendPathParam("alertRules") .accept("application/json") .appendHeader("opc-retry-token", request.getOpcRetryToken()) .appendHeader("opc-request-id", request.getOpcRequestId()) .hasBody() .handleBody( com.oracle.bmc.budget.model.AlertRule.class, CreateAlertRuleResponse.Builder::alertRule) .handleResponseHeaderString( "opc-request-id", CreateAlertRuleResponse.Builder::opcRequestId) .handleResponseHeaderString("etag", CreateAlertRuleResponse.Builder::etag) .callAsync(handler); } @Override public java.util.concurrent.Future createBudget( CreateBudgetRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Objects.requireNonNull(request.getCreateBudgetDetails(), "createBudgetDetails is required"); return clientCall(request, CreateBudgetResponse::builder) .logger(LOG, "createBudget") .serviceDetails( "Budget", "CreateBudget", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/Budget/CreateBudget") .method(com.oracle.bmc.http.client.Method.POST) .requestBuilder(CreateBudgetRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .accept("application/json") .appendHeader("opc-retry-token", request.getOpcRetryToken()) .appendHeader("opc-request-id", request.getOpcRequestId()) .hasBody() .handleBody( com.oracle.bmc.budget.model.Budget.class, CreateBudgetResponse.Builder::budget) .handleResponseHeaderString( "opc-request-id", CreateBudgetResponse.Builder::opcRequestId) .handleResponseHeaderString("etag", CreateBudgetResponse.Builder::etag) .callAsync(handler); } @Override public java.util.concurrent.Future deleteAlertRule( DeleteAlertRuleRequest request, final com.oracle.bmc.responses.AsyncHandler< DeleteAlertRuleRequest, DeleteAlertRuleResponse> handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); Validate.notBlank(request.getAlertRuleId(), "alertRuleId must not be blank"); return clientCall(request, DeleteAlertRuleResponse::builder) .logger(LOG, "deleteAlertRule") .serviceDetails( "Budget", "DeleteAlertRule", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/AlertRule/DeleteAlertRule") .method(com.oracle.bmc.http.client.Method.DELETE) .requestBuilder(DeleteAlertRuleRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .appendPathParam("alertRules") .appendPathParam(request.getAlertRuleId()) .accept("application/json") .appendHeader("if-match", request.getIfMatch()) .appendHeader("opc-request-id", request.getOpcRequestId()) .handleResponseHeaderString( "opc-request-id", DeleteAlertRuleResponse.Builder::opcRequestId) .callAsync(handler); } @Override public java.util.concurrent.Future deleteBudget( DeleteBudgetRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); return clientCall(request, DeleteBudgetResponse::builder) .logger(LOG, "deleteBudget") .serviceDetails( "Budget", "DeleteBudget", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/Budget/DeleteBudget") .method(com.oracle.bmc.http.client.Method.DELETE) .requestBuilder(DeleteBudgetRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .accept("application/json") .appendHeader("if-match", request.getIfMatch()) .appendHeader("opc-request-id", request.getOpcRequestId()) .handleResponseHeaderString( "opc-request-id", DeleteBudgetResponse.Builder::opcRequestId) .callAsync(handler); } @Override public java.util.concurrent.Future getAlertRule( GetAlertRuleRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); Validate.notBlank(request.getAlertRuleId(), "alertRuleId must not be blank"); return clientCall(request, GetAlertRuleResponse::builder) .logger(LOG, "getAlertRule") .serviceDetails( "Budget", "GetAlertRule", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/AlertRule/GetAlertRule") .method(com.oracle.bmc.http.client.Method.GET) .requestBuilder(GetAlertRuleRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .appendPathParam("alertRules") .appendPathParam(request.getAlertRuleId()) .accept("application/json") .appendHeader("opc-request-id", request.getOpcRequestId()) .handleBody( com.oracle.bmc.budget.model.AlertRule.class, GetAlertRuleResponse.Builder::alertRule) .handleResponseHeaderString("etag", GetAlertRuleResponse.Builder::etag) .handleResponseHeaderString( "opc-request-id", GetAlertRuleResponse.Builder::opcRequestId) .callAsync(handler); } @Override public java.util.concurrent.Future getBudget( GetBudgetRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); return clientCall(request, GetBudgetResponse::builder) .logger(LOG, "getBudget") .serviceDetails( "Budget", "GetBudget", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/Budget/GetBudget") .method(com.oracle.bmc.http.client.Method.GET) .requestBuilder(GetBudgetRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .accept("application/json") .appendHeader("opc-request-id", request.getOpcRequestId()) .handleBody( com.oracle.bmc.budget.model.Budget.class, GetBudgetResponse.Builder::budget) .handleResponseHeaderString("etag", GetBudgetResponse.Builder::etag) .handleResponseHeaderString( "opc-request-id", GetBudgetResponse.Builder::opcRequestId) .callAsync(handler); } @Override public java.util.concurrent.Future listAlertRules( ListAlertRulesRequest request, final com.oracle.bmc.responses.AsyncHandler< ListAlertRulesRequest, ListAlertRulesResponse> handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); return clientCall(request, ListAlertRulesResponse::builder) .logger(LOG, "listAlertRules") .serviceDetails( "Budget", "ListAlertRules", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/AlertRuleSummary/ListAlertRules") .method(com.oracle.bmc.http.client.Method.GET) .requestBuilder(ListAlertRulesRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .appendPathParam("alertRules") .appendQueryParam("limit", request.getLimit()) .appendQueryParam("page", request.getPage()) .appendEnumQueryParam("sortOrder", request.getSortOrder()) .appendEnumQueryParam("sortBy", request.getSortBy()) .appendEnumQueryParam("lifecycleState", request.getLifecycleState()) .appendQueryParam("displayName", request.getDisplayName()) .accept("application/json") .appendHeader("opc-request-id", request.getOpcRequestId()) .handleBodyList( com.oracle.bmc.budget.model.AlertRuleSummary.class, ListAlertRulesResponse.Builder::items) .handleResponseHeaderString( "opc-request-id", ListAlertRulesResponse.Builder::opcRequestId) .handleResponseHeaderString( "opc-next-page", ListAlertRulesResponse.Builder::opcNextPage) .callAsync(handler); } @Override public java.util.concurrent.Future listBudgets( ListBudgetsRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Objects.requireNonNull(request.getCompartmentId(), "compartmentId is required"); return clientCall(request, ListBudgetsResponse::builder) .logger(LOG, "listBudgets") .serviceDetails( "Budget", "ListBudgets", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/BudgetSummary/ListBudgets") .method(com.oracle.bmc.http.client.Method.GET) .requestBuilder(ListBudgetsRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendQueryParam("compartmentId", request.getCompartmentId()) .appendQueryParam("limit", request.getLimit()) .appendQueryParam("page", request.getPage()) .appendEnumQueryParam("sortOrder", request.getSortOrder()) .appendEnumQueryParam("sortBy", request.getSortBy()) .appendEnumQueryParam("lifecycleState", request.getLifecycleState()) .appendQueryParam("displayName", request.getDisplayName()) .appendEnumQueryParam("targetType", request.getTargetType()) .accept("application/json") .appendHeader("opc-request-id", request.getOpcRequestId()) .handleBodyList( com.oracle.bmc.budget.model.BudgetSummary.class, ListBudgetsResponse.Builder::items) .handleResponseHeaderString( "opc-request-id", ListBudgetsResponse.Builder::opcRequestId) .handleResponseHeaderString( "opc-next-page", ListBudgetsResponse.Builder::opcNextPage) .callAsync(handler); } @Override public java.util.concurrent.Future updateAlertRule( UpdateAlertRuleRequest request, final com.oracle.bmc.responses.AsyncHandler< UpdateAlertRuleRequest, UpdateAlertRuleResponse> handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); Validate.notBlank(request.getAlertRuleId(), "alertRuleId must not be blank"); Objects.requireNonNull( request.getUpdateAlertRuleDetails(), "updateAlertRuleDetails is required"); return clientCall(request, UpdateAlertRuleResponse::builder) .logger(LOG, "updateAlertRule") .serviceDetails( "Budget", "UpdateAlertRule", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/AlertRule/UpdateAlertRule") .method(com.oracle.bmc.http.client.Method.PUT) .requestBuilder(UpdateAlertRuleRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .appendPathParam("alertRules") .appendPathParam(request.getAlertRuleId()) .accept("application/json") .appendHeader("if-match", request.getIfMatch()) .appendHeader("opc-request-id", request.getOpcRequestId()) .hasBody() .handleBody( com.oracle.bmc.budget.model.AlertRule.class, UpdateAlertRuleResponse.Builder::alertRule) .handleResponseHeaderString( "opc-request-id", UpdateAlertRuleResponse.Builder::opcRequestId) .handleResponseHeaderString("etag", UpdateAlertRuleResponse.Builder::etag) .callAsync(handler); } @Override public java.util.concurrent.Future updateBudget( UpdateBudgetRequest request, final com.oracle.bmc.responses.AsyncHandler handler) { Validate.notBlank(request.getBudgetId(), "budgetId must not be blank"); Objects.requireNonNull(request.getUpdateBudgetDetails(), "updateBudgetDetails is required"); return clientCall(request, UpdateBudgetResponse::builder) .logger(LOG, "updateBudget") .serviceDetails( "Budget", "UpdateBudget", "https://docs.oracle.com/iaas/api/#/en/budgets/20190111/Budget/UpdateBudget") .method(com.oracle.bmc.http.client.Method.PUT) .requestBuilder(UpdateBudgetRequest::builder) .basePath("/20190111") .appendPathParam("budgets") .appendPathParam(request.getBudgetId()) .accept("application/json") .appendHeader("if-match", request.getIfMatch()) .appendHeader("opc-request-id", request.getOpcRequestId()) .hasBody() .handleBody( com.oracle.bmc.budget.model.Budget.class, UpdateBudgetResponse.Builder::budget) .handleResponseHeaderString( "opc-request-id", UpdateBudgetResponse.Builder::opcRequestId) .handleResponseHeaderString("etag", UpdateBudgetResponse.Builder::etag) .callAsync(handler); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.BasicAuthenticationDetailsProvider authenticationDetailsProvider) { this(builder(), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.BasicAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration) { this(builder().configuration(configuration), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @param clientConfigurator {@link Builder#clientConfigurator} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.BasicAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration, com.oracle.bmc.http.ClientConfigurator clientConfigurator) { this( builder().configuration(configuration).clientConfigurator(clientConfigurator), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @param clientConfigurator {@link Builder#clientConfigurator} * @param defaultRequestSignerFactory {@link Builder#requestSignerFactory} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration, com.oracle.bmc.http.ClientConfigurator clientConfigurator, com.oracle.bmc.http.signing.RequestSignerFactory defaultRequestSignerFactory) { this( builder() .configuration(configuration) .clientConfigurator(clientConfigurator) .requestSignerFactory(defaultRequestSignerFactory), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @param clientConfigurator {@link Builder#clientConfigurator} * @param defaultRequestSignerFactory {@link Builder#requestSignerFactory} * @param additionalClientConfigurators {@link Builder#additionalClientConfigurators} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration, com.oracle.bmc.http.ClientConfigurator clientConfigurator, com.oracle.bmc.http.signing.RequestSignerFactory defaultRequestSignerFactory, java.util.List additionalClientConfigurators) { this( builder() .configuration(configuration) .clientConfigurator(clientConfigurator) .requestSignerFactory(defaultRequestSignerFactory) .additionalClientConfigurators(additionalClientConfigurators), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @param clientConfigurator {@link Builder#clientConfigurator} * @param defaultRequestSignerFactory {@link Builder#requestSignerFactory} * @param additionalClientConfigurators {@link Builder#additionalClientConfigurators} * @param endpoint {@link Builder#endpoint} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration, com.oracle.bmc.http.ClientConfigurator clientConfigurator, com.oracle.bmc.http.signing.RequestSignerFactory defaultRequestSignerFactory, java.util.List additionalClientConfigurators, String endpoint) { this( builder() .configuration(configuration) .clientConfigurator(clientConfigurator) .requestSignerFactory(defaultRequestSignerFactory) .additionalClientConfigurators(additionalClientConfigurators) .endpoint(endpoint), authenticationDetailsProvider); } /** * Create a new client instance. * * @param authenticationDetailsProvider The authentication details (see {@link Builder#build}) * @param configuration {@link Builder#configuration} * @param clientConfigurator {@link Builder#clientConfigurator} * @param defaultRequestSignerFactory {@link Builder#requestSignerFactory} * @param additionalClientConfigurators {@link Builder#additionalClientConfigurators} * @param endpoint {@link Builder#endpoint} * @param signingStrategyRequestSignerFactories {@link * Builder#signingStrategyRequestSignerFactories} * @deprecated Use the {@link #builder() builder} instead. */ @Deprecated public BudgetAsyncClient( com.oracle.bmc.auth.AbstractAuthenticationDetailsProvider authenticationDetailsProvider, com.oracle.bmc.ClientConfiguration configuration, com.oracle.bmc.http.ClientConfigurator clientConfigurator, com.oracle.bmc.http.signing.RequestSignerFactory defaultRequestSignerFactory, java.util.Map< com.oracle.bmc.http.signing.SigningStrategy, com.oracle.bmc.http.signing.RequestSignerFactory> signingStrategyRequestSignerFactories, java.util.List additionalClientConfigurators, String endpoint) { this( builder() .configuration(configuration) .clientConfigurator(clientConfigurator) .requestSignerFactory(defaultRequestSignerFactory) .additionalClientConfigurators(additionalClientConfigurators) .endpoint(endpoint) .signingStrategyRequestSignerFactories( signingStrategyRequestSignerFactories), authenticationDetailsProvider); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy