2019-11-22 00:37:17 +00:00
|
|
|
# Copyright 2015 Google Inc.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License 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.
|
|
|
|
|
|
|
|
require 'date'
|
|
|
|
require 'google/apis/core/base_service'
|
|
|
|
require 'google/apis/core/json_representation'
|
|
|
|
require 'google/apis/core/hashable'
|
|
|
|
require 'google/apis/errors'
|
|
|
|
|
|
|
|
module Google
|
|
|
|
module Apis
|
|
|
|
module BillingbudgetsV1beta1
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# AllUpdatesRule defines notifications that are sent based on budget spend and
|
|
|
|
# thresholds.
|
2019-11-22 00:37:17 +00:00
|
|
|
class GoogleCloudBillingBudgetsV1beta1AllUpdatesRule
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-09-15 00:38:05 +00:00
|
|
|
# Optional. When set to true, disables default notifications sent when a
|
|
|
|
# threshold is exceeded. Default notifications are sent to those with Billing
|
|
|
|
# Account Administrator and Billing Account User IAM roles for the target
|
|
|
|
# account.
|
|
|
|
# Corresponds to the JSON property `disableDefaultIamRecipients`
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :disable_default_iam_recipients
|
|
|
|
alias_method :disable_default_iam_recipients?, :disable_default_iam_recipients
|
|
|
|
|
2020-07-15 00:38:40 +00:00
|
|
|
# Optional. Targets to send notifications to when a threshold is exceeded. This
|
2020-09-15 00:38:05 +00:00
|
|
|
# is in addition to default recipients who have billing account IAM roles. The
|
|
|
|
# value is the full REST resource name of a monitoring notification channel with
|
|
|
|
# the form `projects/`project_id`/notificationChannels/`channel_id``. A maximum
|
|
|
|
# of 5 channels are allowed. See https://cloud.google.com/billing/docs/how-to/
|
|
|
|
# budgets-notification-recipients for more details.
|
2020-07-15 00:38:40 +00:00
|
|
|
# Corresponds to the JSON property `monitoringNotificationChannels`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :monitoring_notification_channels
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. The name of the Pub/Sub topic where budget related messages will be
|
|
|
|
# published, in the form `projects/`project_id`/topics/`topic_id``. Updates are
|
|
|
|
# sent at regular intervals to the topic. The topic needs to be created before
|
|
|
|
# the budget is created; see https://cloud.google.com/billing/docs/how-to/
|
|
|
|
# budgets#manage-notifications for more details. Caller is expected to have `
|
|
|
|
# pubsub.topics.setIamPolicy` permission on the topic when it's set for a budget,
|
|
|
|
# otherwise, the API call will fail with PERMISSION_DENIED. See https://cloud.
|
|
|
|
# google.com/billing/docs/how-to/budgets-programmatic-notifications for more
|
|
|
|
# details on Pub/Sub roles and permissions.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `pubsubTopic`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :pubsub_topic
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. The schema version of the notification sent to `pubsub_topic`. Only "
|
|
|
|
# 1.0" is accepted. It represents the JSON schema as defined in https://cloud.
|
|
|
|
# google.com/billing/docs/how-to/budgets-programmatic-notifications#
|
|
|
|
# notification_format
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `schemaVersion`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :schema_version
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
2020-09-15 00:38:05 +00:00
|
|
|
@disable_default_iam_recipients = args[:disable_default_iam_recipients] if args.key?(:disable_default_iam_recipients)
|
2020-07-15 00:38:40 +00:00
|
|
|
@monitoring_notification_channels = args[:monitoring_notification_channels] if args.key?(:monitoring_notification_channels)
|
2019-11-22 00:37:17 +00:00
|
|
|
@pubsub_topic = args[:pubsub_topic] if args.key?(:pubsub_topic)
|
|
|
|
@schema_version = args[:schema_version] if args.key?(:schema_version)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# A budget is a plan that describes what you expect to spend on Cloud projects,
|
|
|
|
# plus the rules to execute as spend is tracked against that plan, (for example,
|
|
|
|
# send an alert when 90% of the target spend is met). Currently all plans are
|
|
|
|
# monthly budgets so the usage period(s) tracked are implied (calendar months of
|
|
|
|
# usage back-to-back).
|
2019-11-22 00:37:17 +00:00
|
|
|
class GoogleCloudBillingBudgetsV1beta1Budget
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# AllUpdatesRule defines notifications that are sent based on budget spend and
|
|
|
|
# thresholds.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `allUpdatesRule`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1AllUpdatesRule]
|
|
|
|
attr_accessor :all_updates_rule
|
|
|
|
|
|
|
|
# The budgeted amount for each usage period.
|
|
|
|
# Corresponds to the JSON property `amount`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1BudgetAmount]
|
|
|
|
attr_accessor :amount
|
|
|
|
|
|
|
|
# A filter for a budget, limiting the scope of the cost to calculate.
|
|
|
|
# Corresponds to the JSON property `budgetFilter`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1Filter]
|
|
|
|
attr_accessor :budget_filter
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# User data for display name in UI. Validation: <= 60 chars.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `displayName`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :display_name
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. Etag to validate that the object is unchanged for a read-modify-
|
|
|
|
# write operation. An empty etag will cause an update to overwrite other changes.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `etag`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :etag
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Output only. Resource name of the budget. The resource name implies the scope
|
|
|
|
# of a budget. Values are of the form `billingAccounts/`billingAccountId`/
|
|
|
|
# budgets/`budgetId``.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `name`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :name
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. Rules that trigger alerts (notifications of thresholds being crossed)
|
|
|
|
# when spend exceeds the specified percentages of the budget.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `thresholdRules`
|
|
|
|
# @return [Array<Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1ThresholdRule>]
|
|
|
|
attr_accessor :threshold_rules
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@all_updates_rule = args[:all_updates_rule] if args.key?(:all_updates_rule)
|
|
|
|
@amount = args[:amount] if args.key?(:amount)
|
|
|
|
@budget_filter = args[:budget_filter] if args.key?(:budget_filter)
|
|
|
|
@display_name = args[:display_name] if args.key?(:display_name)
|
|
|
|
@etag = args[:etag] if args.key?(:etag)
|
|
|
|
@name = args[:name] if args.key?(:name)
|
|
|
|
@threshold_rules = args[:threshold_rules] if args.key?(:threshold_rules)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# The budgeted amount for each usage period.
|
|
|
|
class GoogleCloudBillingBudgetsV1beta1BudgetAmount
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Describes a budget amount targeted to last period's spend. At this time, the
|
|
|
|
# amount is automatically 100% of last period's spend; that is, there are no
|
|
|
|
# other options yet. Future configuration will be described here (for example,
|
|
|
|
# configuring a percentage of last period's spend).
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `lastPeriodAmount`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1LastPeriodAmount]
|
|
|
|
attr_accessor :last_period_amount
|
|
|
|
|
|
|
|
# Represents an amount of money with its currency type.
|
|
|
|
# Corresponds to the JSON property `specifiedAmount`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleTypeMoney]
|
|
|
|
attr_accessor :specified_amount
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@last_period_amount = args[:last_period_amount] if args.key?(:last_period_amount)
|
|
|
|
@specified_amount = args[:specified_amount] if args.key?(:specified_amount)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Request for CreateBudget
|
|
|
|
class GoogleCloudBillingBudgetsV1beta1CreateBudgetRequest
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# A budget is a plan that describes what you expect to spend on Cloud projects,
|
|
|
|
# plus the rules to execute as spend is tracked against that plan, (for example,
|
|
|
|
# send an alert when 90% of the target spend is met). Currently all plans are
|
|
|
|
# monthly budgets so the usage period(s) tracked are implied (calendar months of
|
|
|
|
# usage back-to-back).
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `budget`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1Budget]
|
|
|
|
attr_accessor :budget
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@budget = args[:budget] if args.key?(:budget)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A filter for a budget, limiting the scope of the cost to calculate.
|
|
|
|
class GoogleCloudBillingBudgetsV1beta1Filter
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
feat: Automated regeneration of billingbudgets v1beta1 client (#1289)
This PR was generated using Autosynth. :rainbow:
<details><summary>Log from Synthtool</summary>
```
2020-10-28 01:44:37,749 synthtool [DEBUG] > Executing /home/kbuilder/.cache/synthtool/google-api-ruby-client/synth.py.
On branch autosynth-billingbudgets-v1beta1
nothing to commit, working tree clean
2020-10-28 01:44:37,778 synthtool [DEBUG] > Running: docker run --rm -v/home/kbuilder/.cache/synthtool/google-api-ruby-client:/workspace -v/var/run/docker.sock:/var/run/docker.sock -w /workspace --entrypoint script/synth.rb gcr.io/cloud-devrel-kokoro-resources/yoshi-ruby/autosynth billingbudgets v1beta1
DEBUG:synthtool:Running: docker run --rm -v/home/kbuilder/.cache/synthtool/google-api-ruby-client:/workspace -v/var/run/docker.sock:/var/run/docker.sock -w /workspace --entrypoint script/synth.rb gcr.io/cloud-devrel-kokoro-resources/yoshi-ruby/autosynth billingbudgets v1beta1
bundle install
Don't run Bundler as root. Bundler can ask for sudo if it is needed, and
installing your bundle as root will break this application for all non-root
users on this machine.
The dependency jruby-openssl (>= 0) will be unused by any of the platforms Bundler is installing for. Bundler is installing for ruby but the dependency is only for java. To add those platforms to the bundle, run `bundle lock --add-platform java`.
Fetching gem metadata from https://rubygems.org/.........
Fetching gem metadata from https://rubygems.org/.
Resolving dependencies...
Fetching rake 11.3.0
Installing rake 11.3.0
Fetching concurrent-ruby 1.1.7
Installing concurrent-ruby 1.1.7
Fetching i18n 1.8.5
Installing i18n 1.8.5
Fetching minitest 5.14.2
Installing minitest 5.14.2
Fetching thread_safe 0.3.6
Installing thread_safe 0.3.6
Fetching tzinfo 1.2.7
Installing tzinfo 1.2.7
Fetching activesupport 5.0.7.2
Installing activesupport 5.0.7.2
Fetching public_suffix 4.0.6
Installing public_suffix 4.0.6
Fetching addressable 2.7.0
Installing addressable 2.7.0
Fetching ast 2.4.1
Installing ast 2.4.1
Using bundler 2.1.4
Fetching byebug 11.1.3
Installing byebug 11.1.3 with native extensions
Fetching coderay 1.1.3
Installing coderay 1.1.3
Fetching json 2.3.1
Installing json 2.3.1 with native extensions
Fetching docile 1.3.2
Installing docile 1.3.2
Fetching simplecov-html 0.10.2
Installing simplecov-html 0.10.2
Fetching simplecov 0.16.1
Installing simplecov 0.16.1
Using sync 0.5.0
Fetching tins 1.26.0
Installing tins 1.26.0
Fetching term-ansicolor 1.7.1
Installing term-ansicolor 1.7.1
Fetching thor 0.20.3
Installing thor 0.20.3
Fetching coveralls 0.8.23
Installing coveralls 0.8.23
Fetching crack 0.4.4
Installing crack 0.4.4
Fetching declarative 0.0.20
Installing declarative 0.0.20
Fetching declarative-option 0.1.0
Installing declarative-option 0.1.0
Fetching diff-lcs 1.4.4
Installing diff-lcs 1.4.4
Fetching dotenv 2.7.6
Installing dotenv 2.7.6
Fetching fakefs 0.20.1
Installing fakefs 0.20.1
Fetching multipart-post 2.1.1
Installing multipart-post 2.1.1
Fetching ruby2_keywords 0.0.2
Installing ruby2_keywords 0.0.2
Fetching faraday 1.1.0
Installing faraday 1.1.0
Fetching gems 1.2.0
Installing gems 1.2.0
Fetching github-markup 1.7.0
Installing github-markup 1.7.0
Fetching jwt 2.2.2
Installing jwt 2.2.2
Fetching memoist 0.16.2
Installing memoist 0.16.2
Fetching multi_json 1.15.0
Installing multi_json 1.15.0
Fetching os 0.9.6
Installing os 0.9.6
Fetching signet 0.14.0
Installing signet 0.14.0
Fetching googleauth 0.14.0
Installing googleauth 0.14.0
Fetching httpclient 2.8.3
Installing httpclient 2.8.3
Fetching mini_mime 1.0.2
Installing mini_mime 1.0.2
Fetching uber 0.1.0
Installing uber 0.1.0
Fetching representable 3.0.4
Installing representable 3.0.4
Fetching retriable 3.1.2
Installing retriable 3.1.2
Fetching rexml 3.2.4
Installing rexml 3.2.4
Using google-api-client 0.47.0 from source at `.`
Fetching google-id-token 1.4.2
Installing google-id-token 1.4.2
Fetching hashdiff 1.0.1
Installing hashdiff 1.0.1
Fetching mime-types-data 3.2020.0512
Installing mime-types-data 3.2020.0512
Fetching mime-types 3.3.1
Installing mime-types 3.3.1
Fetching multi_xml 0.6.0
Installing multi_xml 0.6.0
Fetching httparty 0.18.1
Installing httparty 0.18.1
Fetching rspec-support 3.9.4
Installing rspec-support 3.9.4
Fetching rspec-core 3.9.3
Installing rspec-core 3.9.3
Fetching rspec-expectations 3.9.3
Installing rspec-expectations 3.9.3
Fetching rspec-mocks 3.9.1
Installing rspec-mocks 3.9.1
Fetching rspec 3.9.0
Installing rspec 3.9.0
Fetching json_spec 1.1.5
Installing json_spec 1.1.5
Fetching launchy 2.5.0
Installing launchy 2.5.0
Fetching little-plugger 1.1.4
Installing little-plugger 1.1.4
Fetching logging 2.3.0
Installing logging 2.3.0
Fetching method_source 1.0.0
Installing method_source 1.0.0
Fetching opencensus 0.5.0
Installing opencensus 0.5.0
Fetching parallel 1.19.2
Installing parallel 1.19.2
Fetching parser 2.7.2.0
Installing parser 2.7.2.0
Fetching powerpack 0.1.2
Installing powerpack 0.1.2
Fetching pry 0.13.1
Installing pry 0.13.1
Fetching pry-byebug 3.9.0
Installing pry-byebug 3.9.0
Fetching yard 0.9.25
Installing yard 0.9.25
Fetching pry-doc 0.13.5
Installing pry-doc 0.13.5
Fetching rainbow 2.2.2
Installing rainbow 2.2.2 with native extensions
Fetching redcarpet 3.5.0
Installing redcarpet 3.5.0 with native extensions
Fetching redis 3.3.5
Installing redis 3.3.5
Fetching rmail 1.1.4
Installing rmail 1.1.4
Fetching ruby-progressbar 1.10.1
Installing ruby-progressbar 1.10.1
Fetching unicode-display_width 1.7.0
Installing unicode-display_width 1.7.0
Fetching rubocop 0.49.1
Installing rubocop 0.49.1
Fetching webmock 2.3.2
Installing webmock 2.3.2
Bundle complete! 31 Gemfile dependencies, 78 gems now installed.
Use `bundle info [gemname]` to see where a bundled gem is installed.
Post-install message from i18n:
HEADS UP! i18n 1.1 changed fallbacks to exclude default locale.
But that may break your application.
If you are upgrading your Rails application from an older version of Rails:
Please check your Rails app for 'config.i18n.fallbacks = true'.
If you're using I18n (>= 1.1.0) and Rails (< 5.2.2), this should be
'config.i18n.fallbacks = [I18n.default_locale]'.
If not, fallbacks will be broken in your app by I18n 1.1.x.
If you are starting a NEW Rails application, you can ignore this notice.
For more info see:
https://github.com/svenfuchs/i18n/releases/tag/v1.1.0
Post-install message from httparty:
When you HTTParty, you must party hard!
echo a | bundle exec bin/generate-api gen generated --api=billingbudgets.v1beta1 --names-out=/workspace/api_names_out.yaml
Loading billingbudgets, version v1beta1 from https://raw.githubusercontent.com/googleapis/discovery-artifact-manager/master/discoveries/billingbudgets.v1beta1.json
conflict google/apis/billingbudgets_v1beta1.rb
<budgets_v1beta1.rb? (enter "h" for help) [Ynaqdhm] a
force google/apis/billingbudgets_v1beta1.rb
identical google/apis/billingbudgets_v1beta1/service.rb
conflict google/apis/billingbudgets_v1beta1/classes.rb
force google/apis/billingbudgets_v1beta1/classes.rb
conflict google/apis/billingbudgets_v1beta1/representations.rb
force google/apis/billingbudgets_v1beta1/representations.rb
conflict /workspace/api_names_out.yaml
force /workspace/api_names_out.yaml
2020-10-28 01:45:07,522 synthtool [DEBUG] > Wrote metadata to generated/google/apis/billingbudgets_v1beta1/synth.metadata.
DEBUG:synthtool:Wrote metadata to generated/google/apis/billingbudgets_v1beta1/synth.metadata.
```
</details>
Full log will be available here:
https://source.cloud.google.com/results/invocations/fc014795-ecad-4bb9-a08f-f26793ec33cc/targets
- [ ] To automatically regenerate this PR, check this box.
2020-10-28 08:58:03 +00:00
|
|
|
# Optional. A list of credit types to be subtracted from gross cost to determine
|
|
|
|
# the spend for threshold calculations if and only if credit_types_treatment is
|
|
|
|
# INCLUDE_SPECIFIED_CREDITS. If credit_types_treatment is not
|
|
|
|
# INCLUDE_SPECIFIED_CREDITS, this field must be empty. See credits.type at https:
|
|
|
|
# //cloud.google.com/billing/docs/how-to/export-data-bigquery-tables#data-schema
|
|
|
|
# for a list of acceptable credit type values in this field.
|
|
|
|
# Corresponds to the JSON property `creditTypes`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :credit_types
|
|
|
|
|
2019-11-22 00:37:17 +00:00
|
|
|
# Optional. If not set, default behavior is `INCLUDE_ALL_CREDITS`.
|
|
|
|
# Corresponds to the JSON property `creditTypesTreatment`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :credit_types_treatment
|
|
|
|
|
2020-05-20 00:37:45 +00:00
|
|
|
# Optional. A single label and value pair specifying that usage from only this
|
2020-08-04 00:38:33 +00:00
|
|
|
# set of labeled resources should be included in the budget. Currently, multiple
|
|
|
|
# entries or multiple values per entry are not allowed. If omitted, the report
|
|
|
|
# will include all labeled and unlabeled usage.
|
2020-05-20 00:37:45 +00:00
|
|
|
# Corresponds to the JSON property `labels`
|
|
|
|
# @return [Hash<String,Array<Object>>]
|
|
|
|
attr_accessor :labels
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. A set of projects of the form `projects/`project``, specifying that
|
|
|
|
# usage from only this set of projects should be included in the budget. If
|
|
|
|
# omitted, the report will include all usage for the billing account, regardless
|
|
|
|
# of which project the usage occurred on. Only zero or one project can be
|
|
|
|
# specified currently.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `projects`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :projects
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. A set of services of the form `services/`service_id``, specifying
|
|
|
|
# that usage from only this set of services should be included in the budget. If
|
|
|
|
# omitted, the report will include usage for all the services. The service names
|
|
|
|
# are available through the Catalog API: https://cloud.google.com/billing/v1/how-
|
|
|
|
# tos/catalog-api.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `services`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :services
|
|
|
|
|
2020-05-20 00:37:45 +00:00
|
|
|
# Optional. A set of subaccounts of the form `billingAccounts/`account_id``,
|
2020-08-04 00:38:33 +00:00
|
|
|
# specifying that usage from only this set of subaccounts should be included in
|
|
|
|
# the budget. If a subaccount is set to the name of the parent account, usage
|
|
|
|
# from the parent account will be included. If omitted, the report will include
|
|
|
|
# usage from the parent account and all subaccounts, if they exist.
|
2020-05-20 00:37:45 +00:00
|
|
|
# Corresponds to the JSON property `subaccounts`
|
|
|
|
# @return [Array<String>]
|
|
|
|
attr_accessor :subaccounts
|
|
|
|
|
2019-11-22 00:37:17 +00:00
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
feat: Automated regeneration of billingbudgets v1beta1 client (#1289)
This PR was generated using Autosynth. :rainbow:
<details><summary>Log from Synthtool</summary>
```
2020-10-28 01:44:37,749 synthtool [DEBUG] > Executing /home/kbuilder/.cache/synthtool/google-api-ruby-client/synth.py.
On branch autosynth-billingbudgets-v1beta1
nothing to commit, working tree clean
2020-10-28 01:44:37,778 synthtool [DEBUG] > Running: docker run --rm -v/home/kbuilder/.cache/synthtool/google-api-ruby-client:/workspace -v/var/run/docker.sock:/var/run/docker.sock -w /workspace --entrypoint script/synth.rb gcr.io/cloud-devrel-kokoro-resources/yoshi-ruby/autosynth billingbudgets v1beta1
DEBUG:synthtool:Running: docker run --rm -v/home/kbuilder/.cache/synthtool/google-api-ruby-client:/workspace -v/var/run/docker.sock:/var/run/docker.sock -w /workspace --entrypoint script/synth.rb gcr.io/cloud-devrel-kokoro-resources/yoshi-ruby/autosynth billingbudgets v1beta1
bundle install
Don't run Bundler as root. Bundler can ask for sudo if it is needed, and
installing your bundle as root will break this application for all non-root
users on this machine.
The dependency jruby-openssl (>= 0) will be unused by any of the platforms Bundler is installing for. Bundler is installing for ruby but the dependency is only for java. To add those platforms to the bundle, run `bundle lock --add-platform java`.
Fetching gem metadata from https://rubygems.org/.........
Fetching gem metadata from https://rubygems.org/.
Resolving dependencies...
Fetching rake 11.3.0
Installing rake 11.3.0
Fetching concurrent-ruby 1.1.7
Installing concurrent-ruby 1.1.7
Fetching i18n 1.8.5
Installing i18n 1.8.5
Fetching minitest 5.14.2
Installing minitest 5.14.2
Fetching thread_safe 0.3.6
Installing thread_safe 0.3.6
Fetching tzinfo 1.2.7
Installing tzinfo 1.2.7
Fetching activesupport 5.0.7.2
Installing activesupport 5.0.7.2
Fetching public_suffix 4.0.6
Installing public_suffix 4.0.6
Fetching addressable 2.7.0
Installing addressable 2.7.0
Fetching ast 2.4.1
Installing ast 2.4.1
Using bundler 2.1.4
Fetching byebug 11.1.3
Installing byebug 11.1.3 with native extensions
Fetching coderay 1.1.3
Installing coderay 1.1.3
Fetching json 2.3.1
Installing json 2.3.1 with native extensions
Fetching docile 1.3.2
Installing docile 1.3.2
Fetching simplecov-html 0.10.2
Installing simplecov-html 0.10.2
Fetching simplecov 0.16.1
Installing simplecov 0.16.1
Using sync 0.5.0
Fetching tins 1.26.0
Installing tins 1.26.0
Fetching term-ansicolor 1.7.1
Installing term-ansicolor 1.7.1
Fetching thor 0.20.3
Installing thor 0.20.3
Fetching coveralls 0.8.23
Installing coveralls 0.8.23
Fetching crack 0.4.4
Installing crack 0.4.4
Fetching declarative 0.0.20
Installing declarative 0.0.20
Fetching declarative-option 0.1.0
Installing declarative-option 0.1.0
Fetching diff-lcs 1.4.4
Installing diff-lcs 1.4.4
Fetching dotenv 2.7.6
Installing dotenv 2.7.6
Fetching fakefs 0.20.1
Installing fakefs 0.20.1
Fetching multipart-post 2.1.1
Installing multipart-post 2.1.1
Fetching ruby2_keywords 0.0.2
Installing ruby2_keywords 0.0.2
Fetching faraday 1.1.0
Installing faraday 1.1.0
Fetching gems 1.2.0
Installing gems 1.2.0
Fetching github-markup 1.7.0
Installing github-markup 1.7.0
Fetching jwt 2.2.2
Installing jwt 2.2.2
Fetching memoist 0.16.2
Installing memoist 0.16.2
Fetching multi_json 1.15.0
Installing multi_json 1.15.0
Fetching os 0.9.6
Installing os 0.9.6
Fetching signet 0.14.0
Installing signet 0.14.0
Fetching googleauth 0.14.0
Installing googleauth 0.14.0
Fetching httpclient 2.8.3
Installing httpclient 2.8.3
Fetching mini_mime 1.0.2
Installing mini_mime 1.0.2
Fetching uber 0.1.0
Installing uber 0.1.0
Fetching representable 3.0.4
Installing representable 3.0.4
Fetching retriable 3.1.2
Installing retriable 3.1.2
Fetching rexml 3.2.4
Installing rexml 3.2.4
Using google-api-client 0.47.0 from source at `.`
Fetching google-id-token 1.4.2
Installing google-id-token 1.4.2
Fetching hashdiff 1.0.1
Installing hashdiff 1.0.1
Fetching mime-types-data 3.2020.0512
Installing mime-types-data 3.2020.0512
Fetching mime-types 3.3.1
Installing mime-types 3.3.1
Fetching multi_xml 0.6.0
Installing multi_xml 0.6.0
Fetching httparty 0.18.1
Installing httparty 0.18.1
Fetching rspec-support 3.9.4
Installing rspec-support 3.9.4
Fetching rspec-core 3.9.3
Installing rspec-core 3.9.3
Fetching rspec-expectations 3.9.3
Installing rspec-expectations 3.9.3
Fetching rspec-mocks 3.9.1
Installing rspec-mocks 3.9.1
Fetching rspec 3.9.0
Installing rspec 3.9.0
Fetching json_spec 1.1.5
Installing json_spec 1.1.5
Fetching launchy 2.5.0
Installing launchy 2.5.0
Fetching little-plugger 1.1.4
Installing little-plugger 1.1.4
Fetching logging 2.3.0
Installing logging 2.3.0
Fetching method_source 1.0.0
Installing method_source 1.0.0
Fetching opencensus 0.5.0
Installing opencensus 0.5.0
Fetching parallel 1.19.2
Installing parallel 1.19.2
Fetching parser 2.7.2.0
Installing parser 2.7.2.0
Fetching powerpack 0.1.2
Installing powerpack 0.1.2
Fetching pry 0.13.1
Installing pry 0.13.1
Fetching pry-byebug 3.9.0
Installing pry-byebug 3.9.0
Fetching yard 0.9.25
Installing yard 0.9.25
Fetching pry-doc 0.13.5
Installing pry-doc 0.13.5
Fetching rainbow 2.2.2
Installing rainbow 2.2.2 with native extensions
Fetching redcarpet 3.5.0
Installing redcarpet 3.5.0 with native extensions
Fetching redis 3.3.5
Installing redis 3.3.5
Fetching rmail 1.1.4
Installing rmail 1.1.4
Fetching ruby-progressbar 1.10.1
Installing ruby-progressbar 1.10.1
Fetching unicode-display_width 1.7.0
Installing unicode-display_width 1.7.0
Fetching rubocop 0.49.1
Installing rubocop 0.49.1
Fetching webmock 2.3.2
Installing webmock 2.3.2
Bundle complete! 31 Gemfile dependencies, 78 gems now installed.
Use `bundle info [gemname]` to see where a bundled gem is installed.
Post-install message from i18n:
HEADS UP! i18n 1.1 changed fallbacks to exclude default locale.
But that may break your application.
If you are upgrading your Rails application from an older version of Rails:
Please check your Rails app for 'config.i18n.fallbacks = true'.
If you're using I18n (>= 1.1.0) and Rails (< 5.2.2), this should be
'config.i18n.fallbacks = [I18n.default_locale]'.
If not, fallbacks will be broken in your app by I18n 1.1.x.
If you are starting a NEW Rails application, you can ignore this notice.
For more info see:
https://github.com/svenfuchs/i18n/releases/tag/v1.1.0
Post-install message from httparty:
When you HTTParty, you must party hard!
echo a | bundle exec bin/generate-api gen generated --api=billingbudgets.v1beta1 --names-out=/workspace/api_names_out.yaml
Loading billingbudgets, version v1beta1 from https://raw.githubusercontent.com/googleapis/discovery-artifact-manager/master/discoveries/billingbudgets.v1beta1.json
conflict google/apis/billingbudgets_v1beta1.rb
<budgets_v1beta1.rb? (enter "h" for help) [Ynaqdhm] a
force google/apis/billingbudgets_v1beta1.rb
identical google/apis/billingbudgets_v1beta1/service.rb
conflict google/apis/billingbudgets_v1beta1/classes.rb
force google/apis/billingbudgets_v1beta1/classes.rb
conflict google/apis/billingbudgets_v1beta1/representations.rb
force google/apis/billingbudgets_v1beta1/representations.rb
conflict /workspace/api_names_out.yaml
force /workspace/api_names_out.yaml
2020-10-28 01:45:07,522 synthtool [DEBUG] > Wrote metadata to generated/google/apis/billingbudgets_v1beta1/synth.metadata.
DEBUG:synthtool:Wrote metadata to generated/google/apis/billingbudgets_v1beta1/synth.metadata.
```
</details>
Full log will be available here:
https://source.cloud.google.com/results/invocations/fc014795-ecad-4bb9-a08f-f26793ec33cc/targets
- [ ] To automatically regenerate this PR, check this box.
2020-10-28 08:58:03 +00:00
|
|
|
@credit_types = args[:credit_types] if args.key?(:credit_types)
|
2019-11-22 00:37:17 +00:00
|
|
|
@credit_types_treatment = args[:credit_types_treatment] if args.key?(:credit_types_treatment)
|
2020-05-20 00:37:45 +00:00
|
|
|
@labels = args[:labels] if args.key?(:labels)
|
2019-11-22 00:37:17 +00:00
|
|
|
@projects = args[:projects] if args.key?(:projects)
|
|
|
|
@services = args[:services] if args.key?(:services)
|
2020-05-20 00:37:45 +00:00
|
|
|
@subaccounts = args[:subaccounts] if args.key?(:subaccounts)
|
2019-11-22 00:37:17 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Describes a budget amount targeted to last period's spend. At this time, the
|
|
|
|
# amount is automatically 100% of last period's spend; that is, there are no
|
|
|
|
# other options yet. Future configuration will be described here (for example,
|
|
|
|
# configuring a percentage of last period's spend).
|
2019-11-22 00:37:17 +00:00
|
|
|
class GoogleCloudBillingBudgetsV1beta1LastPeriodAmount
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Response for ListBudgets
|
|
|
|
class GoogleCloudBillingBudgetsV1beta1ListBudgetsResponse
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# List of the budgets owned by the requested billing account.
|
|
|
|
# Corresponds to the JSON property `budgets`
|
|
|
|
# @return [Array<Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1Budget>]
|
|
|
|
attr_accessor :budgets
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# If not empty, indicates that there may be more budgets that match the request;
|
|
|
|
# this value should be passed in a new `ListBudgetsRequest`.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `nextPageToken`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :next_page_token
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@budgets = args[:budgets] if args.key?(:budgets)
|
|
|
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# ThresholdRule contains a definition of a threshold which triggers an alert (a
|
|
|
|
# notification of a threshold being crossed) to be sent when spend goes above
|
|
|
|
# the specified amount. Alerts are automatically e-mailed to users with the
|
|
|
|
# Billing Account Administrator role or the Billing Account User role. The
|
|
|
|
# thresholds here have no effect on notifications sent to anything configured
|
|
|
|
# under `Budget.all_updates_rule`.
|
2019-11-22 00:37:17 +00:00
|
|
|
class GoogleCloudBillingBudgetsV1beta1ThresholdRule
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
# Optional. The type of basis used to determine if spend has passed the
|
|
|
|
# threshold. Behavior defaults to CURRENT_SPEND if not set.
|
|
|
|
# Corresponds to the JSON property `spendBasis`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :spend_basis
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Required. Send an alert when this threshold is exceeded. This is a 1.0-based
|
|
|
|
# percentage, so 0.5 = 50%. Validation: non-negative number.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `thresholdPercent`
|
|
|
|
# @return [Float]
|
|
|
|
attr_accessor :threshold_percent
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@spend_basis = args[:spend_basis] if args.key?(:spend_basis)
|
|
|
|
@threshold_percent = args[:threshold_percent] if args.key?(:threshold_percent)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Request for UpdateBudget
|
|
|
|
class GoogleCloudBillingBudgetsV1beta1UpdateBudgetRequest
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# A budget is a plan that describes what you expect to spend on Cloud projects,
|
|
|
|
# plus the rules to execute as spend is tracked against that plan, (for example,
|
|
|
|
# send an alert when 90% of the target spend is met). Currently all plans are
|
|
|
|
# monthly budgets so the usage period(s) tracked are implied (calendar months of
|
|
|
|
# usage back-to-back).
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `budget`
|
|
|
|
# @return [Google::Apis::BillingbudgetsV1beta1::GoogleCloudBillingBudgetsV1beta1Budget]
|
|
|
|
attr_accessor :budget
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Optional. Indicates which fields in the provided budget to update. Read-only
|
|
|
|
# fields (such as `name`) cannot be changed. If this is not provided, then only
|
|
|
|
# fields with non-default values from the request are updated. See https://
|
|
|
|
# developers.google.com/protocol-buffers/docs/proto3#default for more details
|
|
|
|
# about default values.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `updateMask`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :update_mask
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@budget = args[:budget] if args.key?(:budget)
|
|
|
|
@update_mask = args[:update_mask] if args.key?(:update_mask)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# A generic empty message that you can re-use to avoid defining duplicated empty
|
|
|
|
# messages in your APIs. A typical example is to use it as the request or the
|
|
|
|
# response type of an API method. For instance: service Foo ` rpc Bar(google.
|
|
|
|
# protobuf.Empty) returns (google.protobuf.Empty); ` The JSON representation for
|
|
|
|
# `Empty` is empty JSON object ````.
|
2019-11-22 00:37:17 +00:00
|
|
|
class GoogleProtobufEmpty
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Represents an amount of money with its currency type.
|
|
|
|
class GoogleTypeMoney
|
|
|
|
include Google::Apis::Core::Hashable
|
|
|
|
|
2020-10-15 00:39:14 +00:00
|
|
|
# The three-letter currency code defined in ISO 4217.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `currencyCode`
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :currency_code
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# Number of nano (10^-9) units of the amount. The value must be between -999,999,
|
|
|
|
# 999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be
|
|
|
|
# positive or zero. If `units` is zero, `nanos` can be positive, zero, or
|
|
|
|
# negative. If `units` is negative, `nanos` must be negative or zero. For
|
|
|
|
# example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `nanos`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :nanos
|
|
|
|
|
2020-08-04 00:38:33 +00:00
|
|
|
# The whole units of the amount. For example if `currencyCode` is `"USD"`, then
|
|
|
|
# 1 unit is one US dollar.
|
2019-11-22 00:37:17 +00:00
|
|
|
# Corresponds to the JSON property `units`
|
|
|
|
# @return [Fixnum]
|
|
|
|
attr_accessor :units
|
|
|
|
|
|
|
|
def initialize(**args)
|
|
|
|
update!(**args)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Update properties of this object
|
|
|
|
def update!(**args)
|
|
|
|
@currency_code = args[:currency_code] if args.key?(:currency_code)
|
|
|
|
@nanos = args[:nanos] if args.key?(:nanos)
|
|
|
|
@units = args[:units] if args.key?(:units)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|