stage-ruby 0.0.02

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 (40) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +9 -0
  3. data/Gemfile.lock +73 -0
  4. data/README.md +143 -0
  5. data/Rakefile +8 -0
  6. data/docs/AccessFeatureForm.md +8 -0
  7. data/docs/AccessForm.md +9 -0
  8. data/docs/ClientUserForm.md +7 -0
  9. data/docs/ClientUserObjectForm.md +13 -0
  10. data/docs/Field.md +8 -0
  11. data/docs/StageApi.md +167 -0
  12. data/docs/StageError.md +11 -0
  13. data/example.rb +41 -0
  14. data/git_push.sh +55 -0
  15. data/lib/stage-ruby/api/stage_api.rb +232 -0
  16. data/lib/stage-ruby/api_client.rb +388 -0
  17. data/lib/stage-ruby/api_error.rb +57 -0
  18. data/lib/stage-ruby/configuration.rb +205 -0
  19. data/lib/stage-ruby/models/access_feature_form.rb +227 -0
  20. data/lib/stage-ruby/models/access_form.rb +246 -0
  21. data/lib/stage-ruby/models/client_user_form.rb +209 -0
  22. data/lib/stage-ruby/models/client_user_object_form.rb +267 -0
  23. data/lib/stage-ruby/models/field.rb +217 -0
  24. data/lib/stage-ruby/models/stage_error.rb +245 -0
  25. data/lib/stage-ruby/utils.rb +13 -0
  26. data/lib/stage-ruby/version.rb +14 -0
  27. data/lib/stage-ruby.rb +45 -0
  28. data/spec/api/stage_api_spec.rb +69 -0
  29. data/spec/api_client_spec.rb +225 -0
  30. data/spec/base_object_spec.rb +109 -0
  31. data/spec/configuration_spec.rb +41 -0
  32. data/spec/models/access_feature_form_spec.rb +46 -0
  33. data/spec/models/access_form_spec.rb +52 -0
  34. data/spec/models/client_user_form_spec.rb +40 -0
  35. data/spec/models/client_user_object_form_spec.rb +76 -0
  36. data/spec/models/field_spec.rb +46 -0
  37. data/spec/models/stage_error_spec.rb +64 -0
  38. data/spec/spec_helper.rb +110 -0
  39. data/stage-ruby.gemspec +38 -0
  40. metadata +152 -0
@@ -0,0 +1,205 @@
1
+ =begin
2
+ #Stage API Docs
3
+
4
+ #Stage Technologies complete API Documentation
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@heystage.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 3.0.33
10
+ =end
11
+
12
+ module Stage
13
+ class Configuration
14
+ # Defines url scheme
15
+ attr_accessor :scheme
16
+
17
+ # Defines url host
18
+ attr_accessor :host
19
+
20
+ # Defines url base path
21
+ attr_accessor :base_path
22
+
23
+ # Defines API keys used with API Key authentications.
24
+ #
25
+ # @return [Hash] key: parameter name, value: parameter value (API key)
26
+ #
27
+ # @example parameter name is "api_key", API key is "xxx" (e.g. "api_key=xxx" in query string)
28
+ # config.api_key['api_key'] = 'xxx'
29
+ attr_accessor :api_key
30
+
31
+ # Defines API key prefixes used with API Key authentications.
32
+ #
33
+ # @return [Hash] key: parameter name, value: API key prefix
34
+ #
35
+ # @example parameter name is "Authorization", API key prefix is "Token" (e.g. "Authorization: Token xxx" in headers)
36
+ # config.api_key_prefix['api_key'] = 'Token'
37
+ attr_accessor :api_key_prefix
38
+
39
+ # Defines the username used with HTTP basic authentication.
40
+ #
41
+ # @return [String]
42
+ attr_accessor :username
43
+
44
+ # Defines the password used with HTTP basic authentication.
45
+ #
46
+ # @return [String]
47
+ attr_accessor :password
48
+
49
+ # Defines the access token (Bearer) used with OAuth2.
50
+ attr_accessor :access_token
51
+
52
+ # Set this to enable/disable debugging. When enabled (set to true), HTTP request/response
53
+ # details will be logged with `logger.debug` (see the `logger` attribute).
54
+ # Default to false.
55
+ #
56
+ # @return [true, false]
57
+ attr_accessor :debugging
58
+
59
+ # Defines the logger used for debugging.
60
+ # Default to `Rails.logger` (when in Rails) or logging to STDOUT.
61
+ #
62
+ # @return [#debug]
63
+ attr_accessor :logger
64
+
65
+ # Defines the temporary folder to store downloaded files
66
+ # (for API endpoints that have file response).
67
+ # Default to use `Tempfile`.
68
+ #
69
+ # @return [String]
70
+ attr_accessor :temp_folder_path
71
+
72
+ # The time limit for HTTP request in seconds.
73
+ # Default to 0 (never times out).
74
+ attr_accessor :timeout
75
+
76
+ # Set this to false to skip client side validation in the operation.
77
+ # Default to true.
78
+ # @return [true, false]
79
+ attr_accessor :client_side_validation
80
+
81
+ ### TLS/SSL setting
82
+ # Set this to false to skip verifying SSL certificate when calling API from https server.
83
+ # Default to true.
84
+ #
85
+ # @note Do NOT set it to false in production code, otherwise you would face multiple types of cryptographic attacks.
86
+ #
87
+ # @return [true, false]
88
+ attr_accessor :verify_ssl
89
+
90
+ ### TLS/SSL setting
91
+ # Set this to false to skip verifying SSL host name
92
+ # Default to true.
93
+ #
94
+ # @note Do NOT set it to false in production code, otherwise you would face multiple types of cryptographic attacks.
95
+ #
96
+ # @return [true, false]
97
+ attr_accessor :verify_ssl_host
98
+
99
+ ### TLS/SSL setting
100
+ # Set this to customize the certificate file to verify the peer.
101
+ #
102
+ # @return [String] the path to the certificate file
103
+ #
104
+ # @see The `cainfo` option of Typhoeus, `--cert` option of libcurl. Related source code:
105
+ # https://github.com/typhoeus/typhoeus/blob/master/lib/typhoeus/easy_factory.rb#L145
106
+ attr_accessor :ssl_ca_cert
107
+
108
+ ### TLS/SSL setting
109
+ # Client certificate file (for client certificate)
110
+ attr_accessor :cert_file
111
+
112
+ ### TLS/SSL setting
113
+ # Client private key file (for client certificate)
114
+ attr_accessor :key_file
115
+
116
+ # Set this to customize parameters encoding of array parameter with multi collectionFormat.
117
+ # Default to nil.
118
+ #
119
+ # @see The params_encoding option of Ethon. Related source code:
120
+ # https://github.com/typhoeus/ethon/blob/master/lib/ethon/easy/queryable.rb#L96
121
+ attr_accessor :params_encoding
122
+
123
+ attr_accessor :inject_format
124
+
125
+ attr_accessor :force_ending_format
126
+
127
+ def initialize
128
+ @scheme = 'http'
129
+ @host = 'localhost:8080'
130
+ @base_path = ''
131
+ @api_key = {}
132
+ @api_key_prefix = {}
133
+ @timeout = 0
134
+ @client_side_validation = true
135
+ @verify_ssl = true
136
+ @verify_ssl_host = true
137
+ @params_encoding = nil
138
+ @cert_file = nil
139
+ @key_file = nil
140
+ @debugging = false
141
+ @inject_format = false
142
+ @force_ending_format = false
143
+ @logger = defined?(Rails) ? Rails.logger : Logger.new(STDOUT)
144
+
145
+ yield(self) if block_given?
146
+ end
147
+
148
+ # The default Configuration object.
149
+ def self.default
150
+ @@default ||= Configuration.new
151
+ end
152
+
153
+ def configure
154
+ yield(self) if block_given?
155
+ end
156
+
157
+ def scheme=(scheme)
158
+ # remove :// from scheme
159
+ @scheme = scheme.sub(/:\/\//, '')
160
+ end
161
+
162
+ def host=(host)
163
+ # remove http(s):// and anything after a slash
164
+ @host = host.sub(/https?:\/\//, '').split('/').first
165
+ end
166
+
167
+ def base_path=(base_path)
168
+ # Add leading and trailing slashes to base_path
169
+ @base_path = "/#{base_path}".gsub(/\/+/, '/')
170
+ @base_path = '' if @base_path == '/'
171
+ end
172
+
173
+ def base_url
174
+ "#{scheme}://#{[host, base_path].join('/').gsub(/\/+/, '/')}".sub(/\/+\z/, '')
175
+ end
176
+
177
+ # Gets API key (with prefix if set).
178
+ # @param [String] param_name the parameter name of API key auth
179
+ def api_key_with_prefix(param_name)
180
+ if @api_key_prefix[param_name]
181
+ "#{@api_key_prefix[param_name]} #{@api_key[param_name]}"
182
+ else
183
+ @api_key[param_name]
184
+ end
185
+ end
186
+
187
+ # Gets Basic Auth token string
188
+ def basic_auth_token
189
+ 'Basic ' + ["#{username}:#{password}"].pack('m').delete("\r\n")
190
+ end
191
+
192
+ # Returns Auth Settings hash for api client.
193
+ def auth_settings
194
+ {
195
+ 'stage-api-token' =>
196
+ {
197
+ type: 'api_key',
198
+ in: 'header',
199
+ key: 'Authorization',
200
+ value: api_key_with_prefix('Authorization')
201
+ },
202
+ }
203
+ end
204
+ end
205
+ end
@@ -0,0 +1,227 @@
1
+ =begin
2
+ #Stage API Docs
3
+
4
+ #Stage Technologies complete API Documentation
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@heystage.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 3.0.33
10
+ =end
11
+
12
+ require 'date'
13
+
14
+ module Stage
15
+ class AccessFeatureForm
16
+ # A boolean value indicating whether the identified user has access to the feature or not.
17
+ attr_accessor :has_access
18
+
19
+ # The feature identifier.
20
+ attr_accessor :identifier
21
+
22
+ # Attribute mapping from ruby-style variable name to JSON key.
23
+ def self.attribute_map
24
+ {
25
+ :'has_access' => :'hasAccess',
26
+ :'identifier' => :'identifier'
27
+ }
28
+ end
29
+
30
+ # Attribute type mapping.
31
+ def self.openapi_types
32
+ {
33
+ :'has_access' => :'Object',
34
+ :'identifier' => :'Object'
35
+ }
36
+ end
37
+
38
+ # List of attributes with nullable: true
39
+ def self.openapi_nullable
40
+ Set.new([
41
+ ])
42
+ end
43
+
44
+ # Initializes the object
45
+ # @param [Hash] attributes Model attributes in the form of hash
46
+ def initialize(attributes = {})
47
+ if (!attributes.is_a?(Hash))
48
+ fail ArgumentError, "The input argument (attributes) must be a hash in `Stage::AccessFeatureForm` initialize method"
49
+ end
50
+
51
+ # check to see if the attribute exists and convert string to symbol for hash key
52
+ attributes = attributes.each_with_object({}) { |(k, v), h|
53
+ if (!self.class.attribute_map.key?(k.to_sym))
54
+ fail ArgumentError, "`#{k}` is not a valid attribute in `Stage::AccessFeatureForm`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
55
+ end
56
+ h[k.to_sym] = v
57
+ }
58
+
59
+ if attributes.key?(:'has_access')
60
+ self.has_access = attributes[:'has_access']
61
+ end
62
+
63
+ if attributes.key?(:'identifier')
64
+ self.identifier = attributes[:'identifier']
65
+ end
66
+ end
67
+
68
+ # Show invalid properties with the reasons. Usually used together with valid?
69
+ # @return Array for valid properties with the reasons
70
+ def list_invalid_properties
71
+ invalid_properties = Array.new
72
+ if @has_access.nil?
73
+ invalid_properties.push('invalid value for "has_access", has_access cannot be nil.')
74
+ end
75
+
76
+ if @identifier.nil?
77
+ invalid_properties.push('invalid value for "identifier", identifier cannot be nil.')
78
+ end
79
+
80
+ invalid_properties
81
+ end
82
+
83
+ # Check to see if the all the properties in the model are valid
84
+ # @return true if the model is valid
85
+ def valid?
86
+ return false if @has_access.nil?
87
+ return false if @identifier.nil?
88
+ true
89
+ end
90
+
91
+ # Checks equality by comparing each attribute.
92
+ # @param [Object] Object to be compared
93
+ def ==(o)
94
+ return true if self.equal?(o)
95
+ self.class == o.class &&
96
+ has_access == o.has_access &&
97
+ identifier == o.identifier
98
+ end
99
+
100
+ # @see the `==` method
101
+ # @param [Object] Object to be compared
102
+ def eql?(o)
103
+ self == o
104
+ end
105
+
106
+ # Calculates hash code according to all attributes.
107
+ # @return [Integer] Hash code
108
+ def hash
109
+ [has_access, identifier].hash
110
+ end
111
+
112
+ # Builds the object from hash
113
+ # @param [Hash] attributes Model attributes in the form of hash
114
+ # @return [Object] Returns the model itself
115
+ def self.build_from_hash(attributes)
116
+ new.build_from_hash(attributes)
117
+ end
118
+
119
+ # Builds the object from hash
120
+ # @param [Hash] attributes Model attributes in the form of hash
121
+ # @return [Object] Returns the model itself
122
+ def build_from_hash(attributes)
123
+ return nil unless attributes.is_a?(Hash)
124
+ self.class.openapi_types.each_pair do |key, type|
125
+ if type =~ /\AArray<(.*)>/i
126
+ # check to ensure the input is an array given that the attribute
127
+ # is documented as an array but the input is not
128
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
129
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
130
+ end
131
+ elsif !attributes[self.class.attribute_map[key]].nil?
132
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
133
+ elsif attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
134
+ self.send("#{key}=", nil)
135
+ end
136
+ end
137
+
138
+ self
139
+ end
140
+
141
+ # Deserializes the data based on type
142
+ # @param string type Data type
143
+ # @param string value Value to be deserialized
144
+ # @return [Object] Deserialized data
145
+ def _deserialize(type, value)
146
+ case type.to_sym
147
+ when :DateTime
148
+ DateTime.parse(value)
149
+ when :Date
150
+ Date.parse(value)
151
+ when :String
152
+ value.to_s
153
+ when :Integer
154
+ value.to_i
155
+ when :Float
156
+ value.to_f
157
+ when :Boolean
158
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
159
+ true
160
+ else
161
+ false
162
+ end
163
+ when :Object
164
+ # generic object (usually a Hash), return directly
165
+ value
166
+ when /\AArray<(?<inner_type>.+)>\z/
167
+ inner_type = Regexp.last_match[:inner_type]
168
+ value.map { |v| _deserialize(inner_type, v) }
169
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
170
+ k_type = Regexp.last_match[:k_type]
171
+ v_type = Regexp.last_match[:v_type]
172
+ {}.tap do |hash|
173
+ value.each do |k, v|
174
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
175
+ end
176
+ end
177
+ else # model
178
+ Stage.const_get(type).build_from_hash(value)
179
+ end
180
+ end
181
+
182
+ # Returns the string representation of the object
183
+ # @return [String] String presentation of the object
184
+ def to_s
185
+ to_hash.to_s
186
+ end
187
+
188
+ # to_body is an alias to to_hash (backward compatibility)
189
+ # @return [Hash] Returns the object in the form of hash
190
+ def to_body
191
+ to_hash
192
+ end
193
+
194
+ # Returns the object in the form of hash
195
+ # @return [Hash] Returns the object in the form of hash
196
+ def to_hash
197
+ hash = {}
198
+ self.class.attribute_map.each_pair do |attr, param|
199
+ value = self.send(attr)
200
+ if value.nil?
201
+ is_nullable = self.class.openapi_nullable.include?(attr)
202
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
203
+ end
204
+
205
+ hash[param] = _to_hash(value)
206
+ end
207
+ hash
208
+ end
209
+
210
+ # Outputs non-array value in the form of hash
211
+ # For object, use to_hash. Otherwise, just return the value
212
+ # @param [Object] value Any valid value
213
+ # @return [Hash] Returns the value in the form of hash
214
+ def _to_hash(value)
215
+ if value.is_a?(Array)
216
+ value.compact.map { |v| _to_hash(v) }
217
+ elsif value.is_a?(Hash)
218
+ {}.tap do |hash|
219
+ value.each { |k, v| hash[k] = _to_hash(v) }
220
+ end
221
+ elsif value.respond_to? :to_hash
222
+ value.to_hash
223
+ else
224
+ value
225
+ end
226
+ end end
227
+ end
@@ -0,0 +1,246 @@
1
+ =begin
2
+ #Stage API Docs
3
+
4
+ #Stage Technologies complete API Documentation
5
+
6
+ OpenAPI spec version: 1.0.0
7
+ Contact: support@heystage.com
8
+ Generated by: https://github.com/swagger-api/swagger-codegen.git
9
+ Swagger Codegen version: 3.0.33
10
+ =end
11
+
12
+ require 'date'
13
+
14
+ module Stage
15
+ class AccessForm
16
+ # The list of any errors.
17
+ attr_accessor :errors
18
+
19
+ # The list of features.
20
+ attr_accessor :features
21
+
22
+ # The user identifier.
23
+ attr_accessor :user_identifier
24
+
25
+ # Attribute mapping from ruby-style variable name to JSON key.
26
+ def self.attribute_map
27
+ {
28
+ :'errors' => :'errors',
29
+ :'features' => :'features',
30
+ :'user_identifier' => :'userIdentifier'
31
+ }
32
+ end
33
+
34
+ # Attribute type mapping.
35
+ def self.openapi_types
36
+ {
37
+ :'errors' => :'Object',
38
+ :'features' => :'Object',
39
+ :'user_identifier' => :'Object'
40
+ }
41
+ end
42
+
43
+ # List of attributes with nullable: true
44
+ def self.openapi_nullable
45
+ Set.new([
46
+ ])
47
+ end
48
+
49
+ # Initializes the object
50
+ # @param [Hash] attributes Model attributes in the form of hash
51
+ def initialize(attributes = {})
52
+ if (!attributes.is_a?(Hash))
53
+ fail ArgumentError, "The input argument (attributes) must be a hash in `Stage::AccessForm` initialize method"
54
+ end
55
+
56
+ # check to see if the attribute exists and convert string to symbol for hash key
57
+ attributes = attributes.each_with_object({}) { |(k, v), h|
58
+ if (!self.class.attribute_map.key?(k.to_sym))
59
+ fail ArgumentError, "`#{k}` is not a valid attribute in `Stage::AccessForm`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
60
+ end
61
+ h[k.to_sym] = v
62
+ }
63
+
64
+ if attributes.key?(:'errors')
65
+ if (value = attributes[:'errors']).is_a?(Array)
66
+ self.errors = value
67
+ end
68
+ end
69
+
70
+ if attributes.key?(:'features')
71
+ if (value = attributes[:'features']).is_a?(Array)
72
+ self.features = value
73
+ end
74
+ end
75
+
76
+ if attributes.key?(:'user_identifier')
77
+ self.user_identifier = attributes[:'user_identifier']
78
+ end
79
+ end
80
+
81
+ # Show invalid properties with the reasons. Usually used together with valid?
82
+ # @return Array for valid properties with the reasons
83
+ def list_invalid_properties
84
+ invalid_properties = Array.new
85
+ if @errors.nil?
86
+ invalid_properties.push('invalid value for "errors", errors cannot be nil.')
87
+ end
88
+
89
+ if @features.nil?
90
+ invalid_properties.push('invalid value for "features", features cannot be nil.')
91
+ end
92
+
93
+ if @user_identifier.nil?
94
+ invalid_properties.push('invalid value for "user_identifier", user_identifier cannot be nil.')
95
+ end
96
+
97
+ invalid_properties
98
+ end
99
+
100
+ # Check to see if the all the properties in the model are valid
101
+ # @return true if the model is valid
102
+ def valid?
103
+ return false if @errors.nil?
104
+ return false if @features.nil?
105
+ return false if @user_identifier.nil?
106
+ true
107
+ end
108
+
109
+ # Checks equality by comparing each attribute.
110
+ # @param [Object] Object to be compared
111
+ def ==(o)
112
+ return true if self.equal?(o)
113
+ self.class == o.class &&
114
+ errors == o.errors &&
115
+ features == o.features &&
116
+ user_identifier == o.user_identifier
117
+ end
118
+
119
+ # @see the `==` method
120
+ # @param [Object] Object to be compared
121
+ def eql?(o)
122
+ self == o
123
+ end
124
+
125
+ # Calculates hash code according to all attributes.
126
+ # @return [Integer] Hash code
127
+ def hash
128
+ [errors, features, user_identifier].hash
129
+ end
130
+
131
+ # Builds the object from hash
132
+ # @param [Hash] attributes Model attributes in the form of hash
133
+ # @return [Object] Returns the model itself
134
+ def self.build_from_hash(attributes)
135
+ new.build_from_hash(attributes)
136
+ end
137
+
138
+ # Builds the object from hash
139
+ # @param [Hash] attributes Model attributes in the form of hash
140
+ # @return [Object] Returns the model itself
141
+ def build_from_hash(attributes)
142
+ return nil unless attributes.is_a?(Hash)
143
+ self.class.openapi_types.each_pair do |key, type|
144
+ if type =~ /\AArray<(.*)>/i
145
+ # check to ensure the input is an array given that the attribute
146
+ # is documented as an array but the input is not
147
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
148
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
149
+ end
150
+ elsif !attributes[self.class.attribute_map[key]].nil?
151
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
152
+ elsif attributes[self.class.attribute_map[key]].nil? && self.class.openapi_nullable.include?(key)
153
+ self.send("#{key}=", nil)
154
+ end
155
+ end
156
+
157
+ self
158
+ end
159
+
160
+ # Deserializes the data based on type
161
+ # @param string type Data type
162
+ # @param string value Value to be deserialized
163
+ # @return [Object] Deserialized data
164
+ def _deserialize(type, value)
165
+ case type.to_sym
166
+ when :DateTime
167
+ DateTime.parse(value)
168
+ when :Date
169
+ Date.parse(value)
170
+ when :String
171
+ value.to_s
172
+ when :Integer
173
+ value.to_i
174
+ when :Float
175
+ value.to_f
176
+ when :Boolean
177
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
178
+ true
179
+ else
180
+ false
181
+ end
182
+ when :Object
183
+ # generic object (usually a Hash), return directly
184
+ value
185
+ when /\AArray<(?<inner_type>.+)>\z/
186
+ inner_type = Regexp.last_match[:inner_type]
187
+ value.map { |v| _deserialize(inner_type, v) }
188
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
189
+ k_type = Regexp.last_match[:k_type]
190
+ v_type = Regexp.last_match[:v_type]
191
+ {}.tap do |hash|
192
+ value.each do |k, v|
193
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
194
+ end
195
+ end
196
+ else # model
197
+ Stage.const_get(type).build_from_hash(value)
198
+ end
199
+ end
200
+
201
+ # Returns the string representation of the object
202
+ # @return [String] String presentation of the object
203
+ def to_s
204
+ to_hash.to_s
205
+ end
206
+
207
+ # to_body is an alias to to_hash (backward compatibility)
208
+ # @return [Hash] Returns the object in the form of hash
209
+ def to_body
210
+ to_hash
211
+ end
212
+
213
+ # Returns the object in the form of hash
214
+ # @return [Hash] Returns the object in the form of hash
215
+ def to_hash
216
+ hash = {}
217
+ self.class.attribute_map.each_pair do |attr, param|
218
+ value = self.send(attr)
219
+ if value.nil?
220
+ is_nullable = self.class.openapi_nullable.include?(attr)
221
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
222
+ end
223
+
224
+ hash[param] = _to_hash(value)
225
+ end
226
+ hash
227
+ end
228
+
229
+ # Outputs non-array value in the form of hash
230
+ # For object, use to_hash. Otherwise, just return the value
231
+ # @param [Object] value Any valid value
232
+ # @return [Hash] Returns the value in the form of hash
233
+ def _to_hash(value)
234
+ if value.is_a?(Array)
235
+ value.compact.map { |v| _to_hash(v) }
236
+ elsif value.is_a?(Hash)
237
+ {}.tap do |hash|
238
+ value.each { |k, v| hash[k] = _to_hash(v) }
239
+ end
240
+ elsif value.respond_to? :to_hash
241
+ value.to_hash
242
+ else
243
+ value
244
+ end
245
+ end end
246
+ end