1 | <?php
|
---|
2 | /*
|
---|
3 | * Copyright 2014 Google Inc.
|
---|
4 | *
|
---|
5 | * Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
---|
6 | * use this file except in compliance with the License. You may obtain a copy of
|
---|
7 | * the License at
|
---|
8 | *
|
---|
9 | * http://www.apache.org/licenses/LICENSE-2.0
|
---|
10 | *
|
---|
11 | * Unless required by applicable law or agreed to in writing, software
|
---|
12 | * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
---|
13 | * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
---|
14 | * License for the specific language governing permissions and limitations under
|
---|
15 | * the License.
|
---|
16 | */
|
---|
17 |
|
---|
18 | namespace Google\Service\CloudBillingBudget\Resource;
|
---|
19 |
|
---|
20 | use Google\Service\CloudBillingBudget\GoogleCloudBillingBudgetsV1Budget;
|
---|
21 | use Google\Service\CloudBillingBudget\GoogleCloudBillingBudgetsV1ListBudgetsResponse;
|
---|
22 | use Google\Service\CloudBillingBudget\GoogleProtobufEmpty;
|
---|
23 |
|
---|
24 | /**
|
---|
25 | * The "budgets" collection of methods.
|
---|
26 | * Typical usage is:
|
---|
27 | * <code>
|
---|
28 | * $billingbudgetsService = new Google\Service\CloudBillingBudget(...);
|
---|
29 | * $budgets = $billingbudgetsService->billingAccounts_budgets;
|
---|
30 | * </code>
|
---|
31 | */
|
---|
32 | class BillingAccountsBudgets extends \Google\Service\Resource
|
---|
33 | {
|
---|
34 | /**
|
---|
35 | * Creates a new budget. See [Quotas and
|
---|
36 | * limits](https://cloud.google.com/billing/quotas) for more information on the
|
---|
37 | * limits of the number of budgets you can create. (budgets.create)
|
---|
38 | *
|
---|
39 | * @param string $parent Required. The name of the billing account to create the
|
---|
40 | * budget in. Values are of the form `billingAccounts/{billingAccountId}`.
|
---|
41 | * @param GoogleCloudBillingBudgetsV1Budget $postBody
|
---|
42 | * @param array $optParams Optional parameters.
|
---|
43 | * @return GoogleCloudBillingBudgetsV1Budget
|
---|
44 | * @throws \Google\Service\Exception
|
---|
45 | */
|
---|
46 | public function create($parent, GoogleCloudBillingBudgetsV1Budget $postBody, $optParams = [])
|
---|
47 | {
|
---|
48 | $params = ['parent' => $parent, 'postBody' => $postBody];
|
---|
49 | $params = array_merge($params, $optParams);
|
---|
50 | return $this->call('create', [$params], GoogleCloudBillingBudgetsV1Budget::class);
|
---|
51 | }
|
---|
52 | /**
|
---|
53 | * Deletes a budget. Returns successfully if already deleted. (budgets.delete)
|
---|
54 | *
|
---|
55 | * @param string $name Required. Name of the budget to delete. Values are of the
|
---|
56 | * form `billingAccounts/{billingAccountId}/budgets/{budgetId}`.
|
---|
57 | * @param array $optParams Optional parameters.
|
---|
58 | * @return GoogleProtobufEmpty
|
---|
59 | * @throws \Google\Service\Exception
|
---|
60 | */
|
---|
61 | public function delete($name, $optParams = [])
|
---|
62 | {
|
---|
63 | $params = ['name' => $name];
|
---|
64 | $params = array_merge($params, $optParams);
|
---|
65 | return $this->call('delete', [$params], GoogleProtobufEmpty::class);
|
---|
66 | }
|
---|
67 | /**
|
---|
68 | * Returns a budget. WARNING: There are some fields exposed on the Google Cloud
|
---|
69 | * Console that aren't available on this API. When reading from the API, you
|
---|
70 | * will not see these fields in the return value, though they may have been set
|
---|
71 | * in the Cloud Console. (budgets.get)
|
---|
72 | *
|
---|
73 | * @param string $name Required. Name of budget to get. Values are of the form
|
---|
74 | * `billingAccounts/{billingAccountId}/budgets/{budgetId}`.
|
---|
75 | * @param array $optParams Optional parameters.
|
---|
76 | * @return GoogleCloudBillingBudgetsV1Budget
|
---|
77 | * @throws \Google\Service\Exception
|
---|
78 | */
|
---|
79 | public function get($name, $optParams = [])
|
---|
80 | {
|
---|
81 | $params = ['name' => $name];
|
---|
82 | $params = array_merge($params, $optParams);
|
---|
83 | return $this->call('get', [$params], GoogleCloudBillingBudgetsV1Budget::class);
|
---|
84 | }
|
---|
85 | /**
|
---|
86 | * Returns a list of budgets for a billing account. WARNING: There are some
|
---|
87 | * fields exposed on the Google Cloud Console that aren't available on this API.
|
---|
88 | * When reading from the API, you will not see these fields in the return value,
|
---|
89 | * though they may have been set in the Cloud Console.
|
---|
90 | * (budgets.listBillingAccountsBudgets)
|
---|
91 | *
|
---|
92 | * @param string $parent Required. Name of billing account to list budgets
|
---|
93 | * under. Values are of the form `billingAccounts/{billingAccountId}`.
|
---|
94 | * @param array $optParams Optional parameters.
|
---|
95 | *
|
---|
96 | * @opt_param int pageSize Optional. The maximum number of budgets to return per
|
---|
97 | * page. The default and maximum value are 100.
|
---|
98 | * @opt_param string pageToken Optional. The value returned by the last
|
---|
99 | * `ListBudgetsResponse` which indicates that this is a continuation of a prior
|
---|
100 | * `ListBudgets` call, and that the system should return the next page of data.
|
---|
101 | * @opt_param string scope Optional. Set the scope of the budgets to be
|
---|
102 | * returned, in the format of the resource name. The scope of a budget is the
|
---|
103 | * cost that it tracks, such as costs for a single project, or the costs for all
|
---|
104 | * projects in a folder. Only project scope (in the format of "projects/project-
|
---|
105 | * id" or "projects/123") is supported in this field. When this field is set to
|
---|
106 | * a project's resource name, the budgets returned are tracking the costs for
|
---|
107 | * that project.
|
---|
108 | * @return GoogleCloudBillingBudgetsV1ListBudgetsResponse
|
---|
109 | * @throws \Google\Service\Exception
|
---|
110 | */
|
---|
111 | public function listBillingAccountsBudgets($parent, $optParams = [])
|
---|
112 | {
|
---|
113 | $params = ['parent' => $parent];
|
---|
114 | $params = array_merge($params, $optParams);
|
---|
115 | return $this->call('list', [$params], GoogleCloudBillingBudgetsV1ListBudgetsResponse::class);
|
---|
116 | }
|
---|
117 | /**
|
---|
118 | * Updates a budget and returns the updated budget. WARNING: There are some
|
---|
119 | * fields exposed on the Google Cloud Console that aren't available on this API.
|
---|
120 | * Budget fields that are not exposed in this API will not be changed by this
|
---|
121 | * method. (budgets.patch)
|
---|
122 | *
|
---|
123 | * @param string $name Output only. Resource name of the budget. The resource
|
---|
124 | * name implies the scope of a budget. Values are of the form
|
---|
125 | * `billingAccounts/{billingAccountId}/budgets/{budgetId}`.
|
---|
126 | * @param GoogleCloudBillingBudgetsV1Budget $postBody
|
---|
127 | * @param array $optParams Optional parameters.
|
---|
128 | *
|
---|
129 | * @opt_param string updateMask Optional. Indicates which fields in the provided
|
---|
130 | * budget to update. Read-only fields (such as `name`) cannot be changed. If
|
---|
131 | * this is not provided, then only fields with non-default values from the
|
---|
132 | * request are updated. See https://developers.google.com/protocol-
|
---|
133 | * buffers/docs/proto3#default for more details about default values.
|
---|
134 | * @return GoogleCloudBillingBudgetsV1Budget
|
---|
135 | * @throws \Google\Service\Exception
|
---|
136 | */
|
---|
137 | public function patch($name, GoogleCloudBillingBudgetsV1Budget $postBody, $optParams = [])
|
---|
138 | {
|
---|
139 | $params = ['name' => $name, 'postBody' => $postBody];
|
---|
140 | $params = array_merge($params, $optParams);
|
---|
141 | return $this->call('patch', [$params], GoogleCloudBillingBudgetsV1Budget::class);
|
---|
142 | }
|
---|
143 | }
|
---|
144 |
|
---|
145 | // Adding a class alias for backwards compatibility with the previous class name.
|
---|
146 | class_alias(BillingAccountsBudgets::class, 'Google_Service_CloudBillingBudget_Resource_BillingAccountsBudgets');
|
---|