Class: Verizon::DeviceFilter
- Defined in:
- lib/verizon/models/device_filter.rb
Overview
Specify the kind of the device identifier, the type of match, and the string that you want to match.
Instance Attribute Summary collapse
-
#account ⇒ String
The the billing account that the devices belong to.
-
#custom_fields ⇒ Array[CustomFields]
Custom field names and values, if you want to only include devices that have matching values.
-
#group_name ⇒ String
Only include devices that are in this device group.
-
#service_plan ⇒ String
Only include devices that have this service plan.
Class Method Summary collapse
-
.from_hash(hash) ⇒ Object
Creates an instance of the object from a hash.
-
.names ⇒ Object
A mapping from model property names to API property names.
-
.nullables ⇒ Object
An array for nullable fields.
-
.optionals ⇒ Object
An array for optional fields.
Instance Method Summary collapse
-
#initialize(account = SKIP, group_name = SKIP, service_plan = SKIP, custom_fields = SKIP) ⇒ DeviceFilter
constructor
A new instance of DeviceFilter.
Methods inherited from BaseModel
Constructor Details
#initialize(account = SKIP, group_name = SKIP, service_plan = SKIP, custom_fields = SKIP) ⇒ DeviceFilter
Returns a new instance of DeviceFilter.
55 56 57 58 59 60 61 |
# File 'lib/verizon/models/device_filter.rb', line 55 def initialize(account = SKIP, group_name = SKIP, service_plan = SKIP, custom_fields = SKIP) @account = account unless account == SKIP @group_name = group_name unless group_name == SKIP @service_plan = service_plan unless service_plan == SKIP @custom_fields = custom_fields unless custom_fields == SKIP end |
Instance Attribute Details
#account ⇒ String
The the billing account that the devices belong to.
15 16 17 |
# File 'lib/verizon/models/device_filter.rb', line 15 def account @account end |
#custom_fields ⇒ Array[CustomFields]
Custom field names and values, if you want to only include devices that have matching values.
28 29 30 |
# File 'lib/verizon/models/device_filter.rb', line 28 def custom_fields @custom_fields end |
#group_name ⇒ String
Only include devices that are in this device group.
19 20 21 |
# File 'lib/verizon/models/device_filter.rb', line 19 def group_name @group_name end |
#service_plan ⇒ String
Only include devices that have this service plan.
23 24 25 |
# File 'lib/verizon/models/device_filter.rb', line 23 def service_plan @service_plan end |
Class Method Details
.from_hash(hash) ⇒ Object
Creates an instance of the object from a hash.
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/verizon/models/device_filter.rb', line 64 def self.from_hash(hash) return nil unless hash # Extract variables from the hash. account = hash.key?('account') ? hash['account'] : SKIP group_name = hash.key?('groupName') ? hash['groupName'] : SKIP service_plan = hash.key?('servicePlan') ? hash['servicePlan'] : SKIP # Parameter is an array, so we need to iterate through it custom_fields = nil unless hash['customFields'].nil? custom_fields = [] hash['customFields'].each do |structure| custom_fields << (CustomFields.from_hash(structure) if structure) end end custom_fields = SKIP unless hash.key?('customFields') # Create object from extracted values. DeviceFilter.new(account, group_name, service_plan, custom_fields) end |
.names ⇒ Object
A mapping from model property names to API property names.
31 32 33 34 35 36 37 38 |
# File 'lib/verizon/models/device_filter.rb', line 31 def self.names @_hash = {} if @_hash.nil? @_hash['account'] = 'account' @_hash['group_name'] = 'groupName' @_hash['service_plan'] = 'servicePlan' @_hash['custom_fields'] = 'customFields' @_hash end |
.nullables ⇒ Object
An array for nullable fields
51 52 53 |
# File 'lib/verizon/models/device_filter.rb', line 51 def self.nullables [] end |
.optionals ⇒ Object
An array for optional fields
41 42 43 44 45 46 47 48 |
# File 'lib/verizon/models/device_filter.rb', line 41 def self.optionals %w[ account group_name service_plan custom_fields ] end |