Module: InspecPlugins::Compliance::API::Login::ComplianceServer
- Defined in:
- lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb
Class Method Summary collapse
- .compliance_login_refresh_token(options) ⇒ Object
- .compliance_login_user_pass(options) ⇒ Object
- .compliance_store_access_token(options, token) ⇒ Object
-
.compliance_verify_thor_options(o) ⇒ Object
Compliance login requires ‘–user` or `–refresh_token` If `–user` then either `–password`, `–token`, or `–refresh-token`, is required.
- .login(options) ⇒ Object
Class Method Details
.compliance_login_refresh_token(options) ⇒ Object
145 146 147 148 149 150 151 152 153 154 |
# File 'lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb', line 145 def self.compliance_login_refresh_token() success, msg, token = InspecPlugins::Compliance::API.get_token_via_refresh_token( ['url'], ['refresh_token'], ['insecure'], ) raise msg unless success compliance_store_access_token(, token) end |
.compliance_login_user_pass(options) ⇒ Object
133 134 135 136 137 138 139 140 141 142 143 |
# File 'lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb', line 133 def self.compliance_login_user_pass() success, msg, token = InspecPlugins::Compliance::API.get_token_via_password( ['url'], ['user'], ['password'], ['insecure'], ) raise msg unless success compliance_store_access_token(, token) end |
.compliance_store_access_token(options, token) ⇒ Object
156 157 158 159 160 161 162 163 164 165 166 167 168 169 |
# File 'lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb', line 156 def self.compliance_store_access_token(, token) config = InspecPlugins::Compliance::Configuration.new config.clean config['user'] = ['user'] if ['user'] config['server'] = ['url'] config['insecure'] = ['insecure'] || false config['server_type'] = ['server_type'].to_s config['token'] = token config['version'] = InspecPlugins::Compliance::API.version(config) config.store config end |
.compliance_verify_thor_options(o) ⇒ Object
Compliance login requires ‘–user` or `–refresh_token` If `–user` then either `–password`, `–token`, or `–refresh-token`, is required
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 |
# File 'lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb', line 173 def self.(o) error_msg = [] error_msg.push('Please specify a server using `inspec compliance login https://SERVER`') if o['server'].nil? if o['user'].nil? && o['refresh_token'].nil? error_msg.push('Please specify a `--user=\'USER\'` or a `--refresh-token=\'TOKEN\'`') end if o['user'] && o['password'].nil? && o['token'].nil? && o['refresh_token'].nil? error_msg.push('Please specify either a `--password`, `--token`, or `--refresh-token`') end raise ArgumentError, error_msg.join("\n") unless error_msg.empty? end |
.login(options) ⇒ Object
119 120 121 122 123 124 125 126 127 128 129 130 131 |
# File 'lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb', line 119 def self.login() () ['url'] = ['server'] + '/api' if ['user'] && ['token'] compliance_store_access_token(, ['token']) elsif ['user'] && ['password'] compliance_login_user_pass() elsif ['refresh_token'] compliance_login_refresh_token() end end |