Module: Alula::Dcp::ResourceAttributes
- Included in:
- Config, Config::BusModules, Config::BusModules::BusModule, Config::CommData, Config::CommData::AutoCommTestInterval, Config::CommData::ServerHeartbeats, Config::CommData::ServerKeepAlives, Config::PanelOptions, Config::PanelOptions::AcFailDetectDelay, Config::PanelOptions::EventReportingDelay, Config::PanelOptions::KeyFobButtonFunctions, Config::PanelOptions::MinimumPinSize, Config::PanelOptions::PanelLedBrightness, Config::PanelOptions::PanelMiscOptions, Config::PanelOptions::PanelOptions, Config::PanelOptions::ReportableEventTypesPartitions, Config::PanelOptions::ReportableEventTypesSystem, Config::PanelOptions::SwingerThreshold, Config::PanelOptions::SystemOptions, Config::PanelOptions::TroubleBeepSuppress, Config::PanelOptions::VirtualInterfaceOptions, Config::Partitions, Config::Partitions::Partition, Config::SirenData, Config::SirenData::Siren, Config::Synchronize, Config::Timers, Config::Timers::EntryDelays, Config::Timers::ExitDelays, Config::Timers::SensorSupervisionTime, Config::Timers::SirenTimeout, Config::UsersData, Config::UsersData::DuressPin, Config::UsersData::InstallerPin, Config::UsersData::User, ObjectField
- Defined in:
- lib/alula/dcp/resource_attributes.rb
Defined Under Namespace
Modules: InstanceMethods
Class Method Summary collapse
Instance Method Summary collapse
- #date_fields ⇒ Object
-
#field(field_name, **opts) ⇒ Object
Memoizes field names and options.
- #field_names ⇒ Object
- #filterable_fields ⇒ Object
- #get_fields ⇒ Object
- #get_http_methods ⇒ Object
- #get_resource_path(index = nil) ⇒ Object
- #get_type ⇒ Object
- #http_methods(methods) ⇒ Object
- #param_key ⇒ Object
-
#resource_path(name) ⇒ Object
Class methods for defining how fields and types work NOTE: We’re not using real getters and setters here.
- #sortable_fields ⇒ Object
- #type(type) ⇒ Object
Class Method Details
.extended(base) ⇒ Object
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/alula/dcp/resource_attributes.rb', line 6 def self.extended(base) base.class_eval do class << self attr_writer :has_svm def has_svm @has_svm ||= false end end @resource_path = nil @type = nil @http_methods = [] @fields = {} def mark_dirty(field_name, old_value, new_value) @dirty_attributes << field_name if old_value != new_value end end base.include(InstanceMethods) end |
Instance Method Details
#date_fields ⇒ Object
128 129 130 131 132 133 |
# File 'lib/alula/dcp/resource_attributes.rb', line 128 def date_fields @date_fields ||= get_fields.each_pair.each_with_object([]) do |(field_name, opts), collector| collector << field_name if opts[:type].to_sym == :date end end |
#field(field_name, **opts) ⇒ Object
Memoizes field names and options
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/alula/dcp/resource_attributes.rb', line 60 def field(field_name, **opts) @fields ||= {} @fields[field_name] = opts return if has_svm && field_name != :index json_key = Alula::Util.camelize(field_name) instance_eval do # Reader method for attribute define_method(field_name) do value = @values[json_key] if opts[:type] == :date && ![nil, ''].include?(value) begin DateTime.parse(value) rescue ArgumentError value end elsif opts[:type] == :object && opts[:use] && !value.nil? && value.respond_to?(:each) if opts[:use].superclass == Alula::Dcp::ObjectField opts[:use].new({}, field_name, value) elsif respond_to?(:device_id) opts[:use].new(device_id, value) else opts[:use].new(nil, value) end elsif opts[:type] == :array && opts[:of] && !value.nil? && value.respond_to?(:each) # Array of objects, each object is a new instance of the use class value.each_with_object([]) do |item, collector| collector << opts[:of].new(device_id, item) end elsif opts[:type] == :boolean [true, 'true', 1, '1'].include? value elsif opts[:type] == :number value&.to_i else value end end # Setter method define_method("#{field_name}=") do |new_value| # # Coerce 'blank like' fields into a defined blank value # This helps HTML form submissions. A blank text field comes through as an # empty string, instead of a nil as the API validates for. new_value = nil if new_value == '' new_value = [true, 'true', 1, '1'].include? new_value if opts[:type] == :boolean # Mark the attribute as dirty if the new value is different mark_dirty(field_name, @values[json_key], new_value) # # Assign the new value (always assigned even if a duplicate) @values[json_key] = new_value end end end |
#field_names ⇒ Object
147 148 149 |
# File 'lib/alula/dcp/resource_attributes.rb', line 147 def field_names get_fields.keys end |
#filterable_fields ⇒ Object
135 136 137 138 139 |
# File 'lib/alula/dcp/resource_attributes.rb', line 135 def filterable_fields get_fields.each_pair.each_with_object([]) do |(field_name, opts), collector| collector << field_name if opts[:filterable] == true end end |
#get_fields ⇒ Object
117 118 119 120 121 122 123 124 125 126 |
# File 'lib/alula/dcp/resource_attributes.rb', line 117 def get_fields parent_fields = if superclass.respond_to?(:get_fields) superclass.get_fields else {} end @fields ||= {} parent_fields.merge(@fields) end |
#get_http_methods ⇒ Object
54 55 56 |
# File 'lib/alula/dcp/resource_attributes.rb', line 54 def get_http_methods @http_methods end |
#get_resource_path(index = nil) ⇒ Object
36 37 38 39 40 |
# File 'lib/alula/dcp/resource_attributes.rb', line 36 def get_resource_path(index = nil) return "#{@resource_path}/#{index}" if index @resource_path end |
#get_type ⇒ Object
46 47 48 |
# File 'lib/alula/dcp/resource_attributes.rb', line 46 def get_type @type end |
#http_methods(methods) ⇒ Object
50 51 52 |
# File 'lib/alula/dcp/resource_attributes.rb', line 50 def http_methods(methods) @http_methods = methods end |
#param_key ⇒ Object
151 152 153 154 155 |
# File 'lib/alula/dcp/resource_attributes.rb', line 151 def param_key # return only the last part of the class name, in snake_case # e.g. Alula::Dcp::Config::PanelOptions becomes panel_options Util.underscore(name.split('::')[-1]) end |
#resource_path(name) ⇒ Object
Class methods for defining how fields and types work NOTE: We’re not using real getters and setters here. I want the method signature
to match how most other Ruby class configuration is done, and that is with
simple methods that take params.
32 33 34 |
# File 'lib/alula/dcp/resource_attributes.rb', line 32 def resource_path(name) @resource_path = name end |
#sortable_fields ⇒ Object
141 142 143 144 145 |
# File 'lib/alula/dcp/resource_attributes.rb', line 141 def sortable_fields get_fields.each_pair.each_with_object([]) do |(field_name, opts), collector| collector << field_name if opts[:sortable] == true end end |
#type(type) ⇒ Object
42 43 44 |
# File 'lib/alula/dcp/resource_attributes.rb', line 42 def type(type) @type = type end |