Budget

class Budget : KotlinCustomResource

Budget configuration for a billing account. To get more information about Budget, see:

Warning: If you are using User ADCs (Application Default Credentials) with this resource, you must specify a billing_project and set user_project_override to true in the provider configuration. Otherwise the Billing Budgets API will return a 403 error. Your account must have the serviceusage.services.use permission on the billing_project you defined.

Example Usage

Billing Budget Basic

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.organizations.OrganizationsFunctions;
import com.pulumi.gcp.organizations.inputs.GetBillingAccountArgs;
import com.pulumi.gcp.billing.Budget;
import com.pulumi.gcp.billing.BudgetArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountSpecifiedAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetThresholdRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var account = OrganizationsFunctions.getBillingAccount(GetBillingAccountArgs.builder()
.billingAccount("000000-0000000-0000000-000000")
.build());
var budget = new Budget("budget", BudgetArgs.builder()
.billingAccount(account.applyValue(getBillingAccountResult -> getBillingAccountResult.id()))
.displayName("Example Billing Budget")
.amount(BudgetAmountArgs.builder()
.specifiedAmount(BudgetAmountSpecifiedAmountArgs.builder()
.currencyCode("USD")
.units("100000")
.build())
.build())
.thresholdRules(BudgetThresholdRuleArgs.builder()
.thresholdPercent(0.5)
.build())
.build());
}
}

Billing Budget Lastperiod

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.organizations.OrganizationsFunctions;
import com.pulumi.gcp.organizations.inputs.GetBillingAccountArgs;
import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
import com.pulumi.gcp.billing.Budget;
import com.pulumi.gcp.billing.BudgetArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetThresholdRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var account = OrganizationsFunctions.getBillingAccount(GetBillingAccountArgs.builder()
.billingAccount("000000-0000000-0000000-000000")
.build());
final var project = OrganizationsFunctions.getProject();
var budget = new Budget("budget", BudgetArgs.builder()
.billingAccount(account.applyValue(getBillingAccountResult -> getBillingAccountResult.id()))
.displayName("Example Billing Budget")
.budgetFilter(BudgetBudgetFilterArgs.builder()
.projects(String.format("projects/%s", project.applyValue(getProjectResult -> getProjectResult.number())))
.build())
.amount(BudgetAmountArgs.builder()
.lastPeriodAmount(true)
.build())
.thresholdRules(BudgetThresholdRuleArgs.builder()
.thresholdPercent(10)
.build())
.build());
}
}

Billing Budget Filter

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.organizations.OrganizationsFunctions;
import com.pulumi.gcp.organizations.inputs.GetBillingAccountArgs;
import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
import com.pulumi.gcp.billing.Budget;
import com.pulumi.gcp.billing.BudgetArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountSpecifiedAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetThresholdRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var account = OrganizationsFunctions.getBillingAccount(GetBillingAccountArgs.builder()
.billingAccount("000000-0000000-0000000-000000")
.build());
final var project = OrganizationsFunctions.getProject();
var budget = new Budget("budget", BudgetArgs.builder()
.billingAccount(account.applyValue(getBillingAccountResult -> getBillingAccountResult.id()))
.displayName("Example Billing Budget")
.budgetFilter(BudgetBudgetFilterArgs.builder()
.projects(String.format("projects/%s", project.applyValue(getProjectResult -> getProjectResult.number())))
.creditTypesTreatment("INCLUDE_SPECIFIED_CREDITS")
.services("services/24E6-581D-38E5")
.creditTypes(
"PROMOTION",
"FREE_TIER")
.resourceAncestors("organizations/123456789")
.build())
.amount(BudgetAmountArgs.builder()
.specifiedAmount(BudgetAmountSpecifiedAmountArgs.builder()
.currencyCode("USD")
.units("100000")
.build())
.build())
.thresholdRules(
BudgetThresholdRuleArgs.builder()
.thresholdPercent(0.5)
.build(),
BudgetThresholdRuleArgs.builder()
.thresholdPercent(0.9)
.spendBasis("FORECASTED_SPEND")
.build())
.build());
}
}

