class OneAndOne::PrivateNetwork
Attributes
id[RW]
specs[RW]
Public Class Methods
new(test: false)
click to toggle source
# File lib/1and1/private_network.rb, line 11 def initialize(test: false) @id = nil @specs = nil # Check if hitting mock api or live api if test @connection = Excon.new($base_url, :mock => true) else @connection = Excon.new($base_url) end end
Public Instance Methods
add_servers(private_network_id: @id, servers: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 254 def add_servers(private_network_id: @id, servers: nil) # If user passed in private network ID, reassign @id = private_network_id # Build POST body new_servers = { 'servers' => servers } # Clean out null keys in POST body body = OneAndOne.clean_hash(new_servers) # Stringify the PUT body string_body = body.to_json # Build URL path = OneAndOne.build_url("/private_networks/#{@id}/servers") # Perform request response = @connection.request(:method => :post, :path => path, :headers => $header, :body => string_body) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
create(name: nil, description: nil, network_address: nil, subnet_mask: nil, datacenter_id: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 57 def create(name: nil, description: nil, network_address: nil, subnet_mask: nil, datacenter_id: nil) # Build POST body new_private_network = { 'name' => name, 'description' => description, 'network_address' => network_address, 'subnet_mask' => subnet_mask, 'datacenter_id' => datacenter_id } # Clean out null keys in POST body body = OneAndOne.clean_hash(new_private_network) # Stringify the POST body string_body = body.to_json # Build URL path = OneAndOne.build_url('/private_networks') # Perform request response = @connection.request(:method => :post, :path => path, :headers => $header, :body => string_body) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string json = JSON.parse(response.body) # Save new private network ID to PrivateNetwork instance @id = json['id'] @specs = json # If all good, return JSON json end
delete(private_network_id: @id)
click to toggle source
# File lib/1and1/private_network.rb, line 166 def delete(private_network_id: @id) # If user passed in private network ID, reassign @id = private_network_id # Build URL path = OneAndOne.build_url("/private_networks/#{@id}") # Perform request response = @connection.request(:method => :delete, :path => path, :headers => $header) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
get(private_network_id: @id)
click to toggle source
# File lib/1and1/private_network.rb, line 100 def get(private_network_id: @id) # If user passed in private network ID, reassign @id = private_network_id # Build URL path = OneAndOne.build_url("/private_networks/#{@id}") # Perform request response = @connection.request(:method => :get, :path => path, :headers => $header) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string json = JSON.parse(response.body) # Reload specs attribute @specs = json # If all good, return JSON json end
list(page: nil, per_page: nil, sort: nil, q: nil, fields: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 25 def list(page: nil, per_page: nil, sort: nil, q: nil, fields: nil) # Build hash for query parameters keyword_args = { :page => page, :per_page => per_page, :sort => sort, :q => q, :fields => fields } # Clean out null query parameters params = OneAndOne.clean_hash(keyword_args) # Build URL path = OneAndOne.build_url('/private_networks') # Perform request response = @connection.request(:method => :get, :path => path, :headers => $header, :query => params) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
modify(private_network_id: @id, name: nil, description: nil, network_address: nil, subnet_mask: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 128 def modify(private_network_id: @id, name: nil, description: nil, network_address: nil, subnet_mask: nil) # If user passed in private network ID, reassign @id = private_network_id # Build PUT body new_private_network = { 'name' => name, 'description' => description, 'network_address' => network_address, 'subnet_mask' => subnet_mask } # Clean out null keys in PUT body body = OneAndOne.clean_hash(new_private_network) # Stringify the PUT body string_body = body.to_json # Build URL path = OneAndOne.build_url("/private_networks/#{@id}") # Perform request response = @connection.request(:method => :put, :path => path, :headers => $header, :body => string_body) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
reload()
click to toggle source
# File lib/1and1/private_network.rb, line 288 def reload # This reload fx is just a wrapper for the get fx get end
remove_server(private_network_id: @id, server_id: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 232 def remove_server(private_network_id: @id, server_id: nil) # If user passed in private network ID, reassign @id = private_network_id # Build URL path = OneAndOne.build_url("/private_networks/#{@id}/servers/#{server_id}") # Perform request response = @connection.request(:method => :delete, :path => path, :headers => $header) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
server(private_network_id: @id, server_id: nil)
click to toggle source
# File lib/1and1/private_network.rb, line 210 def server(private_network_id: @id, server_id: nil) # If user passed in private network ID, reassign @id = private_network_id # Build URL path = OneAndOne.build_url("/private_networks/#{@id}/servers/#{server_id}") # Perform request response = @connection.request(:method => :get, :path => path, :headers => $header) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
servers(private_network_id: @id)
click to toggle source
# File lib/1and1/private_network.rb, line 188 def servers(private_network_id: @id) # If user passed in private network ID, reassign @id = private_network_id # Build URL path = OneAndOne.build_url("/private_networks/#{@id}/servers") # Perform request response = @connection.request(:method => :get, :path => path, :headers => $header) # Check response status OneAndOne.check_response(response.body, response.status) #JSON-ify the response string JSON.parse(response.body) end
wait_for(timeout: 25, interval: 5)
click to toggle source
# File lib/1and1/private_network.rb, line 296 def wait_for(timeout: 25, interval: 5) # Capture start time start = Time.now # Poll private network and check initial state initial_response = get private_network_state = initial_response['state'] # Keep polling the private network's state until good until $good_states.include? private_network_state # Wait 5 seconds before polling again sleep interval # Check private network state again current_response = get private_network_state = current_response['state'] # Calculate current duration and check for timeout duration = (Time.now - start) / 60 if duration > timeout puts "The operation timed out after #{timeout} minutes.\n" return end end # Return Duration {:duration => duration} end