Class: Morpheus::AuthInterface
- Defined in:
- lib/morpheus/api/auth_interface.rb
Constant Summary
Constants inherited from APIClient
Morpheus::APIClient::CLIENT_ID
Instance Attribute Summary
Attributes inherited from APIClient
Instance Method Summary collapse
-
#login(username, password, use_client_id = nil) ⇒ Object
def initialize(base_url, access_token=nil) @base_url = base_url @access_token = access_token end.
- #logout ⇒ Object
-
#use_refresh_token(refresh_token, use_client_id = nil) ⇒ Object
this regenerates the access_token and refresh_token.
Methods inherited from APIClient
#account_groups, #accounts, #activity, #appliance_settings, #approvals, #apps, #archive_buckets, #archive_files, #auth, #authorization_required?, #backup_settings, #blueprints, #budgets, #cloud_datastores, #cloud_folders, #cloud_policies, #cloud_resource_pools, #clouds, #clusters, #common_interface_options, #containers, #custom_instance_types, #cypher, #dashboard, #datastores, #default_content_type, #default_timeout, #deploy, #deployments, #dry, #dry_run, #environments, #execute, #execute_schedules, #execution_request, #file_copy_request, #group_policies, #groups, #guidance, #health, #image_builder, #initialize, #inspect, #instance_types, #instances, #integrations, #invoice_line_items, #invoices, #jobs, #key_pairs, #library_cluster_layouts, #library_container_scripts, #library_container_templates, #library_container_types, #library_container_upgrades, #library_instance_types, #library_layouts, #library_spec_template_types, #library_spec_templates, #license, #load_balancers, #log_settings, #logged_in?, #logs, #monitoring, #network_domain_records, #network_domains, #network_groups, #network_pool_ips, #network_pool_servers, #network_pools, #network_proxies, #network_routers, #network_security_servers, #network_services, #network_types, #networks, #old_cypher, #option_type_lists, #option_types, #options, #packages, #ping, #policies, #power_schedules, #price_sets, #prices, #processes, #projects, #provision_types, #provisioning_license_types, #provisioning_licenses, #provisioning_settings, #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, #subnet_types, #subnets, #task_sets, #tasks, #to_s, #url, #user_groups, #user_settings, #user_sources, #users, #virtual_images, #whitelabel_settings, #whoami, #wiki, #withopts
Constructor Details
This class inherits a constructor from Morpheus::APIClient
Instance Method Details
#login(username, password, use_client_id = nil) ⇒ Object
def initialize(base_url, access_token=nil)
@base_url = base_url
@access_token = access_token
end
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
# File 'lib/morpheus/api/auth_interface.rb', line 10 def login(username, password, use_client_id=nil) if use_client_id self.client_id = use_client_id end @access_token, @refresh_token, @expires_at = nil, nil, nil url = "#{@base_url}/oauth/token" params = {grant_type: 'password', scope:'write', client_id: self.client_id, username: username} payload = {password: password} opts = {method: :post, url: url, headers:{ params: params}, payload: payload, timeout: 5} response = execute(opts) return response if @dry_run @access_token = response['access_token'] @refresh_token = response['refresh_token'] if response['expires_in'] != nil @expires_at = Time.now + response['expires_in'] end return response end |
#logout ⇒ Object
49 50 51 52 53 54 55 |
# File 'lib/morpheus/api/auth_interface.rb', line 49 def logout() # super.logout() if @access_token # todo: expire the token end raise "#{self}.logout() is not yet implemented" end |
#use_refresh_token(refresh_token, use_client_id = nil) ⇒ Object
this regenerates the access_token and refresh_token
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/morpheus/api/auth_interface.rb', line 30 def use_refresh_token(refresh_token, use_client_id=nil) if use_client_id self.client_id = use_client_id end @access_token = nil url = "#{@base_url}/oauth/token" params = {grant_type: 'refresh_token', scope:'write', client_id: self.client_id} payload = {refresh_token: refresh_token} opts = {method: :post, url: url, headers:{ params: params}, payload: payload} response = execute(opts) return response if @dry_run @access_token = response['access_token'] @refresh_token = response['refresh_token'] if response['expires_in'] != nil @expires_at = Time.now + response['expires_in'] end return response end |