Class: Azure::Consumption::Mgmt::V2018_03_31::GetBalancesByBillingAccount
- Inherits:
-
Object
- Object
- Azure::Consumption::Mgmt::V2018_03_31::GetBalancesByBillingAccount
- Includes:
- MsRestAzure
- Defined in:
- lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb
Overview
Consumption management client provides access to consumption resources for Azure Enterprise Subscriptions.
Instance Attribute Summary collapse
-
#client ⇒ ConsumptionManagementClient
readonly
Reference to the ConsumptionManagementClient.
Instance Method Summary collapse
-
#by_billing_period(billing_account_id, billing_period_name, custom_headers: nil) ⇒ Balance
Gets the balances for a scope by billing period and billingAccountId.
-
#by_billing_period_async(billing_account_id, billing_period_name, custom_headers: nil) ⇒ Concurrent::Promise
Gets the balances for a scope by billing period and billingAccountId.
-
#by_billing_period_with_http_info(billing_account_id, billing_period_name, custom_headers: nil) ⇒ MsRestAzure::AzureOperationResponse
Gets the balances for a scope by billing period and billingAccountId.
-
#initialize(client) ⇒ GetBalancesByBillingAccount
constructor
Creates and initializes a new instance of the GetBalancesByBillingAccount class.
Constructor Details
#initialize(client) ⇒ GetBalancesByBillingAccount
Creates and initializes a new instance of the GetBalancesByBillingAccount class.
18 19 20 |
# File 'lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb', line 18 def initialize(client) @client = client end |
Instance Attribute Details
#client ⇒ ConsumptionManagementClient (readonly)
Returns reference to the ConsumptionManagementClient.
23 24 25 |
# File 'lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb', line 23 def client @client end |
Instance Method Details
#by_billing_period(billing_account_id, billing_period_name, custom_headers: nil) ⇒ Balance
Gets the balances for a scope by billing period and billingAccountId. Balances are available via this API only for May 1, 2014 or later.
will be added to the HTTP request.
36 37 38 39 |
# File 'lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb', line 36 def by_billing_period(billing_account_id, billing_period_name, custom_headers:nil) response = by_billing_period_async(billing_account_id, billing_period_name, custom_headers:custom_headers).value! response.body unless response.nil? end |
#by_billing_period_async(billing_account_id, billing_period_name, custom_headers: nil) ⇒ Concurrent::Promise
Gets the balances for a scope by billing period and billingAccountId. Balances are available via this API only for May 1, 2014 or later.
to the HTTP request.
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 |
# File 'lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb', line 67 def by_billing_period_async(billing_account_id, billing_period_name, custom_headers:nil) fail ArgumentError, '@client.api_version is nil' if @client.api_version.nil? fail ArgumentError, 'billing_account_id is nil' if billing_account_id.nil? fail ArgumentError, 'billing_period_name is nil' if billing_period_name.nil? request_headers = {} request_headers['Content-Type'] = 'application/json; charset=utf-8' # Set Headers request_headers['x-ms-client-request-id'] = SecureRandom.uuid request_headers['accept-language'] = @client.accept_language unless @client.accept_language.nil? path_template = 'providers/Microsoft.Billing/billingAccounts/{billingAccountId}/providers/Microsoft.Billing/billingPeriods/{billingPeriodName}/providers/Microsoft.Consumption/balances' request_url = @base_url || @client.base_url = { middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]], path_params: {'billingAccountId' => billing_account_id,'billingPeriodName' => billing_period_name}, query_params: {'api-version' => @client.api_version}, headers: request_headers.merge(custom_headers || {}), base_url: request_url } promise = @client.make_request_async(:get, path_template, ) promise = promise.then do |result| http_response = result.response status_code = http_response.status response_content = http_response.body unless status_code == 200 error_model = JSON.load(response_content) fail MsRest::HttpOperationError.new(result.request, http_response, error_model) end result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil? result.correlation_request_id = http_response['x-ms-correlation-request-id'] unless http_response['x-ms-correlation-request-id'].nil? result.client_request_id = http_response['x-ms-client-request-id'] unless http_response['x-ms-client-request-id'].nil? # Deserialize Response if status_code == 200 begin parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content) result_mapper = Azure::Consumption::Mgmt::V2018_03_31::Models::Balance.mapper() result.body = @client.deserialize(result_mapper, parsed_response) rescue Exception => e fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e., e.backtrace, result) end end result end promise.execute end |
#by_billing_period_with_http_info(billing_account_id, billing_period_name, custom_headers: nil) ⇒ MsRestAzure::AzureOperationResponse
Gets the balances for a scope by billing period and billingAccountId. Balances are available via this API only for May 1, 2014 or later.
will be added to the HTTP request.
52 53 54 |
# File 'lib/2018-03-31/generated/azure_mgmt_consumption/get_balances_by_billing_account.rb', line 52 def by_billing_period_with_http_info(billing_account_id, billing_period_name, custom_headers:nil) by_billing_period_async(billing_account_id, billing_period_name, custom_headers:custom_headers).value! end |