Class: Morpheus::PackagesInterface
- Defined in:
- lib/morpheus/api/packages_interface.rb
Constant Summary
Constants inherited from APIClient
Instance Method Summary collapse
- #destroy(id) ⇒ Object
- #export(params, outfile) ⇒ Object
- #info(params = {}) ⇒ Object
- #install(params = {}, payload = {}) ⇒ Object
-
#install_file(local_file, params = {}) ⇒ Object
def install_file(package_file, params={}) url = “#@base_url/api/packages/install-file” headers = { :params => params, :authorization => “Bearer #@access_token”, ‘Content-Type’ => ‘application/octet-stream’} payload = package_file execute(method: :post, url: url, headers: headers, payload: payload, timeout: 36000) end.
-
#list(params = {}) ⇒ Object
def get(id) raise “#selfself.class.get() passed a blank id!” if id.to_s == ” url = “#@base_url/api/packages/#id” headers = { params: {}, authorization: “Bearer #@access_token” } opts = :get, url: url, headers: headers execute(opts) end.
- #search(params = {}) ⇒ Object
- #update(id, payload) ⇒ Object
Methods inherited from APIClient
#account_groups, #account_users, #accounts, #activity, #appliance_settings, #approvals, #apps, #archive_buckets, #archive_files, #audit, #auth, #authorization_required?, #backup_jobs, #backup_restores, #backup_results, #backup_service_types, #backup_services, #backup_settings, #backup_types, #backups, #billing, #blueprints, #budgets, #catalog, #catalog_item_types, #certificate_types, #certificates, #client_id, #client_id=, #clients, #cloud_datastores, #cloud_folders, #cloud_policies, #cloud_resource_pools, #clouds, #clusters, #common_interface_options, #containers, #credential_types, #credentials, #cypher, #dashboard, #datastores, #default_content_type, #default_timeout, #deploy, #deployments, #dry, #dry_run, #email_templates, #environments, #execute, #execute_schedules, #execution_request, #file_copy_request, #forgot, #group_policies, #groups, #guidance, #guidance_settings, #health, #hub, #image_builder, #initialize, #inspect, #instance_types, #instances, #integration_types, #integrations, #interface, #invoice_line_items, #invoices, #jobs, #key_pairs, #library_cluster_layouts, #library_cluster_packages, #library_container_scripts, #library_container_templates, #library_container_types, #library_container_upgrades, #library_instance_types, #library_layouts, #library_operating_systems, #library_spec_template_types, #library_spec_templates, #license, #load_balancer_monitors, #load_balancer_pool_nodes, #load_balancer_pools, #load_balancer_pools_secondary, #load_balancer_profiles, #load_balancer_types, #load_balancer_virtual_servers, #load_balancers, #log_settings, #logged_in?, #login, #logout, #logs, #monitoring, #monitoring_settings, #network_dhcp_relays, #network_dhcp_servers, #network_domain_records, #network_domains, #network_edge_clusters, #network_floating_ips, #network_groups, #network_pool_ips, #network_pool_server_types, #network_pool_servers, #network_pools, #network_proxies, #network_resource_types, #network_routers, #network_security_server_types, #network_security_servers, #network_server_groups, #network_server_services, #network_server_types, #network_servers, #network_services, #network_static_routes, #network_types, #networks, #old_cypher, #option_type_forms, #option_type_lists, #option_types, #options, #packages, #ping, #plugins, #policies, #power_schedules, #price_sets, #prices, #processes, #projects, #provision_types, #provisioning_license_types, #provisioning_licenses, #provisioning_settings, #reports, #resource_pool_groups, #rest, #roles, #scale_thresholds, #security_group_rules, #security_groups, #security_package_types, #security_packages, #security_scans, #server_types, #servers, #service_plans, #set_ssl_verification_enabled, #setopts, #setup, #snapshots, #ssl_verification_enabled?, #storage_providers, #storage_server_types, #storage_servers, #storage_volume_types, #storage_volumes, #subnet_types, #subnets, #task_sets, #tasks, #to_s, #url, #usage, #use_refresh_token, #user_groups, #user_settings, #user_sources, #users, #vdi, #vdi_allocations, #vdi_apps, #vdi_gateways, #vdi_pools, #virtual_images, #whitelabel_settings, #whoami, #wiki, #withopts
Constructor Details
This class inherits a constructor from Morpheus::APIClient
Instance Method Details
#destroy(id) ⇒ Object
70 71 72 73 74 75 |
# File 'lib/morpheus/api/packages_interface.rb', line 70 def destroy(id) url = "#{@base_url}/api/packages/#{id}" headers = { :params => {}, :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' } opts = {method: :delete, url: url, headers: headers} execute(opts) end |
#export(params, outfile) ⇒ Object
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 |
# File 'lib/morpheus/api/packages_interface.rb', line 77 def export(params, outfile) url = "#{@base_url}/api/packages/export" headers = { params: params, authorization: "Bearer #{@access_token}" } opts = {method: :post, url: url, headers: headers} # execute(opts, {parse_json: false}) if Dir.exist?(outfile) raise "outfile is invalid. It is the name of an existing directory: #{outfile}" end # if @verify_ssl == false # opts[:verify_ssl] = OpenSSL::SSL::VERIFY_NONE # end if @dry_run return opts end http_response = nil bad_body = nil File.open(outfile, 'w') {|f| block = proc { |response| if response.code.to_i == 200 response.read_body do |chunk| #puts "writing to #{outfile} ..." f.write chunk end else # puts_error (#{response.inspect}) #{chunk} ..." bad_body = response.body.to_s end } opts[:block_response] = block http_response = Morpheus::RestClient.execute(opts) } return http_response, bad_body end |
#info(params = {}) ⇒ Object
29 30 31 32 33 34 35 |
# File 'lib/morpheus/api/packages_interface.rb', line 29 def info(params={}) url = "#{@base_url}/api/packages/info" headers = { params: {}, authorization: "Bearer #{@access_token}" } headers[:params].merge!(params) opts = {method: :get, url: url, headers: headers} execute(opts) end |
#install(params = {}, payload = {}) ⇒ Object
37 38 39 40 41 42 |
# File 'lib/morpheus/api/packages_interface.rb', line 37 def install(params={}, payload={}) url = "#{@base_url}/api/packages/install" headers = { :params => params, :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' } opts = {method: :post, url: url, headers: headers, payload: payload.to_json} execute(opts) end |
#install_file(local_file, params = {}) ⇒ Object
def install_file(package_file, params={})
url = "#{@base_url}/api/packages/install-file"
headers = { :params => params, :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/octet-stream'}
payload = package_file
execute(method: :post, url: url, headers: headers, payload: payload, timeout: 36000)
end
51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/morpheus/api/packages_interface.rb', line 51 def install_file(local_file, params={}) url = "#{@base_url}/api/packages/install-file" headers = { :params => params, :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/octet-stream'} if !local_file.kind_of?(File) local_file = File.new(local_file, 'rb') end payload = local_file headers['Content-Length'] = local_file.size # File.size(local_file) opts = {method: :post, url: url, headers: headers, payload: payload} execute(opts) end |
#list(params = {}) ⇒ Object
def get(id)
raise "#{self.class}.get() passed a blank id!" if id.to_s == ''
url = "#{@base_url}/api/packages/#{id}"
headers = { params: {}, authorization: "Bearer #{@access_token}" }
opts = {method: :get, url: url, headers: headers}
execute(opts)
end
13 14 15 16 17 18 19 |
# File 'lib/morpheus/api/packages_interface.rb', line 13 def list(params={}) url = "#{@base_url}/api/packages" headers = { params: {}, authorization: "Bearer #{@access_token}" } headers[:params].merge!(params) opts = {method: :get, url: url, headers: headers} execute(opts) end |
#search(params = {}) ⇒ Object
21 22 23 24 25 26 27 |
# File 'lib/morpheus/api/packages_interface.rb', line 21 def search(params={}) url = "#{@base_url}/api/packages/search" headers = { params: {}, authorization: "Bearer #{@access_token}" } headers[:params].merge!(params) opts = {method: :get, url: url, headers: headers} execute(opts) end |
#update(id, payload) ⇒ Object
63 64 65 66 67 68 |
# File 'lib/morpheus/api/packages_interface.rb', line 63 def update(id, payload) url = "#{@base_url}/api/packages/update/#{id}" headers = { :params => {}, :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' } opts = {method: :put, url: url, headers: headers, payload: payload.to_json} execute(opts) end |