Class: Morpheus::RolesInterface

Inherits:
APIClient show all
Defined in:
lib/morpheus/api/roles_interface.rb

Instance Method Summary collapse

Methods inherited from APIClient

#account_groups, #accounts, #apps, #archive_buckets, #archive_files, #auth, #blueprints, #cloud_datastores, #cloud_folders, #cloud_policies, #cloud_resource_pools, #clouds, #clusters, #containers, #custom_instance_types, #cypher, #dashboard, #default_content_type, #deploy, #deployments, #dry, #dry_run, #environments, #execute, #execute_schedules, #execution_request, #file_copy_request, #group_policies, #groups, #image_builder, #inspect, #instance_types, #instances, #key_pairs, #library_compute_type_layouts, #library_container_scripts, #library_container_templates, #library_container_types, #library_container_upgrades, #library_instance_types, #library_layouts, #license, #load_balancers, #logged_in?, #login, #logout, #logs, #monitoring, #network_domain_records, #network_domains, #network_groups, #network_pool_ips, #network_pool_servers, #network_pools, #network_proxies, #network_services, #network_subnet_types, #network_subnets, #network_types, #networks, #old_cypher, #option_type_lists, #option_types, #options, #packages, #policies, #power_schedules, #processes, #provision_types, #refresh_token, #reports, #roles, #security_group_rules, #security_groups, #server_types, #servers, #service_plans, #set_ssl_verification_enabled, #setopts, #setup, #ssl_verification_enabled?, #storage_providers, #task_sets, #tasks, #to_s, #url, #user_groups, #user_settings, #user_sources, #users, #virtual_images, #whoami, #wiki, #withopts

Constructor Details

#initialize(access_token, refresh_token, expires_at = nil, base_url = nil) ⇒ RolesInterface

Returns a new instance of RolesInterface.



4
5
6
7
8
9
# File 'lib/morpheus/api/roles_interface.rb', line 4

def initialize(access_token, refresh_token, expires_at = nil, base_url=nil) 
  @access_token = access_token
  @refresh_token = refresh_token
  @base_url = base_url
  @expires_at = expires_at
end

Instance Method Details

#create(account_id, options) ⇒ Object



25
26
27
28
29
30
# File 'lib/morpheus/api/roles_interface.rb', line 25

def create(, options)
  url = build_url()
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :post, url: url, headers: headers, payload: payload.to_json)
end

#destroy(account_id, id) ⇒ Object



39
40
41
42
43
# File 'lib/morpheus/api/roles_interface.rb', line 39

def destroy(, id)
  url = build_url(, id)
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  execute(method: :delete, url: url, headers: headers)
end

#get(account_id, id) ⇒ Object



11
12
13
14
15
16
# File 'lib/morpheus/api/roles_interface.rb', line 11

def get(, id)
  raise "#{self.class}.get() passed a blank id!" if id.to_s == ''
  url = build_url(, id)
  headers = { params: {}, authorization: "Bearer #{@access_token}" }
  execute(method: :get, url: url, headers: headers)
end

#list(account_id, options = {}) ⇒ Object



18
19
20
21
22
23
# File 'lib/morpheus/api/roles_interface.rb', line 18

def list(, options={})
  url = build_url()
  headers = { params: {}, authorization: "Bearer #{@access_token}" }
  headers[:params].merge!(options)
  execute(method: :get, url: url, headers: headers)
end

#update(account_id, id, options) ⇒ Object



32
33
34
35
36
37
# File 'lib/morpheus/api/roles_interface.rb', line 32

def update(, id, options)
  url = build_url(, id)
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end

#update_blueprint(account_id, id, options) ⇒ Object



59
60
61
62
63
64
# File 'lib/morpheus/api/roles_interface.rb', line 59

def update_blueprint(, id, options)
  url = build_url(, id) + "/update-blueprint"
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end

#update_cloud(account_id, id, options) ⇒ Object



73
74
75
76
77
78
# File 'lib/morpheus/api/roles_interface.rb', line 73

def update_cloud(, id, options)
  url = build_url(, id) + "/update-cloud"
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end

#update_group(account_id, id, options) ⇒ Object



66
67
68
69
70
71
# File 'lib/morpheus/api/roles_interface.rb', line 66

def update_group(, id, options)
  url = build_url(, id) + "/update-group"
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end

#update_instance_type(account_id, id, options) ⇒ Object



52
53
54
55
56
57
# File 'lib/morpheus/api/roles_interface.rb', line 52

def update_instance_type(, id, options)
  url = build_url(, id) + "/update-instance-type"
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end

#update_permission(account_id, id, options) ⇒ Object



45
46
47
48
49
50
# File 'lib/morpheus/api/roles_interface.rb', line 45

def update_permission(, id, options)
  url = build_url(, id) + "/update-permission"
  headers = { :authorization => "Bearer #{@access_token}", 'Content-Type' => 'application/json' }
  payload = options
  execute(method: :put, url: url, headers: headers, payload: payload.to_json)
end