/resource_management/azure_mgmt_authorization/lib/azure_mgmt_authorization/permissions.rb
Ruby | 277 lines | 177 code | 28 blank | 72 comment | 32 complexity | a6f44b01c20d15ce930576fcf2f536e7 MD5 | raw file
- # encoding: utf-8
- # Code generated by Microsoft (R) AutoRest Code Generator 0.16.0.0
- # Changes may cause incorrect behavior and will be lost if the code is
- # regenerated.
- module Azure::ARM::Authorization
- #
- # Permissions
- #
- class Permissions
- include Azure::ARM::Authorization::Models
- include MsRestAzure
- #
- # Creates and initializes a new instance of the Permissions class.
- # @param client service class for accessing basic functionality.
- #
- def initialize(client)
- @client = client
- end
- # @return reference to the AuthorizationManagementClient
- attr_reader :client
- #
- # Gets a resource group permissions.
- #
- # @param resource_group_name [String] Name of the resource group to get the
- # permissions for.The name is case insensitive.
- # @param [Hash{String => String}] The hash of custom headers need to be
- # applied to HTTP request.
- #
- # @return [Concurrent::Promise] Promise object which allows to get HTTP
- # response.
- #
- def list_for_resource_group(resource_group_name, custom_headers = nil)
- fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil?
- fail ArgumentError, '@client.api_version is nil' if @client.api_version.nil?
- fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil?
- request_headers = {}
- # 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 = '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/Microsoft.Authorization/permissions'
- options = {
- middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]],
- path_params: {'resourceGroupName' => resource_group_name,'subscriptionId' => @client.subscription_id},
- query_params: {'api-version' => @client.api_version},
- headers: request_headers.merge(custom_headers || {})
- }
- request = MsRest::HttpOperationRequest.new(@base_url || @client.base_url, path_template, :get, options)
- promise = request.run_promise do |req|
- @client.credentials.sign_request(req) unless @client.credentials.nil?
- end
- promise = promise.then do |http_response|
- status_code = http_response.status
- response_content = http_response.body
- unless status_code == 200
- error_model = JSON.load(response_content)
- fail MsRestAzure::AzureOperationError.new(request, http_response, error_model)
- end
- # Create Result
- result = MsRestAzure::AzureOperationResponse.new(request, http_response)
- result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil?
- # Deserialize Response
- if status_code == 200
- begin
- parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content)
- unless parsed_response.nil?
- parsed_response = PermissionGetResult.deserialize_object(parsed_response)
- end
- result.body = parsed_response
- rescue Exception => e
- fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result)
- end
- end
- result
- end
- promise.execute
- end
- #
- # Gets a resource permissions.
- #
- # @param resource_group_name [String] The name of the resource group. The name
- # is case insensitive.
- # @param resource_provider_namespace [String] Resource
- # @param parent_resource_path [String] Resource
- # @param resource_type [String] Resource
- # @param resource_name [String] Resource
- # @param [Hash{String => String}] The hash of custom headers need to be
- # applied to HTTP request.
- #
- # @return [Concurrent::Promise] Promise object which allows to get HTTP
- # response.
- #
- def list_for_resource(resource_group_name, resource_provider_namespace, parent_resource_path, resource_type, resource_name, custom_headers = nil)
- fail ArgumentError, 'resource_group_name is nil' if resource_group_name.nil?
- fail ArgumentError, 'resource_provider_namespace is nil' if resource_provider_namespace.nil?
- fail ArgumentError, 'parent_resource_path is nil' if parent_resource_path.nil?
- fail ArgumentError, 'resource_type is nil' if resource_type.nil?
- fail ArgumentError, 'resource_name is nil' if resource_name.nil?
- fail ArgumentError, '@client.api_version is nil' if @client.api_version.nil?
- fail ArgumentError, '@client.subscription_id is nil' if @client.subscription_id.nil?
- request_headers = {}
- # 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 = '/subscriptions/{subscriptionId}/resourcegroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{parentResourcePath}/{resourceType}/{resourceName}/providers/Microsoft.Authorization/permissions'
- options = {
- middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]],
- path_params: {'resourceGroupName' => resource_group_name,'resourceProviderNamespace' => resource_provider_namespace,'resourceName' => resource_name,'subscriptionId' => @client.subscription_id},
- skip_encoding_path_params: {'parentResourcePath' => parent_resource_path,'resourceType' => resource_type},
- query_params: {'api-version' => @client.api_version},
- headers: request_headers.merge(custom_headers || {})
- }
- request = MsRest::HttpOperationRequest.new(@base_url || @client.base_url, path_template, :get, options)
- promise = request.run_promise do |req|
- @client.credentials.sign_request(req) unless @client.credentials.nil?
- end
- promise = promise.then do |http_response|
- status_code = http_response.status
- response_content = http_response.body
- unless status_code == 200
- error_model = JSON.load(response_content)
- fail MsRestAzure::AzureOperationError.new(request, http_response, error_model)
- end
- # Create Result
- result = MsRestAzure::AzureOperationResponse.new(request, http_response)
- result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil?
- # Deserialize Response
- if status_code == 200
- begin
- parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content)
- unless parsed_response.nil?
- parsed_response = PermissionGetResult.deserialize_object(parsed_response)
- end
- result.body = parsed_response
- rescue Exception => e
- fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result)
- end
- end
- result
- end
- promise.execute
- end
- #
- # Gets a resource group permissions.
- #
- # @param next_page_link [String] The NextLink from the previous successful
- # call to List operation.
- # @param [Hash{String => String}] The hash of custom headers need to be
- # applied to HTTP request.
- #
- # @return [Concurrent::Promise] Promise object which allows to get HTTP
- # response.
- #
- def list_for_resource_group_next(next_page_link, custom_headers = nil)
- fail ArgumentError, 'next_page_link is nil' if next_page_link.nil?
- request_headers = {}
- # 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 = '{nextLink}'
- options = {
- middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]],
- skip_encoding_path_params: {'nextLink' => next_page_link},
- headers: request_headers.merge(custom_headers || {})
- }
- request = MsRest::HttpOperationRequest.new(@base_url || @client.base_url, path_template, :get, options)
- promise = request.run_promise do |req|
- @client.credentials.sign_request(req) unless @client.credentials.nil?
- end
- promise = promise.then do |http_response|
- status_code = http_response.status
- response_content = http_response.body
- unless status_code == 200
- error_model = JSON.load(response_content)
- fail MsRestAzure::AzureOperationError.new(request, http_response, error_model)
- end
- # Create Result
- result = MsRestAzure::AzureOperationResponse.new(request, http_response)
- result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil?
- # Deserialize Response
- if status_code == 200
- begin
- parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content)
- unless parsed_response.nil?
- parsed_response = PermissionGetResult.deserialize_object(parsed_response)
- end
- result.body = parsed_response
- rescue Exception => e
- fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result)
- end
- end
- result
- end
- promise.execute
- end
- #
- # Gets a resource permissions.
- #
- # @param next_page_link [String] The NextLink from the previous successful
- # call to List operation.
- # @param [Hash{String => String}] The hash of custom headers need to be
- # applied to HTTP request.
- #
- # @return [Concurrent::Promise] Promise object which allows to get HTTP
- # response.
- #
- def list_for_resource_next(next_page_link, custom_headers = nil)
- fail ArgumentError, 'next_page_link is nil' if next_page_link.nil?
- request_headers = {}
- # 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 = '{nextLink}'
- options = {
- middlewares: [[MsRest::RetryPolicyMiddleware, times: 3, retry: 0.02], [:cookie_jar]],
- skip_encoding_path_params: {'nextLink' => next_page_link},
- headers: request_headers.merge(custom_headers || {})
- }
- request = MsRest::HttpOperationRequest.new(@base_url || @client.base_url, path_template, :get, options)
- promise = request.run_promise do |req|
- @client.credentials.sign_request(req) unless @client.credentials.nil?
- end
- promise = promise.then do |http_response|
- status_code = http_response.status
- response_content = http_response.body
- unless status_code == 200
- error_model = JSON.load(response_content)
- fail MsRestAzure::AzureOperationError.new(request, http_response, error_model)
- end
- # Create Result
- result = MsRestAzure::AzureOperationResponse.new(request, http_response)
- result.request_id = http_response['x-ms-request-id'] unless http_response['x-ms-request-id'].nil?
- # Deserialize Response
- if status_code == 200
- begin
- parsed_response = response_content.to_s.empty? ? nil : JSON.load(response_content)
- unless parsed_response.nil?
- parsed_response = PermissionGetResult.deserialize_object(parsed_response)
- end
- result.body = parsed_response
- rescue Exception => e
- fail MsRest::DeserializationError.new('Error occurred in deserializing the response', e.message, e.backtrace, result)
- end
- end
- result
- end
- promise.execute
- end
- end
- end