Class: OpenC3::Model

Inherits:
Object show all
Defined in:
lib/openc3/models/model.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(primary_key, **kw_args) ⇒ Model

Store the primary key and keyword arguments



136
137
138
139
140
141
142
143
# File 'lib/openc3/models/model.rb', line 136

def initialize(primary_key, **kw_args)
  @primary_key = primary_key
  @name = kw_args[:name]
  @updated_at = kw_args[:updated_at]
  @plugin = kw_args[:plugin]
  @scope = kw_args[:scope]
  @destroyed = false
end

Instance Attribute Details

#nameObject

Returns the value of attribute name.



28
29
30
# File 'lib/openc3/models/model.rb', line 28

def name
  @name
end

#pluginObject

Returns the value of attribute plugin.



30
31
32
# File 'lib/openc3/models/model.rb', line 30

def plugin
  @plugin
end

#scopeObject

Returns the value of attribute scope.



31
32
33
# File 'lib/openc3/models/model.rb', line 31

def scope
  @scope
end

#updated_atObject

Returns the value of attribute updated_at.



29
30
31
# File 'lib/openc3/models/model.rb', line 29

def updated_at
  @updated_at
end

Class Method Details

.all(primary_key) ⇒ Array<Hash>

Returns All the models (as Hash objects) stored under the primary key.

Returns:

  • (Array<Hash>)

    All the models (as Hash objects) stored under the primary key



56
57
58
59
60
61
62
# File 'lib/openc3/models/model.rb', line 56

def self.all(primary_key)
  hash = store.hgetall(primary_key)
  hash.each do |key, value|
    hash[key] = JSON.parse(value, :allow_nan => true, :create_additions => true)
  end
  hash
end

.filter(key, value, scope:, use_regex: false) ⇒ Object

Loops over all items and returns objects that match a key value pair



66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# File 'lib/openc3/models/model.rb', line 66

def self.filter(key, value, scope:, use_regex: false)
  filtered = {}
  results = all(scope: scope)
  regex = nil
  regex = Regexp.new(value) if use_regex
  results.each do |name, result|
    if regex
      if result[key] =~ regex
        filtered[name] = result
      end
    else
      if result[key] == value
        filtered[name] = result
      end
    end
  end
  return filtered
end

.find_all_by_plugin(plugin:, scope:) ⇒ Array<Object>

Returns All the models (as Model objects) stored under the primary key which have the plugin attribute.

Returns:

  • (Array<Object>)

    All the models (as Model objects) stored under the primary key which have the plugin attribute



122
123
124
125
126
127
128
129
# File 'lib/openc3/models/model.rb', line 122

def self.find_all_by_plugin(plugin:, scope:)
  result = {}
  models = get_all_models(scope: scope)
  models.each do |name, model|
    result[name] = model if model.plugin == plugin
  end
  result
end

.from_json(json, scope:) ⇒ Model

Returns Model generated from the passed JSON.

Returns:

  • (Model)

    Model generated from the passed JSON



93
94
95
96
97
98
99
100
# File 'lib/openc3/models/model.rb', line 93

def self.from_json(json, scope:)
  json = JSON.parse(json, :allow_nan => true, :create_additions => true) if String === json
  raise "json data is nil" if json.nil?

  json[:scope] = scope
  json.transform_keys!(&:to_sym)
  self.new(**json, scope: scope)
end

.get(primary_key, name:) ⇒ Hash|nil

Returns Hash of this model or nil if name not found under primary_key.

Returns:

  • (Hash|nil)

    Hash of this model or nil if name not found under primary_key



41
42
43
44
45
46
47
48
# File 'lib/openc3/models/model.rb', line 41

def self.get(primary_key, name:)
  json = store.hget(primary_key, name)
  if json
    return JSON.parse(json, :allow_nan => true, :create_additions => true)
  else
    return nil
  end
end

.get_all_models(scope:) ⇒ Array<Object>

Returns All the models (as Model objects) stored under the primary key.

Returns:

  • (Array<Object>)

    All the models (as Model objects) stored under the primary key



114
115
116
117
118
# File 'lib/openc3/models/model.rb', line 114

def self.get_all_models(scope:)
  models = {}
  all(scope: scope).each { |name, json| models[name] = from_json(json, scope: scope) }
  models
end

.get_model(name:, scope:) ⇒ Object|nil

Calls self.get and then from_json to turn the Hash configuration into a Ruby Model object.

Returns:

  • (Object|nil)

    Model object or nil if name not found under primary_key



104
105
106
107
108
109
110
111
# File 'lib/openc3/models/model.rb', line 104

def self.get_model(name:, scope:)
  json = get(name: name, scope: scope)
  if json
    return from_json(json, scope: scope)
  else
    return nil
  end
end

.handle_config(parser, keyword, parameters) ⇒ Object



131
132
133
# File 'lib/openc3/models/model.rb', line 131

def self.handle_config(parser, keyword, parameters)
  raise "must be implemented by subclass"
end

.names(primary_key) ⇒ Array<String>

Returns All the names stored under the primary key.

Returns:

  • (Array<String>)

    All the names stored under the primary key



51
52
53
# File 'lib/openc3/models/model.rb', line 51

def self.names(primary_key)
  store.hkeys(primary_key).sort
end

.set(json, scope:) ⇒ Object

Sets (updates) the redis hash of this model



86
87
88
89
90
# File 'lib/openc3/models/model.rb', line 86

def self.set(json, scope:)
  json[:scope] = scope
  json.transform_keys!(&:to_sym)
  self.new(**json).create(force: true)
end

.storeObject



33
34
35
# File 'lib/openc3/models/model.rb', line 33

def self.store
  Store
end

Instance Method Details

#as_json(*a) ⇒ Hash

Returns JSON encoding of this model.

Returns:

  • (Hash)

    JSON encoding of this model



189
190
191
192
193
194
# File 'lib/openc3/models/model.rb', line 189

def as_json(*a)
  { 'name' => @name,
    'updated_at' => @updated_at,
    'plugin' => @plugin,
    'scope' => @scope }
end

#create(update: false, force: false) ⇒ Object

Update the Redis hash at primary_key and set the field “name” to the JSON generated via calling as_json



147
148
149
150
151
152
153
154
155
156
157
158
# File 'lib/openc3/models/model.rb', line 147

def create(update: false, force: false)
  unless force
    existing = self.class.store.hget(@primary_key, @name)
    if existing
      raise "#{@primary_key}:#{@name} already exists at create" unless update
    else
      raise "#{@primary_key}:#{@name} doesn't exist at update" if update
    end
  end
  @updated_at = Time.now.to_nsec_from_epoch
  self.class.store.hset(@primary_key, @name, JSON.generate(self.as_json(:allow_nan => true), :allow_nan => true))
end

#deploy(gem_path, variables) ⇒ Object

Deploy the model into the OpenC3 system. Subclasses must implement this and typically create MicroserviceModels to implement.



167
168
169
# File 'lib/openc3/models/model.rb', line 167

def deploy(gem_path, variables)
  raise "must be implemented by subclass"
end

#destroyObject

Delete the model from the Store



177
178
179
180
181
# File 'lib/openc3/models/model.rb', line 177

def destroy
  @destroyed = true
  undeploy()
  self.class.store.hdel(@primary_key, @name)
end

#destroyed?Boolean

Indicate if destroy has been called

Returns:

  • (Boolean)


184
185
186
# File 'lib/openc3/models/model.rb', line 184

def destroyed?
  @destroyed
end

#undeployObject

Undo the actions of deploy and remove the model from OpenC3. Subclasses must implement this as by default it is a noop.



173
174
# File 'lib/openc3/models/model.rb', line 173

def undeploy
end

#updateObject

Alias for create(update: true)



161
162
163
# File 'lib/openc3/models/model.rb', line 161

def update
  create(update: true)
end