Billing Budget Notify

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.organizations.OrganizationsFunctions;
import com.pulumi.gcp.organizations.inputs.GetBillingAccountArgs;
import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
import com.pulumi.gcp.monitoring.NotificationChannel;
import com.pulumi.gcp.monitoring.NotificationChannelArgs;
import com.pulumi.gcp.billing.Budget;
import com.pulumi.gcp.billing.BudgetArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountSpecifiedAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetThresholdRuleArgs;
import com.pulumi.gcp.billing.inputs.BudgetAllUpdatesRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var account = OrganizationsFunctions.getBillingAccount(GetBillingAccountArgs.builder()
.billingAccount("000000-0000000-0000000-000000")
.build());
final var project = OrganizationsFunctions.getProject();
var notificationChannel = new NotificationChannel("notificationChannel", NotificationChannelArgs.builder()
.displayName("Example Notification Channel")
.type("email")
.labels(Map.of("email_address", "address@example.com"))
.build());
var budget = new Budget("budget", BudgetArgs.builder()
.billingAccount(account.applyValue(getBillingAccountResult -> getBillingAccountResult.id()))
.displayName("Example Billing Budget")
.budgetFilter(BudgetBudgetFilterArgs.builder()
.projects(String.format("projects/%s", project.applyValue(getProjectResult -> getProjectResult.number())))
.build())
.amount(BudgetAmountArgs.builder()
.specifiedAmount(BudgetAmountSpecifiedAmountArgs.builder()
.currencyCode("USD")
.units("100000")
.build())
.build())
.thresholdRules(
BudgetThresholdRuleArgs.builder()
.thresholdPercent(1)
.build(),
BudgetThresholdRuleArgs.builder()
.thresholdPercent(1)
.spendBasis("FORECASTED_SPEND")
.build())
.allUpdatesRule(BudgetAllUpdatesRuleArgs.builder()
.monitoringNotificationChannels(notificationChannel.id())
.disableDefaultIamRecipients(true)
.build())
.build());
}
}

Billing Budget Customperiod

package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.gcp.organizations.OrganizationsFunctions;
import com.pulumi.gcp.organizations.inputs.GetBillingAccountArgs;
import com.pulumi.gcp.organizations.inputs.GetProjectArgs;
import com.pulumi.gcp.billing.Budget;
import com.pulumi.gcp.billing.BudgetArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterCustomPeriodArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterCustomPeriodStartDateArgs;
import com.pulumi.gcp.billing.inputs.BudgetBudgetFilterCustomPeriodEndDateArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetAmountSpecifiedAmountArgs;
import com.pulumi.gcp.billing.inputs.BudgetThresholdRuleArgs;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var account = OrganizationsFunctions.getBillingAccount(GetBillingAccountArgs.builder()
.billingAccount("000000-0000000-0000000-000000")
.build());
final var project = OrganizationsFunctions.getProject();
var budget = new Budget("budget", BudgetArgs.builder()
.billingAccount(account.applyValue(getBillingAccountResult -> getBillingAccountResult.id()))
.displayName("Example Billing Budget")
.budgetFilter(BudgetBudgetFilterArgs.builder()
.projects(String.format("projects/%s", project.applyValue(getProjectResult -> getProjectResult.number())))
.creditTypesTreatment("EXCLUDE_ALL_CREDITS")
.services("services/24E6-581D-38E5")
.customPeriod(BudgetBudgetFilterCustomPeriodArgs.builder()
.startDate(BudgetBudgetFilterCustomPeriodStartDateArgs.builder()
.year(2022)
.month(1)
.day(1)
.build())
.endDate(BudgetBudgetFilterCustomPeriodEndDateArgs.builder()
.year(2023)
.month(12)
.day(31)
.build())
.build())
.build())
.amount(BudgetAmountArgs.builder()
.specifiedAmount(BudgetAmountSpecifiedAmountArgs.builder()
.currencyCode("USD")
.units("100000")
.build())
.build())
.thresholdRules(
BudgetThresholdRuleArgs.builder()
.thresholdPercent(0.5)
.build(),
BudgetThresholdRuleArgs.builder()
.thresholdPercent(0.9)
.build())
.build());
}
}

Import

Budget can be imported using any of these accepted formats

$ pulumi import gcp:billing/budget:Budget default billingAccounts/{{billing_account}}/budgets/{{name}}
$ pulumi import gcp:billing/budget:Budget default {{billing_account}}/{{name}}
$ pulumi import gcp:billing/budget:Budget default {{name}}

Properties

Link copied to clipboard

Defines notifications that are sent on every update to the billing account's spend, regardless of the thresholds defined using threshold rules. Structure is documented below.

Link copied to clipboard
val amount: Output<BudgetAmount>

The budgeted amount for each usage period. Structure is documented below.

Link copied to clipboard
val billingAccount: Output<String>

ID of the billing account to set a budget on.

Link copied to clipboard

Filters that define which resources are used to compute the actual spend against the budget. Structure is documented below.

Link copied to clipboard
val displayName: Output<String>?

User data for display name in UI. Must be <= 60 chars.

Link copied to clipboard
val id: Output<String>
Link copied to clipboard
val name: Output<String>

Resource name of the budget. The resource name implies the scope of a budget. Values are of the form billingAccounts/{billingAccountId}/budgets/{budgetId}.

Link copied to clipboard
val pulumiChildResources: Set<KotlinResource>
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard

Rules that trigger alerts (notifications of thresholds being crossed) when spend exceeds the specified percentages of the budget. Structure is documented below.

Link copied to clipboard
val urn: Output<String>