cloudmersive-validate-api-client 1.3.6 → 1.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +25 -9
  3. data/cloudmersive-validate-api-client.gemspec +1 -1
  4. data/docs/AddressApi.md +166 -1
  5. data/docs/AddressGetServersResponse.md +2 -2
  6. data/docs/AddressVerifySyntaxOnlyResponse.md +3 -0
  7. data/docs/DomainApi.md +8 -8
  8. data/docs/EmailApi.md +3 -3
  9. data/docs/GetTimezonesRequest.md +8 -0
  10. data/docs/GetTimezonesResponse.md +13 -0
  11. data/docs/IPAddressApi.md +1 -1
  12. data/docs/LeadEnrichmentApi.md +61 -0
  13. data/docs/LeadEnrichmentRequest.md +21 -0
  14. data/docs/LeadEnrichmentResponse.md +25 -0
  15. data/docs/NameApi.md +59 -4
  16. data/docs/ParseAddressResponse.md +2 -1
  17. data/docs/PhoneNumberApi.md +1 -1
  18. data/docs/Timezone.md +10 -0
  19. data/docs/UserAgentApi.md +1 -1
  20. data/docs/ValidateAddressRequest.md +13 -0
  21. data/docs/ValidateAddressResponse.md +10 -0
  22. data/docs/ValidateCountryRequest.md +8 -0
  23. data/docs/ValidateCountryResponse.md +13 -0
  24. data/docs/ValidateIdentifierRequest.md +15 -0
  25. data/docs/ValidateIdentifierResponse.md +9 -0
  26. data/docs/ValidateUrlRequestFull.md +1 -1
  27. data/docs/ValidateUrlRequestSyntaxOnly.md +1 -1
  28. data/docs/VatApi.md +5 -5
  29. data/docs/VatLookupRequest.md +1 -1
  30. data/docs/VatLookupResponse.md +12 -5
  31. data/docs/WhoisResponse.md +11 -0
  32. data/lib/cloudmersive-validate-api-client.rb +13 -1
  33. data/lib/cloudmersive-validate-api-client/api/address_api.rb +167 -2
  34. data/lib/cloudmersive-validate-api-client/api/domain_api.rb +9 -9
  35. data/lib/cloudmersive-validate-api-client/api/email_api.rb +4 -4
  36. data/lib/cloudmersive-validate-api-client/api/ip_address_api.rb +2 -2
  37. data/lib/cloudmersive-validate-api-client/api/lead_enrichment_api.rb +78 -0
  38. data/lib/cloudmersive-validate-api-client/api/name_api.rb +60 -5
  39. data/lib/cloudmersive-validate-api-client/api/phone_number_api.rb +2 -2
  40. data/lib/cloudmersive-validate-api-client/api/user_agent_api.rb +2 -2
  41. data/lib/cloudmersive-validate-api-client/api/vat_api.rb +6 -6
  42. data/lib/cloudmersive-validate-api-client/api_client.rb +1 -1
  43. data/lib/cloudmersive-validate-api-client/api_error.rb +1 -1
  44. data/lib/cloudmersive-validate-api-client/configuration.rb +1 -1
  45. data/lib/cloudmersive-validate-api-client/models/address_get_servers_response.rb +3 -1
  46. data/lib/cloudmersive-validate-api-client/models/address_verify_syntax_only_response.rb +35 -5
  47. data/lib/cloudmersive-validate-api-client/models/check_response.rb +1 -1
  48. data/lib/cloudmersive-validate-api-client/models/first_name_validation_request.rb +1 -1
  49. data/lib/cloudmersive-validate-api-client/models/first_name_validation_response.rb +1 -1
  50. data/lib/cloudmersive-validate-api-client/models/full_email_validation_response.rb +1 -1
  51. data/lib/cloudmersive-validate-api-client/models/full_name_validation_request.rb +1 -1
  52. data/lib/cloudmersive-validate-api-client/models/full_name_validation_response.rb +1 -1
  53. data/lib/cloudmersive-validate-api-client/models/geolocate_response.rb +1 -1
  54. data/lib/cloudmersive-validate-api-client/models/get_gender_request.rb +1 -1
  55. data/lib/cloudmersive-validate-api-client/models/get_gender_response.rb +1 -1
  56. data/lib/cloudmersive-validate-api-client/models/get_timezones_request.rb +189 -0
  57. data/lib/cloudmersive-validate-api-client/models/get_timezones_response.rb +241 -0
  58. data/lib/cloudmersive-validate-api-client/models/last_name_validation_request.rb +1 -1
  59. data/lib/cloudmersive-validate-api-client/models/last_name_validation_response.rb +1 -1
  60. data/lib/cloudmersive-validate-api-client/models/lead_enrichment_request.rb +319 -0
  61. data/lib/cloudmersive-validate-api-client/models/lead_enrichment_response.rb +359 -0
  62. data/lib/cloudmersive-validate-api-client/models/parse_address_request.rb +1 -1
  63. data/lib/cloudmersive-validate-api-client/models/parse_address_response.rb +18 -8
  64. data/lib/cloudmersive-validate-api-client/models/phone_number_validate_request.rb +1 -1
  65. data/lib/cloudmersive-validate-api-client/models/phone_number_validation_response.rb +1 -1
  66. data/lib/cloudmersive-validate-api-client/models/timezone.rb +209 -0
  67. data/lib/cloudmersive-validate-api-client/models/user_agent_validate_request.rb +1 -1
  68. data/lib/cloudmersive-validate-api-client/models/user_agent_validate_response.rb +1 -1
  69. data/lib/cloudmersive-validate-api-client/models/validate_address_request.rb +239 -0
  70. data/lib/cloudmersive-validate-api-client/models/validate_address_response.rb +209 -0
  71. data/lib/cloudmersive-validate-api-client/models/validate_country_request.rb +189 -0
  72. data/lib/cloudmersive-validate-api-client/models/validate_country_response.rb +241 -0
  73. data/lib/cloudmersive-validate-api-client/models/validate_identifier_request.rb +259 -0
  74. data/lib/cloudmersive-validate-api-client/models/validate_identifier_response.rb +199 -0
  75. data/lib/cloudmersive-validate-api-client/models/validate_url_request_full.rb +2 -1
  76. data/lib/cloudmersive-validate-api-client/models/validate_url_request_syntax_only.rb +2 -1
  77. data/lib/cloudmersive-validate-api-client/models/validate_url_response_full.rb +1 -1
  78. data/lib/cloudmersive-validate-api-client/models/validate_url_response_syntax_only.rb +1 -1
  79. data/lib/cloudmersive-validate-api-client/models/vat_lookup_request.rb +2 -1
  80. data/lib/cloudmersive-validate-api-client/models/vat_lookup_response.rb +80 -5
  81. data/lib/cloudmersive-validate-api-client/models/whois_response.rb +112 -2
  82. data/lib/cloudmersive-validate-api-client/version.rb +2 -2
  83. data/spec/api/address_api_spec.rb +37 -1
  84. data/spec/api/domain_api_spec.rb +3 -3
  85. data/spec/api/email_api_spec.rb +1 -1
  86. data/spec/api/ip_address_api_spec.rb +1 -1
  87. data/spec/api/lead_enrichment_api_spec.rb +47 -0
  88. data/spec/api/name_api_spec.rb +13 -1
  89. data/spec/api/phone_number_api_spec.rb +1 -1
  90. data/spec/api/user_agent_api_spec.rb +1 -1
  91. data/spec/api/vat_api_spec.rb +3 -3
  92. data/spec/api_client_spec.rb +1 -1
  93. data/spec/configuration_spec.rb +1 -1
  94. data/spec/models/address_get_servers_response_spec.rb +1 -1
  95. data/spec/models/address_verify_syntax_only_response_spec.rb +19 -1
  96. data/spec/models/check_response_spec.rb +1 -1
  97. data/spec/models/first_name_validation_request_spec.rb +1 -1
  98. data/spec/models/first_name_validation_response_spec.rb +1 -1
  99. data/spec/models/full_email_validation_response_spec.rb +1 -1
  100. data/spec/models/full_name_validation_request_spec.rb +1 -1
  101. data/spec/models/full_name_validation_response_spec.rb +1 -1
  102. data/spec/models/geolocate_response_spec.rb +1 -1
  103. data/spec/models/get_gender_request_spec.rb +1 -1
  104. data/spec/models/get_gender_response_spec.rb +1 -1
  105. data/spec/models/get_timezones_request_spec.rb +42 -0
  106. data/spec/models/get_timezones_response_spec.rb +72 -0
  107. data/spec/models/last_name_validation_request_spec.rb +1 -1
  108. data/spec/models/last_name_validation_response_spec.rb +1 -1
  109. data/spec/models/lead_enrichment_request_spec.rb +120 -0
  110. data/spec/models/lead_enrichment_response_spec.rb +144 -0
  111. data/spec/models/parse_address_request_spec.rb +1 -1
  112. data/spec/models/parse_address_response_spec.rb +8 -2
  113. data/spec/models/phone_number_validate_request_spec.rb +1 -1
  114. data/spec/models/phone_number_validation_response_spec.rb +1 -1
  115. data/spec/models/timezone_spec.rb +54 -0
  116. data/spec/models/user_agent_validate_request_spec.rb +1 -1
  117. data/spec/models/user_agent_validate_response_spec.rb +1 -1
  118. data/spec/models/validate_address_request_spec.rb +72 -0
  119. data/spec/models/validate_address_response_spec.rb +54 -0
  120. data/spec/models/validate_country_request_spec.rb +42 -0
  121. data/spec/models/validate_country_response_spec.rb +72 -0
  122. data/spec/models/validate_identifier_request_spec.rb +84 -0
  123. data/spec/models/validate_identifier_response_spec.rb +48 -0
  124. data/spec/models/validate_url_request_full_spec.rb +1 -1
  125. data/spec/models/validate_url_request_syntax_only_spec.rb +1 -1
  126. data/spec/models/validate_url_response_full_spec.rb +1 -1
  127. data/spec/models/validate_url_response_syntax_only_spec.rb +1 -1
  128. data/spec/models/vat_lookup_request_spec.rb +1 -1
  129. data/spec/models/vat_lookup_response_spec.rb +43 -1
  130. data/spec/models/whois_response_spec.rb +67 -1
  131. data/spec/spec_helper.rb +1 -1
  132. metadata +51 -16
@@ -0,0 +1,241 @@
1
+ =begin
2
+ #validateapi
3
+
4
+ #The validation APIs help you validate data. Check if an E-mail address is real. Check if a domain is real. Check up on an IP address, and even where it is located. All this and much more is available in the validation API.
5
+
6
+ OpenAPI spec version: v1
7
+
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 2.3.1
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module CloudmersiveValidateApiClient
16
+ # Result of performing a get time zones operation
17
+ class GetTimezonesResponse
18
+ # True if successful, false otherwise
19
+ attr_accessor :successful
20
+
21
+ # Full name of the country
22
+ attr_accessor :country_full_name
23
+
24
+ # Two-letter ISO 3166-1 country code
25
+ attr_accessor :iso_two_letter_code
26
+
27
+ # Two-letter FIPS 10-4 country code
28
+ attr_accessor :fips_two_letter_code
29
+
30
+ # Three-letter ISO 3166-1 country code
31
+ attr_accessor :three_letter_code
32
+
33
+ # Time zones (IANA/Olsen) in the country
34
+ attr_accessor :timezones
35
+
36
+
37
+ # Attribute mapping from ruby-style variable name to JSON key.
38
+ def self.attribute_map
39
+ {
40
+ :'successful' => :'Successful',
41
+ :'country_full_name' => :'CountryFullName',
42
+ :'iso_two_letter_code' => :'ISOTwoLetterCode',
43
+ :'fips_two_letter_code' => :'FIPSTwoLetterCode',
44
+ :'three_letter_code' => :'ThreeLetterCode',
45
+ :'timezones' => :'Timezones'
46
+ }
47
+ end
48
+
49
+ # Attribute type mapping.
50
+ def self.swagger_types
51
+ {
52
+ :'successful' => :'BOOLEAN',
53
+ :'country_full_name' => :'String',
54
+ :'iso_two_letter_code' => :'String',
55
+ :'fips_two_letter_code' => :'String',
56
+ :'three_letter_code' => :'String',
57
+ :'timezones' => :'Array<Timezone>'
58
+ }
59
+ end
60
+
61
+ # Initializes the object
62
+ # @param [Hash] attributes Model attributes in the form of hash
63
+ def initialize(attributes = {})
64
+ return unless attributes.is_a?(Hash)
65
+
66
+ # convert string to symbol for hash key
67
+ attributes = attributes.each_with_object({}){|(k,v), h| h[k.to_sym] = v}
68
+
69
+ if attributes.has_key?(:'Successful')
70
+ self.successful = attributes[:'Successful']
71
+ end
72
+
73
+ if attributes.has_key?(:'CountryFullName')
74
+ self.country_full_name = attributes[:'CountryFullName']
75
+ end
76
+
77
+ if attributes.has_key?(:'ISOTwoLetterCode')
78
+ self.iso_two_letter_code = attributes[:'ISOTwoLetterCode']
79
+ end
80
+
81
+ if attributes.has_key?(:'FIPSTwoLetterCode')
82
+ self.fips_two_letter_code = attributes[:'FIPSTwoLetterCode']
83
+ end
84
+
85
+ if attributes.has_key?(:'ThreeLetterCode')
86
+ self.three_letter_code = attributes[:'ThreeLetterCode']
87
+ end
88
+
89
+ if attributes.has_key?(:'Timezones')
90
+ if (value = attributes[:'Timezones']).is_a?(Array)
91
+ self.timezones = value
92
+ end
93
+ end
94
+
95
+ end
96
+
97
+ # Show invalid properties with the reasons. Usually used together with valid?
98
+ # @return Array for valid properties with the reasons
99
+ def list_invalid_properties
100
+ invalid_properties = Array.new
101
+ return invalid_properties
102
+ end
103
+
104
+ # Check to see if the all the properties in the model are valid
105
+ # @return true if the model is valid
106
+ def valid?
107
+ return true
108
+ end
109
+
110
+ # Checks equality by comparing each attribute.
111
+ # @param [Object] Object to be compared
112
+ def ==(o)
113
+ return true if self.equal?(o)
114
+ self.class == o.class &&
115
+ successful == o.successful &&
116
+ country_full_name == o.country_full_name &&
117
+ iso_two_letter_code == o.iso_two_letter_code &&
118
+ fips_two_letter_code == o.fips_two_letter_code &&
119
+ three_letter_code == o.three_letter_code &&
120
+ timezones == o.timezones
121
+ end
122
+
123
+ # @see the `==` method
124
+ # @param [Object] Object to be compared
125
+ def eql?(o)
126
+ self == o
127
+ end
128
+
129
+ # Calculates hash code according to all attributes.
130
+ # @return [Fixnum] Hash code
131
+ def hash
132
+ [successful, country_full_name, iso_two_letter_code, fips_two_letter_code, three_letter_code, timezones].hash
133
+ end
134
+
135
+ # Builds the object from hash
136
+ # @param [Hash] attributes Model attributes in the form of hash
137
+ # @return [Object] Returns the model itself
138
+ def build_from_hash(attributes)
139
+ return nil unless attributes.is_a?(Hash)
140
+ self.class.swagger_types.each_pair do |key, type|
141
+ if type =~ /\AArray<(.*)>/i
142
+ # check to ensure the input is an array given that the the attribute
143
+ # is documented as an array but the input is not
144
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
145
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } )
146
+ end
147
+ elsif !attributes[self.class.attribute_map[key]].nil?
148
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
149
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
150
+ end
151
+
152
+ self
153
+ end
154
+
155
+ # Deserializes the data based on type
156
+ # @param string type Data type
157
+ # @param string value Value to be deserialized
158
+ # @return [Object] Deserialized data
159
+ def _deserialize(type, value)
160
+ case type.to_sym
161
+ when :DateTime
162
+ DateTime.parse(value)
163
+ when :Date
164
+ Date.parse(value)
165
+ when :String
166
+ value.to_s
167
+ when :Integer
168
+ value.to_i
169
+ when :Float
170
+ value.to_f
171
+ when :BOOLEAN
172
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
173
+ true
174
+ else
175
+ false
176
+ end
177
+ when :Object
178
+ # generic object (usually a Hash), return directly
179
+ value
180
+ when /\AArray<(?<inner_type>.+)>\z/
181
+ inner_type = Regexp.last_match[:inner_type]
182
+ value.map { |v| _deserialize(inner_type, v) }
183
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
184
+ k_type = Regexp.last_match[:k_type]
185
+ v_type = Regexp.last_match[:v_type]
186
+ {}.tap do |hash|
187
+ value.each do |k, v|
188
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
189
+ end
190
+ end
191
+ else # model
192
+ temp_model = CloudmersiveValidateApiClient.const_get(type).new
193
+ temp_model.build_from_hash(value)
194
+ end
195
+ end
196
+
197
+ # Returns the string representation of the object
198
+ # @return [String] String presentation of the object
199
+ def to_s
200
+ to_hash.to_s
201
+ end
202
+
203
+ # to_body is an alias to to_hash (backward compatibility)
204
+ # @return [Hash] Returns the object in the form of hash
205
+ def to_body
206
+ to_hash
207
+ end
208
+
209
+ # Returns the object in the form of hash
210
+ # @return [Hash] Returns the object in the form of hash
211
+ def to_hash
212
+ hash = {}
213
+ self.class.attribute_map.each_pair do |attr, param|
214
+ value = self.send(attr)
215
+ next if value.nil?
216
+ hash[param] = _to_hash(value)
217
+ end
218
+ hash
219
+ end
220
+
221
+ # Outputs non-array value in the form of hash
222
+ # For object, use to_hash. Otherwise, just return the value
223
+ # @param [Object] value Any valid value
224
+ # @return [Hash] Returns the value in the form of hash
225
+ def _to_hash(value)
226
+ if value.is_a?(Array)
227
+ value.compact.map{ |v| _to_hash(v) }
228
+ elsif value.is_a?(Hash)
229
+ {}.tap do |hash|
230
+ value.each { |k, v| hash[k] = _to_hash(v) }
231
+ end
232
+ elsif value.respond_to? :to_hash
233
+ value.to_hash
234
+ else
235
+ value
236
+ end
237
+ end
238
+
239
+ end
240
+
241
+ end
@@ -6,7 +6,7 @@
6
6
  OpenAPI spec version: v1
