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

com.ibm.cloud.objectstorage.monitoring.ApiCallMonitoringEvent Maven / Gradle / Ivy

/*
 * Copyright 2010-2019 Amazon.com, Inc. or its affiliates. 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.
 * A copy of the License is located at
 *
 *  http://aws.amazon.com/apache2.0
 *
 * or in the "license" file accompanying this file. This file 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.
 */

package com.ibm.cloud.objectstorage.monitoring;

/**
 * A Monitoring Event that describes the results of an Api Call.
 */
public class ApiCallMonitoringEvent extends ApiMonitoringEvent {

    public static final String API_CALL_MONITORING_EVENT_TYPE = "ApiCall";

    private Integer attemptCount;
    private Long latency;
    private int apiCallTimeout;
    private int maxRetriesExceeded;
    private String finalAwsException;
    private String finalAwsExceptionMessage;
    private String finalSdkException;
    private String finalSdkExceptionMessage;
    private Integer finalHttpStatusCode;

    @Override
    public ApiCallMonitoringEvent withApi(String api) {
        this.api = api;
        return this;
    }

    @Override
    public ApiCallMonitoringEvent withVersion(Integer version) {
        this.version = version;
        return this;
    }

    @Override
    public ApiCallMonitoringEvent withUserAgent(String userAgent) {
        this.userAgent = userAgent;
        return this;
    }

    @Override
    public ApiCallMonitoringEvent withRegion(String region) {
        this.region = region;
        return this;
    }

    @Override
    public ApiCallMonitoringEvent withService(String service) {
        this.service = service;
        return this;
    }

    @Override
    public ApiCallMonitoringEvent withClientId(String clientId) {
        this.clientId = clientId;
        return this;
    }

    /**
     * {@inheritDoc}
     *
     * 

* This is when the request is first seen by the service client. */ public ApiCallMonitoringEvent withTimestamp(Long timestamp) { this.timestamp = timestamp; return this; } /** * @return The total number of attempts that were made by the service client to fulfill this request before succeeding or * failing. */ public Integer getAttemptCount() { return attemptCount; } /** * Sets the attemptCount * * @param attemptCount The new attemptCount value. * @return This object for method chaining. */ public ApiCallMonitoringEvent withAttemptCount(Integer attemptCount) { this.attemptCount = attemptCount; return this; } /** * @return The elapsed time, in milliseconds, between when the Api Call was begun and when a final response or error is * manifested to the caller. */ public Long getLatency() { return latency; } /** * Sets the latency * * @param latency The new latency value. * @return This object for method chaining. */ public ApiCallMonitoringEvent withLatency(Long latency) { this.latency = latency; return this; } /** * @return a boolean (0/1) value that is 0 unless the Api call failed due to hitting an Api Call time limit. */ public int getApiCallTimeout() { return apiCallTimeout; } /** * Sets the api call timeout * * @param apiCallTimeout The new apiCallTimeout value. * @return This object for method chaining. */ public ApiCallMonitoringEvent withApiCallTimeout(int apiCallTimeout) { this.apiCallTimeout = apiCallTimeout; return this; } /** * @return a boolean (0/1) value that is 0 unless the Api call failed and the final attempt returned a retryable error. */ public int getMaxRetriesExceeded() { return maxRetriesExceeded; } /** * Sets the api call timeout * * @param maxRetriesExceeded The new maxRetriesExceeded value. * @return This object for method chaining. */ public ApiCallMonitoringEvent withMaxRetriesExceeded(int maxRetriesExceeded) { this.maxRetriesExceeded = maxRetriesExceeded; return this; } /** * The {@link ApiCallAttemptMonitoringEvent#getAwsException()} from the last reported API call attempt. This does * not include any exceptions raised between the completion of last API call attempt and the completion of the API call. * Consequently, this may be null even if an AwsException thrown by the client. */ public String getFinalAwsException() { return finalAwsException; } public ApiCallMonitoringEvent withFinalAwsException(String finalAwsException) { this.finalAwsException = finalAwsException; return this; } /** * The {@link ApiCallAttemptMonitoringEvent#getAwsExceptionMessage()} from the last reported API call attempt. This does * not include any exceptions raised between the completion of last API call attempt and the completion of the API call. * Consequently, this may be null even if an AwsException thrown by the client. */ public String getFinalAwsExceptionMessage() { return finalAwsExceptionMessage; } public ApiCallMonitoringEvent withFinalAwsExceptionMessage(String finalAwsExceptionMessage) { this.finalAwsExceptionMessage = finalAwsExceptionMessage; return this; } /** * The {@link ApiCallAttemptMonitoringEvent#getSdkException()} from the last reported API call attempt. This does * not include any exceptions raised between the completion of last API call attempt and the completion of the API call. * Consequently, this may be null even if an SdkException thrown by the client. */ public String getFinalSdkException() { return finalSdkException; } public ApiCallMonitoringEvent withFinalSdkException(String finalSdkException) { this.finalSdkException = finalSdkException; return this; } /** * The {@link ApiCallAttemptMonitoringEvent#getSdkExceptionMessage()} from the last reported API call attempt. This does * not include any exceptions raised between the completion of last API call attempt and the completion of the API call. * Consequently, this may be null even if an SdkException thrown by the client. */ public String getFinalSdkExceptionMessage() { return finalSdkExceptionMessage; } public ApiCallMonitoringEvent withFinalSdkExceptionMessage(String finalSdkExceptionMessage) { this.finalSdkExceptionMessage = finalSdkExceptionMessage; return this; } /** * The last status code returned by the service. This may be null if the API call or last API call attempt did not succeed. */ public Integer getFinalHttpStatusCode() { return finalHttpStatusCode; } public ApiCallMonitoringEvent withFinalHttpStatusCode(Integer finalHttpStatusCode) { this.finalHttpStatusCode = finalHttpStatusCode; return this; } @Override public String getType() { return API_CALL_MONITORING_EVENT_TYPE; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy