data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.azure.resourcemanager.costmanagement.models.GenerateCostDetailsReportRequestDefinition Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-resourcemanager-costmanagement Show documentation
Show all versions of azure-resourcemanager-costmanagement Show documentation
This package contains Microsoft Azure SDK for CostManagement Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt. CostManagement management client provides access to CostManagement resources for Azure Enterprise Subscriptions. Package tag package-2022-10.
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.
package com.azure.resourcemanager.costmanagement.models;
import com.azure.core.annotation.Fluent;
import com.fasterxml.jackson.annotation.JsonProperty;
/** The definition of a cost detailed report. */
@Fluent
public final class GenerateCostDetailsReportRequestDefinition {
/*
* The type of the detailed report. By default ActualCost is provided
*/
@JsonProperty(value = "metric")
private CostDetailsMetricType metric;
/*
* The specific date range of cost details requested for the report. This parameter cannot be used alongside either
* the invoiceId or billingPeriod parameters. If a timePeriod, invoiceId or billingPeriod parameter is not provided
* in the request body the API will return the current month's cost. API only allows data to be pulled for 1 month
* or less and no older than 13 months. If no timePeriod or billingPeriod or invoiceId is provided the API defaults
* to the open month time period
*/
@JsonProperty(value = "timePeriod")
private CostDetailsTimePeriod timePeriod;
/*
* This parameter can be used only by Enterprise Agreement customers. Use the YearMonth(e.g. 202008) format. This
* parameter cannot be used alongside either the invoiceId or timePeriod parameters. If a timePeriod, invoiceId or
* billingPeriod parameter is not provided in the request body the API will return the current month's cost.
*/
@JsonProperty(value = "billingPeriod")
private String billingPeriod;
/*
* This parameter can only be used by Microsoft Customer Agreement customers. Additionally, it can only be used at
* the Billing Profile or Customer scope. This parameter cannot be used alongside either the billingPeriod or
* timePeriod parameters. If a timePeriod, invoiceId or billingPeriod parameter is not provided in the request body
* the API will return the current month's cost.
*/
@JsonProperty(value = "invoiceId")
private String invoiceId;
/** Creates an instance of GenerateCostDetailsReportRequestDefinition class. */
public GenerateCostDetailsReportRequestDefinition() {
}
/**
* Get the metric property: The type of the detailed report. By default ActualCost is provided.
*
* @return the metric value.
*/
public CostDetailsMetricType metric() {
return this.metric;
}
/**
* Set the metric property: The type of the detailed report. By default ActualCost is provided.
*
* @param metric the metric value to set.
* @return the GenerateCostDetailsReportRequestDefinition object itself.
*/
public GenerateCostDetailsReportRequestDefinition withMetric(CostDetailsMetricType metric) {
this.metric = metric;
return this;
}
/**
* Get the timePeriod property: The specific date range of cost details requested for the report. This parameter
* cannot be used alongside either the invoiceId or billingPeriod parameters. If a timePeriod, invoiceId or
* billingPeriod parameter is not provided in the request body the API will return the current month's cost. API
* only allows data to be pulled for 1 month or less and no older than 13 months. If no timePeriod or billingPeriod
* or invoiceId is provided the API defaults to the open month time period.
*
* @return the timePeriod value.
*/
public CostDetailsTimePeriod timePeriod() {
return this.timePeriod;
}
/**
* Set the timePeriod property: The specific date range of cost details requested for the report. This parameter
* cannot be used alongside either the invoiceId or billingPeriod parameters. If a timePeriod, invoiceId or
* billingPeriod parameter is not provided in the request body the API will return the current month's cost. API
* only allows data to be pulled for 1 month or less and no older than 13 months. If no timePeriod or billingPeriod
* or invoiceId is provided the API defaults to the open month time period.
*
* @param timePeriod the timePeriod value to set.
* @return the GenerateCostDetailsReportRequestDefinition object itself.
*/
public GenerateCostDetailsReportRequestDefinition withTimePeriod(CostDetailsTimePeriod timePeriod) {
this.timePeriod = timePeriod;
return this;
}
/**
* Get the billingPeriod property: This parameter can be used only by Enterprise Agreement customers. Use the
* YearMonth(e.g. 202008) format. This parameter cannot be used alongside either the invoiceId or timePeriod
* parameters. If a timePeriod, invoiceId or billingPeriod parameter is not provided in the request body the API
* will return the current month's cost.
*
* @return the billingPeriod value.
*/
public String billingPeriod() {
return this.billingPeriod;
}
/**
* Set the billingPeriod property: This parameter can be used only by Enterprise Agreement customers. Use the
* YearMonth(e.g. 202008) format. This parameter cannot be used alongside either the invoiceId or timePeriod
* parameters. If a timePeriod, invoiceId or billingPeriod parameter is not provided in the request body the API
* will return the current month's cost.
*
* @param billingPeriod the billingPeriod value to set.
* @return the GenerateCostDetailsReportRequestDefinition object itself.
*/
public GenerateCostDetailsReportRequestDefinition withBillingPeriod(String billingPeriod) {
this.billingPeriod = billingPeriod;
return this;
}
/**
* Get the invoiceId property: This parameter can only be used by Microsoft Customer Agreement customers.
* Additionally, it can only be used at the Billing Profile or Customer scope. This parameter cannot be used
* alongside either the billingPeriod or timePeriod parameters. If a timePeriod, invoiceId or billingPeriod
* parameter is not provided in the request body the API will return the current month's cost.
*
* @return the invoiceId value.
*/
public String invoiceId() {
return this.invoiceId;
}
/**
* Set the invoiceId property: This parameter can only be used by Microsoft Customer Agreement customers.
* Additionally, it can only be used at the Billing Profile or Customer scope. This parameter cannot be used
* alongside either the billingPeriod or timePeriod parameters. If a timePeriod, invoiceId or billingPeriod
* parameter is not provided in the request body the API will return the current month's cost.
*
* @param invoiceId the invoiceId value to set.
* @return the GenerateCostDetailsReportRequestDefinition object itself.
*/
public GenerateCostDetailsReportRequestDefinition withInvoiceId(String invoiceId) {
this.invoiceId = invoiceId;
return this;
}
/**
* Validates the instance.
*
* @throws IllegalArgumentException thrown if the instance is not valid.
*/
public void validate() {
if (timePeriod() != null) {
timePeriod().validate();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy