class PlaceOS::Model::Trigger::Actions

Defined in:

placeos-models/trigger/actions.cr

Constant Summary

Log = ::Log.for(self)

Constructors

Class Method Summary

Instance Method Summary

Instance methods inherited from class PlaceOS::Model::SubModel

apply_defaults apply_defaults, assign_attributes(params : HTTP::Params | Hash(String, String) | Tuple(String, String))
assign_attributes(model : PlaceOS::Model::SubModel)
assign_attributes
assign_attributes
, attributes attributes, attributes_tuple attributes_tuple, persistent_attributes persistent_attributes, to_reql to_reql

Constructor methods inherited from class PlaceOS::Model::SubModel

new(ctx : YAML::ParseContext, node : YAML::Nodes::Node)
new(pull : JSON::PullParser)
new(rs : DB::ResultSet)
new

Class methods inherited from class PlaceOS::Model::SubModel

attributes : Array(Symbol) attributes, from_rs(rs : DB::ResultSet) from_rs

Constructor Detail

def self.from_json(string_or_io : String | IO, trusted : Bool = false) : self #

def self.from_json(string_or_io : String | IO, root : String, trusted : Bool = false) : self #

Deserializes the given JSON in string_or_io into an instance of self, assuming the JSON consists of an JSON object with key root, and whose value is the value to deserialize. Will not deserialise from fields with mass_assign: false

class User < ActiveModel::Model
  attribute name : String
  attribute google_id : UUID, mass_assign: false
end

User.from_json(%({"main": {"name": "Jason", "google_id": "f6f70bfb-c882-446d-8758-7ce47db39620"}}), root: "main") # => #<User:0x103131b20 @name="Jason">

def self.from_trusted_json(string_or_io : String | IO, root : String) : self #

def self.from_trusted_json(string_or_io : String | IO) : self #

Serialize from a trusted JSON source


def self.from_trusted_yaml(string_or_io : String | IO) : self #

Serialize from a trusted YAML source


def self.from_yaml(string_or_io : String | IO, trusted : Bool = false) : self #

def self.new(ctx : YAML::ParseContext, node : YAML::Nodes::Node) #

def self.new(pull : JSON::PullParser) #

def self.new(rs : DB::ResultSet) #

def self.new(functions : Array(PlaceOS::Model::Trigger::Actions::Function) | ActiveModel::Model::None = ::ActiveModel::Model::None.new, mailers : Array(PlaceOS::Model::Trigger::Actions::Email) | ActiveModel::Model::None = ::ActiveModel::Model::None.new) #

def self.new(params : HTTP::Params | Hash(String, String) | Tuple(String, String)) #

Initialize PlaceOS::Model::Trigger::Actions from HTTP::Params.


Class Method Detail

def self.attributes : Array(Symbol) #

Returns all attribute keys.


def self.from_rs(rs : DB::ResultSet) #

Instance Method Detail

def after_initialize(trusted : Bool) #

def apply_defaults #

Generate code to apply default values


def assign_attributes(functions : Array(PlaceOS::Model::Trigger::Actions::Function) | Missing = Missing, mailers : Array(PlaceOS::Model::Trigger::Actions::Email) | Missing = Missing) #

Assign to multiple attributes.


def assign_attributes(params : HTTP::Params | Hash(String, String) | Tuple(String, String)) #

Assign to mulitple attributes via HTTP::Params.


def assign_attributes(model : PlaceOS::Model::Trigger::Actions) #

Assign to multiple attributes from a model object


def assign_attributes_from_json(json, root : String) #

def assign_attributes_from_json(json) #

def assign_attributes_from_trusted_json(json, root : String) #

def assign_attributes_from_trusted_json(json) #

Assign each field from JSON if field exists in JSON and has changed in model


def assign_attributes_from_trusted_yaml(yaml) #

def assign_attributes_from_yaml(yaml) #

Uses the YAML parser as JSON is valid YAML


def attributes #

Returns a Hash of all attribute values


def attributes_tuple #

Returns a NamedTuple of all attribute values.


def changed? #

Check if any attributes have changed.


def changed_attributes #

Returns a Hash with all changed attributes.


def changed_json(io : IO) : Nil #

Serialize the set of changed attributes to JSON.


def changed_json : String #

Serialize the set of changed attributes to JSON.


def changed_yaml(io : IO) : Nil #

Serialize the set of changed attributes to YAML.


def changed_yaml : String #

Serialize the set of changed attributes to YAML.


def clear_changes_information #

Reset changes for all attributes.


#functions getter


def functions=(value : Array(PlaceOS::Model::Trigger::Actions::Function)) #

Setters #functions setter


def functions? : Array(PlaceOS::Model::Trigger::Actions::Function) | Nil #

def functions_assigned? : Bool #

def functions_change : Tuple(Array(PlaceOS::Model::Trigger::Actions::Function) | Nil, Array(PlaceOS::Model::Trigger::Actions::Function) | Nil) | Nil #

Returns a Tuple of the previous and the current value of an instance variable if it has changed


def functions_changed? : Bool #

def functions_default : Array(Function) #

#functions's default value


def functions_present? : Bool #

def functions_was : Array(PlaceOS::Model::Trigger::Actions::Function) | Nil #

def functions_will_change! : Nil #

Include #functions in the set of changed attributes, whether it has changed or not.


#mailers getter


def mailers=(value : Array(PlaceOS::Model::Trigger::Actions::Email)) #

#mailers setter


def mailers? : Array(PlaceOS::Model::Trigger::Actions::Email) | Nil #

def mailers_assigned? : Bool #

def mailers_change : Tuple(Array(PlaceOS::Model::Trigger::Actions::Email) | Nil, Array(PlaceOS::Model::Trigger::Actions::Email) | Nil) | Nil #

Returns a Tuple of the previous and the current value of an instance variable if it has changed


def mailers_changed? : Bool #

def mailers_default : Array(Email) #

#mailers's default value


def mailers_present? : Bool #

def mailers_was : Array(PlaceOS::Model::Trigger::Actions::Email) | Nil #

def mailers_will_change! : Nil #

Include #mailers in the set of changed attributes, whether it has changed or not.


def persistent_attributes #

Returns a Hash of all attributes that can be persisted.


def restore_attributes #

Reset each attribute to their previous values and clears all changes.


def validate_nilability #

Validate that all non-nillable fields have values.