7
7
 
8
8
  Generated by: https://github.com/swagger-api/swagger-codegen.git
9
- Swagger Codegen version: unset
9
+ Swagger Codegen version: 2.3.1
10
10
 
11
11
  =end
12
12
 
@@ -6,7 +6,7 @@
6
6
  OpenAPI spec version: v1
7
7
 
8
8
  Generated by: https://github.com/swagger-api/swagger-codegen.git
9
- Swagger Codegen version: unset
9
+ Swagger Codegen version: 2.3.1
10
10
 
11
11
  =end
12
12
 
@@ -0,0 +1,319 @@
1
+ =begin
2
+ #validateapi
3
+
4
+ #The validation APIs help you validate data. Check if an E-mail address is real. Check if a domain is real. Check up on an IP address, and even where it is located. All this and much more is available in the validation API.
5
+
6
+ OpenAPI spec version: v1
7
+
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 2.3.1
10
+
11
+ =end
12
+
13
+ require 'date'
14
+
15
+ module CloudmersiveValidateApiClient
16
+ # Input lead contact; fill in known fields to extend them with matched field values
17
+ class LeadEnrichmentRequest
18
+ # The person's business email address for the lead
19
+ attr_accessor :contact_business_email
20
+
21
+ # The person's first name for the lead
22
+ attr_accessor :contact_first_name
23
+
24
+ # The person's last name for the lead
25
+ attr_accessor :contact_last_name
26
+
27
+ # Name of the company for the lead
28
+ attr_accessor :company_name
29
+
30
+ # Domain name / website for the lead
31
+ attr_accessor :company_domain_name
32
+
33
+ # House number of the address of the company for the lead
34
+ attr_accessor :company_house_number
35
+
36
+ # Street name of the address of the company for the lead
37
+ attr_accessor :company_street
38
+
39
+ # City of the address of the company for the lead
40
+ attr_accessor :company_city
41
+
42
+ # State or Province of the address of the company for the lead
43
+ attr_accessor :company_state_or_province
44
+
45
+ # Postal Code of the address of the company for the lead
46
+ attr_accessor :company_postal_code
47
+
48
+ # Country of the address of the company for the lead
49
+ attr_accessor :company_country
50
+
51
+ # Country Code (2-letter ISO 3166-1) of the address of the company for the lead
52
+ attr_accessor :company_country_code
53
+
54
+ # Telephone of the company office for the lead
55
+ attr_accessor :company_telephone
56
+
57
+ # VAT number of the company for the lead
58
+ attr_accessor :company_vat_number
59
+
60
+
61
+ # Attribute mapping from ruby-style variable name to JSON key.
62
+ def self.attribute_map
63
+ {
64
+ :'contact_business_email' => :'ContactBusinessEmail',
65
+ :'contact_first_name' => :'ContactFirstName',
66
+ :'contact_last_name' => :'ContactLastName',
67
+ :'company_name' => :'CompanyName',
68
+ :'company_domain_name' => :'CompanyDomainName',
69
+ :'company_house_number' => :'CompanyHouseNumber',
70
+ :'company_street' => :'CompanyStreet',
71
+ :'company_city' => :'CompanyCity',
72
+ :'company_state_or_province' => :'CompanyStateOrProvince',
73
+ :'company_postal_code' => :'CompanyPostalCode',
74
+ :'company_country' => :'CompanyCountry',
75
+ :'company_country_code' => :'CompanyCountryCode',
76
+ :'company_telephone' => :'CompanyTelephone',
77
+ :'company_vat_number' => :'CompanyVATNumber'
78
+ }
79
+ end
80
+
81
+ # Attribute type mapping.
82
+ def self.swagger_types
83
+ {
84
+ :'contact_business_email' => :'String',
85
+ :'contact_first_name' => :'String',
86
+ :'contact_last_name' => :'String',
87
+ :'company_name' => :'String',
88
+ :'company_domain_name' => :'String',
89
+ :'company_house_number' => :'String',
90
+ :'company_street' => :'String',
91
+ :'company_city' => :'String',
92
+ :'company_state_or_province' => :'String',
93
+ :'company_postal_code' => :'String',
94
+ :'company_country' => :'String',
95
+ :'company_country_code' => :'String',
96
+ :'company_telephone' => :'String',
97
+ :'company_vat_number' => :'String'
98
+ }
99
+ end
100
+
101
+ # Initializes the object
102
+ # @param [Hash] attributes Model attributes in the form of hash
103
+ def initialize(attributes = {})
104
+ return unless attributes.is_a?(Hash)
105
+
106
+ # convert string to symbol for hash key
107
+ attributes = attributes.each_with_object({}){|(k,v), h| h[k.to_sym] = v}
108
+
109
+ if attributes.has_key?(:'ContactBusinessEmail')
110
+ self.contact_business_email = attributes[:'ContactBusinessEmail']
111
+ end
112
+
113
+ if attributes.has_key?(:'ContactFirstName')
114
+ self.contact_first_name = attributes[:'ContactFirstName']
115
+ end
116
+
117
+ if attributes.has_key?(:'ContactLastName')
118
+ self.contact_last_name = attributes[:'ContactLastName']
119
+ end
120
+
121
+ if attributes.has_key?(:'CompanyName')
122
+ self.company_name = attributes[:'CompanyName']
123
+ end
124
+
125
+ if attributes.has_key?(:'CompanyDomainName')
126
+ self.company_domain_name = attributes[:'CompanyDomainName']
127
+ end
128
+
129
+ if attributes.has_key?(:'CompanyHouseNumber')
130
+ self.company_house_number = attributes[:'CompanyHouseNumber']
131
+ end
132
+
133
+ if attributes.has_key?(:'CompanyStreet')
134
+ self.company_street = attributes[:'CompanyStreet']
135
+ end
136
+
137
+ if attributes.has_key?(:'CompanyCity')
138
+ self.company_city = attributes[:'CompanyCity']
139
+ end
140
+
141
+ if attributes.has_key?(:'CompanyStateOrProvince')
142
+ self.company_state_or_province = attributes[:'CompanyStateOrProvince']
143
+ end
144
+
145
+ if attributes.has_key?(:'CompanyPostalCode')
146
+ self.company_postal_code = attributes[:'CompanyPostalCode']
147
+ end
148
+
149
+ if attributes.has_key?(:'CompanyCountry')
150
+ self.company_country = attributes[:'CompanyCountry']
151
+ end
152
+
153
+ if attributes.has_key?(:'CompanyCountryCode')
154
+ self.company_country_code = attributes[:'CompanyCountryCode']
155
+ end
156
+
157
+ if attributes.has_key?(:'CompanyTelephone')
158
+ self.company_telephone = attributes[:'CompanyTelephone']
159
+ end
160
+
161
+ if attributes.has_key?(:'CompanyVATNumber')
162
+ self.company_vat_number = attributes[:'CompanyVATNumber']
163
+ end
164
+
165
+ end
166
+
167
+ # Show invalid properties with the reasons. Usually used together with valid?
168
+ # @return Array for valid properties with the reasons
169
+ def list_invalid_properties
170
+ invalid_properties = Array.new
171
+ return invalid_properties
172
+ end
173
+
174
+ # Check to see if the all the properties in the model are valid
175
+ # @return true if the model is valid
176
+ def valid?
177
+ return true
178
+ end
179
+
180
+ # Checks equality by comparing each attribute.
181
+ # @param [Object] Object to be compared
182
+ def ==(o)
183
+ return true if self.equal?(o)
184
+ self.class == o.class &&
185
+ contact_business_email == o.contact_business_email &&
186
+ contact_first_name == o.contact_first_name &&
187
+ contact_last_name == o.contact_last_name &&
188
+ company_name == o.company_name &&
189
+ company_domain_name == o.company_domain_name &&
190
+ company_house_number == o.company_house_number &&
191
+ company_street == o.company_street &&
192
+ company_city == o.company_city &&
193
+ company_state_or_province == o.company_state_or_province &&
194
+ company_postal_code == o.company_postal_code &&
195
+ company_country == o.company_country &&
196
+ company_country_code == o.company_country_code &&
197
+ company_telephone == o.company_telephone &&
198
+ company_vat_number == o.company_vat_number
199
+ end
200
+
201
+ # @see the `==` method
202
+ # @param [Object] Object to be compared
203
+ def eql?(o)
204
+ self == o
205
+ end
206
+
207
+ # Calculates hash code according to all attributes.
208
+ # @return [Fixnum] Hash code
209
+ def hash
210
+ [contact_business_email, contact_first_name, contact_last_name, company_name, company_domain_name, company_house_number, company_street, company_city, company_state_or_province, company_postal_code, company_country, company_country_code, company_telephone, company_vat_number].hash
211
+ end
212
+
213
+ # Builds the object from hash
214
+ # @param [Hash] attributes Model attributes in the form of hash
215
+ # @return [Object] Returns the model itself
216
+ def build_from_hash(attributes)
217
+ return nil unless attributes.is_a?(Hash)
218
+ self.class.swagger_types.each_pair do |key, type|
219
+ if type =~ /\AArray<(.*)>/i
220
+ # check to ensure the input is an array given that the the attribute
221
+ # is documented as an array but the input is not
222
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
223
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } )
224
+ end
225
+ elsif !attributes[self.class.attribute_map[key]].nil?
226
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
227
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
228
+ end
229
+
230
+ self
231
+ end
232
+
233
+ # Deserializes the data based on type
234
+ # @param string type Data type
235
+ # @param string value Value to be deserialized
236
+ # @return [Object] Deserialized data
237
+ def _deserialize(type, value)
238
+ case type.to_sym
239
+ when :DateTime
240
+ DateTime.parse(value)
241
+ when :Date
242
+ Date.parse(value)
243
+ when :String
244
+ value.to_s
245
+ when :Integer
246
+ value.to_i
247
+ when :Float
248
+ value.to_f
249
+ when :BOOLEAN
250
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
251
+ true
252
+ else
253
+ false
254
+ end
255
+ when :Object
256
+ # generic object (usually a Hash), return directly
257
+ value
258
+ when /\AArray<(?<inner_type>.+)>\z/
259
+ inner_type = Regexp.last_match[:inner_type]
260
+ value.map { |v| _deserialize(inner_type, v) }
261
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
262
+ k_type = Regexp.last_match[:k_type]
263
+ v_type = Regexp.last_match[:v_type]
264
+ {}.tap do |hash|
265
+ value.each do |k, v|
266
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
267
+ end
268
+ end
269
+ else # model
270
+ temp_model = CloudmersiveValidateApiClient.const_get(type).new
271
+ temp_model.build_from_hash(value)
272
+ end
273
+ end
274
+
275
+ # Returns the string representation of the object
276
+ # @return [String] String presentation of the object
277
+ def to_s
278
+ to_hash.to_s
279
+ end
280
+
281
+ # to_body is an alias to to_hash (backward compatibility)
282
+ # @return [Hash] Returns the object in the form of hash
283
+ def to_body
284
+ to_hash
285
+ end
286
+
287
+ # Returns the object in the form of hash
288
+ # @return [Hash] Returns the object in the form of hash
289
+ def to_hash
290
+ hash = {}
291
+ self.class.attribute_map.each_pair do |attr, param|
292
+ value = self.send(attr)
293
+ next if value.nil?
294
+ hash[param] = _to_hash(value)
295
+ end
296
+ hash
297
+ end
298
+
299
+ # Outputs non-array value in the form of hash
300
+ # For object, use to_hash. Otherwise, just return the value
301
+ # @param [Object] value Any valid value
302
+ # @return [Hash] Returns the value in the form of hash
303
+ def _to_hash(value)
304
+ if value.is_a?(Array)
305
+ value.compact.map{ |v| _to_hash(v) }
306
+ elsif value.is_a?(Hash)
307
+ {}.tap do |hash|
308
+ value.each { |k, v| hash[k] = _to_hash(v) }
309
+ end
310
+ elsif value.respond_to? :to_hash
311
+ value.to_hash
312
+ else
313
+ value
314
+ end
315
+ end
316
+
317
+ end
318
+
319
+ end