class Azure::CloudServiceManagement::CloudServiceManagementService
Public Class Methods
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 20 def initialize super() end
Public Instance Methods
Public: Creates a new cloud service in Windows Azure
.
Attributes¶ ↑
-
name
-String
. The name of the cloud service. -
options
- Hash. Optional parameters.
Options¶ ↑
Accepted key/value pairs in options parameter are:
-
:label
-String. The label for this cloud service. -
:description
-String
. A description for the hosted service. (optional) -
:location
-String
. The regional data center location where the
cloud service will be created. Required if affinity group not specified (optional)
-
+:affinity_group_name -
String
. Name of the affinity group with
which to assocate the cloud service. Required if location not specified (optional)
-
:extended_properties
- Hash. Key/Value pairs of extended
properties to add to the cloud service. The key is used as the property name and the value as its value. (optional)
See msdn.microsoft.com/en-us/library/windowsazure/gg441304.aspx
Returns None
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 49 def create_cloud_service(name, options = {}) Loggerx.error_with_exit 'Cloud service name is not valid ' unless name if get_cloud_service(name) Loggerx.warn "Cloud service #{name} already exists. Skipped..." else Loggerx.info "Creating cloud service #{name}." request_path = '/services/hostedservices' body = Serialization.cloud_services_to_xml(name, options) request = ManagementHttpRequest.new(:post, request_path, body) request.call end end
Public: Deletes the specified cloud service of given subscription id from Windows Azure
.
Attributes¶ ↑
-
name
-String
. Cloud service name.
Returns: None
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 107 def delete_cloud_service(cloud_service_name) request_path = "/services/hostedservices/#{cloud_service_name}" request = ManagementHttpRequest.new(:delete, request_path) Loggerx.info "Deleting cloud service #{cloud_service_name}. \n" request.call end
Public: Deletes the specified deployment.
Attributes¶ ↑
-
cloud_service_name
-String
. Cloud service name.
See msdn.microsoft.com/en-us/library/windowsazure/ee460815.aspx
Returns NONE
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 123 def delete_cloud_service_deployment(cloud_service_name) request_path = "/services/hostedservices/#{cloud_service_name}/deploymentslots/production" request = ManagementHttpRequest.new(:delete, request_path) Loggerx.info "Deleting deployment of cloud service \"#{cloud_service_name}\" ..." request.call end
Public: Checks to see if the specified hosted service is available
Attributes¶ ↑
-
name
-String
. Cloud service name.
Returns: A boolean value indicating whether the cloud service exists. If true, the cloud service is available. If false, the cloud service does not exist.
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 81 def get_cloud_service(name) return false if name.nil? flag = false list_cloud_services.each do |cloud_service| if cloud_service.name == name flag = true break end end flag end
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 93 def get_cloud_service_properties(name) request_path = "/services/hostedservices/#{name}?embed-detail=true" request = ManagementHttpRequest.new(:get, request_path) response = request.call Serialization.cloud_services_from_xml(response).first end
Public: Gets a list of hosted services available under the current subscription.
Returns an array of Azure::CloudServiceManagement::CloudService
objects
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 65 def list_cloud_services request_path = '/services/hostedservices' request = ManagementHttpRequest.new(:get, request_path, nil) response = request.call Serialization.cloud_services_from_xml(response) end
# File lib/azure/cloud_service_management/cloud_service_management_service.rb, line 130 def upload_certificate(cloud_service_name, ssh) data = export_der(ssh[:cert], ssh[:key]) request_path = "/services/hostedservices/#{cloud_service_name}/certificates" body = Serialization.add_certificate_to_xml(data) Loggerx.info "Uploading certificate to cloud service #{cloud_service_name}..." request = ManagementHttpRequest.new(:post, request_path, body) request.call end