Class: OpenC3::ServerProxy
Overview
Provides a proxy to the JsonDRbObject which communicates with the API server
Instance Method Summary collapse
-
#generate_auth ⇒ Object
generate the auth object.
-
#generate_timeout ⇒ Object
pull openc3-cmd-tlm-api timeout from environment variables.
-
#generate_url ⇒ Object
pull openc3-cmd-tlm-api url from environment variables.
-
#initialize ⇒ ServerProxy
constructor
Create a JsonDRbObject connection to the API server.
-
#method_missing(method_name, *method_params, **kw_params) ⇒ Object
Ruby method which captures any method calls on this object.
Constructor Details
#initialize ⇒ ServerProxy
Create a JsonDRbObject connection to the API server
206 207 208 209 210 211 212 |
# File 'lib/openc3/script/script.rb', line 206 def initialize @json_drb = JsonDRbObject.new( url: generate_url(), timeout: generate_timeout(), authentication: generate_auth() ) end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *method_params, **kw_params) ⇒ Object
Ruby method which captures any method calls on this object. This allows us to proxy the methods to the API server through the JsonDRbObject.
216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 |
# File 'lib/openc3/script/script.rb', line 216 def method_missing(method_name, *method_params, **kw_params) # Must call shutdown and disconnect on the JsonDRbObject itself # to avoid it being sent to the API kw_params[:scope] = $openc3_scope unless kw_params[:scope] case method_name when :shutdown @json_drb.shutdown when :request @json_drb.request(*method_params, **kw_params) else if $disconnect result = nil # If :disconnect is there delete it and return the value # If it is not there, delete returns nil disconnect = kw_params.delete(:disconnect) # The only commands allowed through in disconnect mode are read-only # Thus we allow the get, list, tlm and limits_enabled and subscribe methods if method_name =~ /get_\w*|list_\w*|^tlm|limits_enabled|subscribe/ result = @json_drb.method_missing(method_name, *method_params, **kw_params) end # If they overrode the return value using the disconnect keyword then return that return disconnect ? disconnect : result else @json_drb.method_missing(method_name, *method_params, **kw_params) end end end |
Instance Method Details
#generate_auth ⇒ Object
generate the auth object
197 198 199 200 201 202 203 |
# File 'lib/openc3/script/script.rb', line 197 def generate_auth if ENV['OPENC3_API_USER'].nil? return OpenC3Authentication.new() else return OpenC3KeycloakAuthentication.new(ENV['OPENC3_KEYCLOAK_URL']) end end |
#generate_timeout ⇒ Object
pull openc3-cmd-tlm-api timeout from environment variables
191 192 193 194 |
# File 'lib/openc3/script/script.rb', line 191 def generate_timeout timeout = ENV['OPENC3_API_TIMEOUT'] || '1.0' return timeout.to_f end |
#generate_url ⇒ Object
pull openc3-cmd-tlm-api url from environment variables
182 183 184 185 186 187 188 |
# File 'lib/openc3/script/script.rb', line 182 def generate_url schema = ENV['OPENC3_API_SCHEMA'] || 'http' hostname = ENV['OPENC3_API_HOSTNAME'] || (ENV['OPENC3_DEVEL'] ? '127.0.0.1' : 'openc3-cmd-tlm-api') port = ENV['OPENC3_API_PORT'] || '2901' port = port.to_i return "#{schema}://#{hostname}:#{port}" end |