aspose_slides_cloud 21.3.0 → 21.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (178) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +61 -61
  3. data/TestData/TemplatingCVDataWithBase64.xml +22 -22
  4. data/TestData/watermark.png +0 -0
  5. data/lib/aspose_slides_cloud.rb +213 -215
  6. data/lib/aspose_slides_cloud/api/slides_api.rb +17689 -17009
  7. data/lib/aspose_slides_cloud/api/slides_api_requests.rb +4742 -4624
  8. data/lib/aspose_slides_cloud/api_client.rb +439 -434
  9. data/lib/aspose_slides_cloud/models/add_layout_slide.rb +244 -244
  10. data/lib/aspose_slides_cloud/models/add_master_slide.rb +259 -259
  11. data/lib/aspose_slides_cloud/models/add_shape.rb +239 -239
  12. data/lib/aspose_slides_cloud/models/add_slide.rb +269 -269
  13. data/lib/aspose_slides_cloud/models/api_info.rb +217 -217
  14. data/lib/aspose_slides_cloud/models/arrow_head_properties.rb +285 -285
  15. data/lib/aspose_slides_cloud/models/audio_frame.rb +359 -359
  16. data/lib/aspose_slides_cloud/models/axes.rb +237 -237
  17. data/lib/aspose_slides_cloud/models/axis.rb +699 -699
  18. data/lib/aspose_slides_cloud/models/base64_input_file.rb +230 -230
  19. data/lib/aspose_slides_cloud/models/blur_effect.rb +227 -227
  20. data/lib/aspose_slides_cloud/models/box_and_whisker_series.rb +299 -299
  21. data/lib/aspose_slides_cloud/models/bubble_chart_data_point.rb +212 -212
  22. data/lib/aspose_slides_cloud/models/bubble_series.rb +248 -248
  23. data/lib/aspose_slides_cloud/models/chart.rb +365 -365
  24. data/lib/aspose_slides_cloud/models/chart_category.rb +271 -271
  25. data/lib/aspose_slides_cloud/models/chart_title.rb +222 -222
  26. data/lib/aspose_slides_cloud/models/chart_wall.rb +281 -281
  27. data/lib/aspose_slides_cloud/models/color_scheme.rb +317 -317
  28. data/lib/aspose_slides_cloud/models/common_slide_view_properties.rb +217 -217
  29. data/lib/aspose_slides_cloud/models/connector.rb +275 -275
  30. data/lib/aspose_slides_cloud/models/custom_dash_pattern.rb +209 -209
  31. data/lib/aspose_slides_cloud/models/data_point.rb +197 -197
  32. data/lib/aspose_slides_cloud/models/disc_usage.rb +227 -227
  33. data/lib/aspose_slides_cloud/models/document.rb +257 -257
  34. data/lib/aspose_slides_cloud/models/document_properties.rb +209 -209
  35. data/lib/aspose_slides_cloud/models/document_property.rb +232 -232
  36. data/lib/aspose_slides_cloud/models/document_replace_result.rb +218 -218
  37. data/lib/aspose_slides_cloud/models/effect.rb +424 -424
  38. data/lib/aspose_slides_cloud/models/effect_format.rb +277 -277
  39. data/lib/aspose_slides_cloud/models/entity_exists.rb +212 -212
  40. data/lib/aspose_slides_cloud/models/error.rb +237 -237
  41. data/lib/aspose_slides_cloud/models/error_details.rb +222 -222
  42. data/lib/aspose_slides_cloud/models/export_format.rb +60 -60
  43. data/lib/aspose_slides_cloud/models/export_options.rb +216 -216
  44. data/lib/aspose_slides_cloud/models/file_version.rb +225 -225
  45. data/lib/aspose_slides_cloud/models/file_versions.rb +209 -209
  46. data/lib/aspose_slides_cloud/models/files_list.rb +209 -209
  47. data/lib/aspose_slides_cloud/models/files_upload_result.rb +221 -221
  48. data/lib/aspose_slides_cloud/models/fill_format.rb +240 -240
  49. data/lib/aspose_slides_cloud/models/fill_overlay_effect.rb +246 -246
  50. data/lib/aspose_slides_cloud/models/font_scheme.rb +227 -227
  51. data/lib/aspose_slides_cloud/models/font_set.rb +227 -227
  52. data/lib/aspose_slides_cloud/models/format_scheme.rb +245 -245
  53. data/lib/aspose_slides_cloud/models/geometry_shape.rb +260 -260
  54. data/lib/aspose_slides_cloud/models/glow_effect.rb +222 -222
  55. data/lib/aspose_slides_cloud/models/gradient_fill.rb +342 -342
  56. data/lib/aspose_slides_cloud/models/gradient_fill_stop.rb +222 -222
  57. data/lib/aspose_slides_cloud/models/graphical_object.rb +234 -234
  58. data/lib/aspose_slides_cloud/models/group_shape.rb +234 -234
  59. data/lib/aspose_slides_cloud/models/header_footer.rb +247 -247
  60. data/lib/aspose_slides_cloud/models/html_export_options.rb +421 -421
  61. data/lib/aspose_slides_cloud/models/i_shape_export_options.rb +197 -197
  62. data/lib/aspose_slides_cloud/models/image.rb +237 -237
  63. data/lib/aspose_slides_cloud/models/image_export_format.rb +43 -43
  64. data/lib/aspose_slides_cloud/models/image_export_options.rb +299 -299
  65. data/lib/aspose_slides_cloud/models/images.rb +209 -209
  66. data/lib/aspose_slides_cloud/models/inner_shadow_effect.rb +252 -252
  67. data/lib/aspose_slides_cloud/models/input.rb +227 -227
  68. data/lib/aspose_slides_cloud/models/input_file.rb +250 -250
  69. data/lib/aspose_slides_cloud/models/interactive_sequence.rb +224 -224
  70. data/lib/aspose_slides_cloud/models/layout_slide.rb +278 -278
  71. data/lib/aspose_slides_cloud/models/layout_slides.rb +209 -209
  72. data/lib/aspose_slides_cloud/models/legend.rb +321 -321
  73. data/lib/aspose_slides_cloud/models/line_format.rb +411 -411
  74. data/lib/aspose_slides_cloud/models/master_slide.rb +231 -231
  75. data/lib/aspose_slides_cloud/models/master_slides.rb +209 -209
  76. data/lib/aspose_slides_cloud/models/merge.rb +231 -231
  77. data/lib/aspose_slides_cloud/models/merging_source.rb +219 -219
  78. data/lib/aspose_slides_cloud/models/no_fill.rb +219 -219
  79. data/lib/aspose_slides_cloud/models/normal_view_restored_properties.rb +217 -217
  80. data/lib/aspose_slides_cloud/models/notes_slide.rb +217 -217
  81. data/lib/aspose_slides_cloud/models/notes_slide_export_format.rb +43 -43
  82. data/lib/aspose_slides_cloud/models/notes_slide_header_footer.rb +267 -267
  83. data/lib/aspose_slides_cloud/models/object_exist.rb +227 -227
  84. data/lib/aspose_slides_cloud/models/ole_object_frame.rb +259 -259
  85. data/lib/aspose_slides_cloud/models/one_value_chart_data_point.rb +210 -210
  86. data/lib/aspose_slides_cloud/models/one_value_series.rb +248 -248
  87. data/lib/aspose_slides_cloud/models/ordered_merge_request.rb +209 -209
  88. data/lib/aspose_slides_cloud/models/outer_shadow_effect.rb +252 -252
  89. data/lib/aspose_slides_cloud/models/output_file.rb +240 -240
  90. data/lib/aspose_slides_cloud/models/paragraph.rb +517 -517
  91. data/lib/aspose_slides_cloud/models/paragraphs.rb +209 -209
  92. data/lib/aspose_slides_cloud/models/path_input_file.rb +240 -240
  93. data/lib/aspose_slides_cloud/models/path_output_file.rb +239 -239
  94. data/lib/aspose_slides_cloud/models/pattern_fill.rb +266 -266
  95. data/lib/aspose_slides_cloud/models/pdf_export_options.rb +547 -547
  96. data/lib/aspose_slides_cloud/models/picture_fill.rb +351 -351
  97. data/lib/aspose_slides_cloud/models/picture_frame.rb +245 -245
  98. data/lib/aspose_slides_cloud/models/pipeline.rb +219 -219
  99. data/lib/aspose_slides_cloud/models/placeholder.rb +325 -325
  100. data/lib/aspose_slides_cloud/models/placeholders.rb +209 -209
  101. data/lib/aspose_slides_cloud/models/plot_area.rb +311 -311
  102. data/lib/aspose_slides_cloud/models/portion.rb +589 -589
  103. data/lib/aspose_slides_cloud/models/portions.rb +209 -209
  104. data/lib/aspose_slides_cloud/models/pptx_export_options.rb +247 -247
  105. data/lib/aspose_slides_cloud/models/presentation_to_merge.rb +273 -273
  106. data/lib/aspose_slides_cloud/models/presentations_merge_request.rb +221 -221
  107. data/lib/aspose_slides_cloud/models/preset_shadow_effect.rb +286 -286
  108. data/lib/aspose_slides_cloud/models/protection_properties.rb +267 -217
  109. data/lib/aspose_slides_cloud/models/reflection_effect.rb +441 -441
  110. data/lib/aspose_slides_cloud/models/remove_shape.rb +229 -229
  111. data/lib/aspose_slides_cloud/models/remove_slide.rb +234 -234
  112. data/lib/aspose_slides_cloud/models/reorder_slide.rb +249 -249
  113. data/lib/aspose_slides_cloud/models/replace_text.rb +269 -269
  114. data/lib/aspose_slides_cloud/models/request_input_file.rb +235 -235
  115. data/lib/aspose_slides_cloud/models/reset_slide.rb +234 -234
  116. data/lib/aspose_slides_cloud/models/resource_base.rb +219 -219
  117. data/lib/aspose_slides_cloud/models/resource_uri.rb +237 -237
  118. data/lib/aspose_slides_cloud/models/response_output_file.rb +219 -219
  119. data/lib/aspose_slides_cloud/models/save.rb +266 -266
  120. data/lib/aspose_slides_cloud/models/save_shape.rb +276 -276
  121. data/lib/aspose_slides_cloud/models/save_slide.rb +301 -301
  122. data/lib/aspose_slides_cloud/models/scatter_chart_data_point.rb +225 -225
  123. data/lib/aspose_slides_cloud/models/scatter_series.rb +248 -248
  124. data/lib/aspose_slides_cloud/models/section.rb +234 -234
  125. data/lib/aspose_slides_cloud/models/sections.rb +209 -209
  126. data/lib/aspose_slides_cloud/models/series.rb +422 -422
  127. data/lib/aspose_slides_cloud/models/series_marker.rb +281 -281
  128. data/lib/aspose_slides_cloud/models/shape.rb +255 -255
  129. data/lib/aspose_slides_cloud/models/shape_base.rb +375 -375
  130. data/lib/aspose_slides_cloud/models/shape_export_format.rb +44 -44
  131. data/lib/aspose_slides_cloud/models/shape_image_export_options.rb +286 -286
  132. data/lib/aspose_slides_cloud/models/shape_thumbnail_bounds.rb +41 -41
  133. data/lib/aspose_slides_cloud/models/shapes.rb +209 -209
  134. data/lib/aspose_slides_cloud/models/{scale_type.rb → shapes_alignment_type.rb} +46 -41
  135. data/lib/aspose_slides_cloud/models/slide.rb +322 -322
  136. data/lib/aspose_slides_cloud/models/slide_animation.rb +221 -221
  137. data/lib/aspose_slides_cloud/models/slide_background.rb +266 -266
  138. data/lib/aspose_slides_cloud/models/slide_comment.rb +239 -239
  139. data/lib/aspose_slides_cloud/models/slide_comments.rb +209 -209
  140. data/lib/aspose_slides_cloud/models/slide_export_format.rb +59 -59
  141. data/lib/aspose_slides_cloud/models/slide_properties.rb +315 -315
  142. data/lib/aspose_slides_cloud/models/slide_replace_result.rb +223 -223
  143. data/lib/aspose_slides_cloud/models/slides.rb +209 -209
  144. data/lib/aspose_slides_cloud/models/smart_art.rb +342 -342
  145. data/lib/aspose_slides_cloud/models/smart_art_node.rb +293 -293
  146. data/lib/aspose_slides_cloud/models/smart_art_shape.rb +235 -235
  147. data/lib/aspose_slides_cloud/models/soft_edge_effect.rb +212 -212
  148. data/lib/aspose_slides_cloud/models/solid_fill.rb +229 -229
  149. data/lib/aspose_slides_cloud/models/split_document_result.rb +209 -209
  150. data/lib/aspose_slides_cloud/models/storage_exist.rb +212 -212
  151. data/lib/aspose_slides_cloud/models/storage_file.rb +257 -257
  152. data/lib/aspose_slides_cloud/models/svg_export_options.rb +379 -379
  153. data/lib/aspose_slides_cloud/models/swf_export_options.rb +529 -529
  154. data/lib/aspose_slides_cloud/models/table.rb +350 -350
  155. data/lib/aspose_slides_cloud/models/table_cell.rb +403 -403
  156. data/lib/aspose_slides_cloud/models/table_column.rb +212 -212
  157. data/lib/aspose_slides_cloud/models/table_row.rb +239 -239
  158. data/lib/aspose_slides_cloud/models/task.rb +240 -240
  159. data/lib/aspose_slides_cloud/models/text_item.rb +217 -217
  160. data/lib/aspose_slides_cloud/models/text_items.rb +209 -209
  161. data/lib/aspose_slides_cloud/models/theme.rb +237 -237
  162. data/lib/aspose_slides_cloud/models/tiff_export_options.rb +423 -423
  163. data/lib/aspose_slides_cloud/models/update_background.rb +241 -241
  164. data/lib/aspose_slides_cloud/models/update_shape.rb +239 -239
  165. data/lib/aspose_slides_cloud/models/video_frame.rb +329 -329
  166. data/lib/aspose_slides_cloud/models/view_properties.rb +357 -357
  167. data/lib/aspose_slides_cloud/models/waterfall_chart_data_point.rb +206 -206
  168. data/lib/aspose_slides_cloud/models/waterfall_series.rb +247 -247
  169. data/lib/aspose_slides_cloud/models/xps_export_options.rb +243 -243
  170. data/lib/aspose_slides_cloud/type_registry.rb +323 -325
  171. data/lib/aspose_slides_cloud/version.rb +25 -25
  172. data/spec/api/slides_api_spec.rb +39435 -38557
  173. data/spec/extra/extra_spec.rb +202 -202
  174. data/spec/spec_utils.rb +182 -180
  175. data/testConfig.json +7 -7
  176. data/testRules.json +511 -495
  177. metadata +4 -4
  178. data/lib/aspose_slides_cloud/models/size_type.rb +0 -55
@@ -1,221 +1,221 @@
1
- =begin
2
- Copyright (c) 2019 Aspose Pty Ltd
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy
5
- of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction, including without limitation the rights
7
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
- copies of the Software, and to permit persons to whom the Software is
9
- furnished to do so, subject to the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be included in all
12
- copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
- SOFTWARE.
21
- =end
22
-
23
- require 'date'
24
-
25
- module AsposeSlidesCloud
26
- # Request for presentations merge
27
- class PresentationsMergeRequest
28
- # Gets or sets the presentation paths.
29
- attr_accessor :presentation_paths
30
-
31
- # Gets or sets the presentation passwords.
32
- attr_accessor :presentation_passwords
33
-
34
- # Attribute mapping from ruby-style variable name to JSON key.
35
- def self.attribute_map
36
- {
37
- :'presentation_paths' => :'PresentationPaths',
38
- :'presentation_passwords' => :'PresentationPasswords',
39
- }
40
- end
41
-
42
- # Attribute type mapping.
43
- def self.swagger_types
44
- {
45
- :'presentation_paths' => :'Array<String>',
46
- :'presentation_passwords' => :'Array<String>',
47
- }
48
- end
49
-
50
- # Initializes the object
51
- # @param [Hash] attributes Model attributes in the form of hash
52
- def initialize(attributes = {})
53
- return unless attributes.is_a?(Hash)
54
-
55
- # convert string to symbol for hash key
56
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
57
-
58
- if attributes.has_key?(:'PresentationPaths')
59
- if (value = attributes[:'PresentationPaths']).is_a?(Array)
60
- self.presentation_paths = value
61
- end
62
- end
63
-
64
- if attributes.has_key?(:'PresentationPasswords')
65
- if (value = attributes[:'PresentationPasswords']).is_a?(Array)
66
- self.presentation_passwords = value
67
- end
68
- end
69
- end
70
-
71
- # Show invalid properties with the reasons. Usually used together with valid?
72
- # @return Array for valid properties with the reasons
73
- def list_invalid_properties
74
- invalid_properties = Array.new
75
- invalid_properties
76
- end
77
-
78
- # Check to see if the all the properties in the model are valid
79
- # @return true if the model is valid
80
- def valid?
81
- true
82
- end
83
-
84
- # Checks equality by comparing each attribute.
85
- # @param [Object] Object to be compared
86
- def ==(o)
87
- return true if self.equal?(o)
88
- self.class == o.class &&
89
- presentation_paths == o.presentation_paths &&
90
- presentation_passwords == o.presentation_passwords
91
- end
92
-
93
- # @see the `==` method
94
- # @param [Object] Object to be compared
95
- def eql?(o)
96
- self == o
97
- end
98
-
99
- # Calculates hash code according to all attributes.
100
- # @return [Fixnum] Hash code
101
- def hash
102
- [presentation_paths, presentation_passwords].hash
103
- end
104
-
105
- # Builds the object from hash
106
- # @param [Hash] attributes Model attributes in the form of hash
107
- # @return [Object] Returns the model itself
108
- def build_from_hash(attributes)
109
- return nil unless attributes.is_a?(Hash)
110
- self.class.swagger_types.each_pair do |key, type|
111
- mapKey = self.class.attribute_map[key]
112
- if !mapKey.nil?
113
- val = attributes[mapKey]
114
- if val.nil?
115
- mapKeyString = mapKey.to_s
116
- mapKeyString[0] = mapKeyString[0].downcase
117
- mapKey = mapKeyString.to_sym
118
- val = attributes[mapKey]
119
- end
120
- if !val.nil?
121
- if type =~ /\AArray<(.*)>/i
122
- # check to ensure the input is an array given that the the attribute
123
- # is documented as an array but the input is not
124
- if val.is_a?(Array)
125
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
126
- end
127
- else
128
- self.send("#{key}=", _deserialize(type, val))
129
- end
130
- end
131
- end
132
- end
133
-
134
- self
135
- end
136
-
137
- # Deserializes the data based on type
138
- # @param string type Data type
139
- # @param string value Value to be deserialized
140
- # @return [Object] Deserialized data
141
- def _deserialize(type, value)
142
- case type.to_sym
143
- when :DateTime
144
- DateTime.parse(value)
145
- when :Date
146
- Date.parse(value)
147
- when :String
148
- value.to_s
149
- when :Integer
150
- value.to_i
151
- when :Float
152
- value.to_f
153
- when :BOOLEAN
154
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
155
- true
156
- else
157
- false
158
- end
159
- when :Object
160
- # generic object (usually a Hash), return directly
161
- value
162
- when /\AArray<(?<inner_type>.+)>\z/
163
- inner_type = Regexp.last_match[:inner_type]
164
- value.map { |v| _deserialize(inner_type, v) }
165
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
166
- k_type = Regexp.last_match[:k_type]
167
- v_type = Regexp.last_match[:v_type]
168
- {}.tap do |hash|
169
- value.each do |k, v|
170
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
171
- end
172
- end
173
- else # model
174
- temp_model = AsposeSlidesCloud.const_get(type).new
175
- temp_model.build_from_hash(value)
176
- end
177
- end
178
-
179
- # Returns the string representation of the object
180
- # @return [String] String presentation of the object
181
- def to_s
182
- to_hash.to_s
183
- end
184
-
185
- # to_body is an alias to to_hash (backward compatibility)
186
- # @return [Hash] Returns the object in the form of hash
187
- def to_body
188
- to_hash
189
- end
190
-
191
- # Returns the object in the form of hash
192
- # @return [Hash] Returns the object in the form of hash
193
- def to_hash
194
- hash = {}
195
- self.class.attribute_map.each_pair do |attr, param|
196
- value = self.send(attr)
197
- next if value.nil?
198
- hash[param] = _to_hash(value)
199
- end
200
- hash
201
- end
202
-
203
- # Outputs non-array value in the form of hash
204
- # For object, use to_hash. Otherwise, just return the value
205
- # @param [Object] value Any valid value
206
- # @return [Hash] Returns the value in the form of hash
207
- def _to_hash(value)
208
- if value.is_a?(Array)
209
- value.compact.map { |v| _to_hash(v) }
210
- elsif value.is_a?(Hash)
211
- {}.tap do |hash|
212
- value.each { |k, v| hash[k] = _to_hash(v) }
213
- end
214
- elsif value.respond_to? :to_hash
215
- value.to_hash
216
- else
217
- value
218
- end
219
- end
220
- end
221
- end
1
+ =begin
2
+ Copyright (c) 2019 Aspose Pty Ltd
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in all
12
+ copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
+ SOFTWARE.
21
+ =end
22
+
23
+ require 'date'
24
+
25
+ module AsposeSlidesCloud
26
+ # Request for presentations merge
27
+ class PresentationsMergeRequest
28
+ # Gets or sets the presentation paths.
29
+ attr_accessor :presentation_paths
30
+
31
+ # Gets or sets the presentation passwords.
32
+ attr_accessor :presentation_passwords
33
+
34
+ # Attribute mapping from ruby-style variable name to JSON key.
35
+ def self.attribute_map
36
+ {
37
+ :'presentation_paths' => :'PresentationPaths',
38
+ :'presentation_passwords' => :'PresentationPasswords',
39
+ }
40
+ end
41
+
42
+ # Attribute type mapping.
43
+ def self.swagger_types
44
+ {
45
+ :'presentation_paths' => :'Array<String>',
46
+ :'presentation_passwords' => :'Array<String>',
47
+ }
48
+ end
49
+
50
+ # Initializes the object
51
+ # @param [Hash] attributes Model attributes in the form of hash
52
+ def initialize(attributes = {})
53
+ return unless attributes.is_a?(Hash)
54
+
55
+ # convert string to symbol for hash key
56
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
57
+
58
+ if attributes.has_key?(:'PresentationPaths')
59
+ if (value = attributes[:'PresentationPaths']).is_a?(Array)
60
+ self.presentation_paths = value
61
+ end
62
+ end
63
+
64
+ if attributes.has_key?(:'PresentationPasswords')
65
+ if (value = attributes[:'PresentationPasswords']).is_a?(Array)
66
+ self.presentation_passwords = value
67
+ end
68
+ end
69
+ end
70
+
71
+ # Show invalid properties with the reasons. Usually used together with valid?
72
+ # @return Array for valid properties with the reasons
73
+ def list_invalid_properties
74
+ invalid_properties = Array.new
75
+ invalid_properties
76
+ end
77
+
78
+ # Check to see if the all the properties in the model are valid
79
+ # @return true if the model is valid
80
+ def valid?
81
+ true
82
+ end
83
+
84
+ # Checks equality by comparing each attribute.
85
+ # @param [Object] Object to be compared
86
+ def ==(o)
87
+ return true if self.equal?(o)
88
+ self.class == o.class &&
89
+ presentation_paths == o.presentation_paths &&
90
+ presentation_passwords == o.presentation_passwords
91
+ end
92
+
93
+ # @see the `==` method
94
+ # @param [Object] Object to be compared
95
+ def eql?(o)
96
+ self == o
97
+ end
98
+
99
+ # Calculates hash code according to all attributes.
100
+ # @return [Fixnum] Hash code
101
+ def hash
102
+ [presentation_paths, presentation_passwords].hash
103
+ end
104
+
105
+ # Builds the object from hash
106
+ # @param [Hash] attributes Model attributes in the form of hash
107
+ # @return [Object] Returns the model itself
108
+ def build_from_hash(attributes)
109
+ return nil unless attributes.is_a?(Hash)
110
+ self.class.swagger_types.each_pair do |key, type|
111
+ mapKey = self.class.attribute_map[key]
112
+ if !mapKey.nil?
113
+ val = attributes[mapKey]
114
+ if val.nil?
115
+ mapKeyString = mapKey.to_s
116
+ mapKeyString[0] = mapKeyString[0].downcase
117
+ mapKey = mapKeyString.to_sym
118
+ val = attributes[mapKey]
119
+ end
120
+ if !val.nil?
121
+ if type =~ /\AArray<(.*)>/i
122
+ # check to ensure the input is an array given that the the attribute
123
+ # is documented as an array but the input is not
124
+ if val.is_a?(Array)
125
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
126
+ end
127
+ else
128
+ self.send("#{key}=", _deserialize(type, val))
129
+ end
130
+ end
131
+ end
132
+ end
133
+
134
+ self
135
+ end
136
+
137
+ # Deserializes the data based on type
138
+ # @param string type Data type
139
+ # @param string value Value to be deserialized
140
+ # @return [Object] Deserialized data
141
+ def _deserialize(type, value)
142
+ case type.to_sym
143
+ when :DateTime
144
+ DateTime.parse(value)
145
+ when :Date
146
+ Date.parse(value)
147
+ when :String
148
+ value.to_s
149
+ when :Integer
150
+ value.to_i
151
+ when :Float
152
+ value.to_f
153
+ when :BOOLEAN
154
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
155
+ true
156
+ else
157
+ false
158
+ end
159
+ when :Object
160
+ # generic object (usually a Hash), return directly
161
+ value
162
+ when /\AArray<(?<inner_type>.+)>\z/
163
+ inner_type = Regexp.last_match[:inner_type]
164
+ value.map { |v| _deserialize(inner_type, v) }
165
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
166
+ k_type = Regexp.last_match[:k_type]
167
+ v_type = Regexp.last_match[:v_type]
168
+ {}.tap do |hash|
169
+ value.each do |k, v|
170
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
171
+ end
172
+ end
173
+ else # model
174
+ temp_model = AsposeSlidesCloud.const_get(type).new
175
+ temp_model.build_from_hash(value)
176
+ end
177
+ end
178
+
179
+ # Returns the string representation of the object
180
+ # @return [String] String presentation of the object
181
+ def to_s
182
+ to_hash.to_s
183
+ end
184
+
185
+ # to_body is an alias to to_hash (backward compatibility)
186
+ # @return [Hash] Returns the object in the form of hash
187
+ def to_body
188
+ to_hash
189
+ end
190
+
191
+ # Returns the object in the form of hash
192
+ # @return [Hash] Returns the object in the form of hash
193
+ def to_hash
194
+ hash = {}
195
+ self.class.attribute_map.each_pair do |attr, param|
196
+ value = self.send(attr)
197
+ next if value.nil?
198
+ hash[param] = _to_hash(value)
199
+ end
200
+ hash
201
+ end
202
+
203
+ # Outputs non-array value in the form of hash
204
+ # For object, use to_hash. Otherwise, just return the value
205
+ # @param [Object] value Any valid value
206
+ # @return [Hash] Returns the value in the form of hash
207
+ def _to_hash(value)
208
+ if value.is_a?(Array)
209
+ value.compact.map { |v| _to_hash(v) }
210
+ elsif value.is_a?(Hash)
211
+ {}.tap do |hash|
212
+ value.each { |k, v| hash[k] = _to_hash(v) }
213
+ end
214
+ elsif value.respond_to? :to_hash
215
+ value.to_hash
216
+ else
217
+ value
218
+ end
219
+ end
220
+ end
221
+ end
@@ -1,286 +1,286 @@
1
- =begin
2
- Copyright (c) 2019 Aspose Pty Ltd
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy
5
- of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction, including without limitation the rights
7
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
- copies of the Software, and to permit persons to whom the Software is
9
- furnished to do so, subject to the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be included in all
12
- copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
- SOFTWARE.
21
- =end
22
-
23
- require 'date'
24
-
25
- module AsposeSlidesCloud
26
- # Represents preset shadow effect
27
- class PresetShadowEffect
28
- # direction
29
- attr_accessor :direction
30
-
31
- # distance
32
- attr_accessor :distance
33
-
34
- # preset
35
- attr_accessor :preset
36
-
37
- # shadow color
38
- attr_accessor :shadow_color
39
-
40
- class EnumAttributeValidator
41
- attr_reader :datatype
42
- attr_reader :allowable_values
43
-
44
- def initialize(datatype, allowable_values)
45
- @allowable_values = allowable_values.map do |value|
46
- case datatype.to_s
47
- when /Integer/i
48
- value.to_i
49
- when /Float/i
50
- value.to_f
51
- else
52
- value
53
- end
54
- end
55
- end
56
-
57
- def valid?(value)
58
- !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
59
- end
60
- end
61
-
62
- # Attribute mapping from ruby-style variable name to JSON key.
63
- def self.attribute_map
64
- {
65
- :'direction' => :'Direction',
66
- :'distance' => :'Distance',
67
- :'preset' => :'Preset',
68
- :'shadow_color' => :'ShadowColor',
69
- }
70
- end
71
-
72
- # Attribute type mapping.
73
- def self.swagger_types
74
- {
75
- :'direction' => :'Float',
76
- :'distance' => :'Float',
77
- :'preset' => :'String',
78
- :'shadow_color' => :'String',
79
- }
80
- end
81
-
82
- # Initializes the object
83
- # @param [Hash] attributes Model attributes in the form of hash
84
- def initialize(attributes = {})
85
- return unless attributes.is_a?(Hash)
86
-
87
- # convert string to symbol for hash key
88
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
89
-
90
- if attributes.has_key?(:'Direction')
91
- self.direction = attributes[:'Direction']
92
- end
93
-
94
- if attributes.has_key?(:'Distance')
95
- self.distance = attributes[:'Distance']
96
- end
97
-
98
- if attributes.has_key?(:'Preset')
99
- self.preset = attributes[:'Preset']
100
- end
101
-
102
- if attributes.has_key?(:'ShadowColor')
103
- self.shadow_color = attributes[:'ShadowColor']
104
- end
105
- end
106
-
107
- # Show invalid properties with the reasons. Usually used together with valid?
108
- # @return Array for valid properties with the reasons
109
- def list_invalid_properties
110
- invalid_properties = Array.new
111
- if @direction.nil?
112
- invalid_properties.push('invalid value for "direction", direction cannot be nil.')
113
- end
114
-
115
- if @distance.nil?
116
- invalid_properties.push('invalid value for "distance", distance cannot be nil.')
117
- end
118
-
119
- if @preset.nil?
120
- invalid_properties.push('invalid value for "preset", preset cannot be nil.')
121
- end
122
-
123
- invalid_properties
124
- end
125
-
126
- # Check to see if the all the properties in the model are valid
127
- # @return true if the model is valid
128
- def valid?
129
- return false if @direction.nil?
130
- return false if @distance.nil?
131
- return false if @preset.nil?
132
- preset_validator = EnumAttributeValidator.new('String', ['TopLeftDropShadow', 'TopLeftLargeDropShadow', 'BackLeftLongPerspectiveShadow', 'BackRightLongPerspectiveShadow', 'TopLeftDoubleDropShadow', 'BottomRightSmallDropShadow', 'FrontLeftLongPerspectiveShadow', 'FrontRightLongPerspectiveShadow', 'OuterBoxShadow3D', 'InnerBoxShadow3D', 'BackCenterPerspectiveShadow', 'TopRightDropShadow', 'FrontBottomShadow', 'BackLeftPerspectiveShadow', 'BackRightPerspectiveShadow', 'BottomLeftDropShadow', 'BottomRightDropShadow', 'FrontLeftPerspectiveShadow', 'FrontRightPerspectiveShadow', 'TopLeftSmallDropShadow'])
133
- return false unless preset_validator.valid?(@preset)
134
- true
135
- end
136
-
137
- # Custom attribute writer method checking allowed values (enum).
138
- # @param [Object] preset Object to be assigned
139
- def preset=(preset)
140
- validator = EnumAttributeValidator.new('String', ['TopLeftDropShadow', 'TopLeftLargeDropShadow', 'BackLeftLongPerspectiveShadow', 'BackRightLongPerspectiveShadow', 'TopLeftDoubleDropShadow', 'BottomRightSmallDropShadow', 'FrontLeftLongPerspectiveShadow', 'FrontRightLongPerspectiveShadow', 'OuterBoxShadow3D', 'InnerBoxShadow3D', 'BackCenterPerspectiveShadow', 'TopRightDropShadow', 'FrontBottomShadow', 'BackLeftPerspectiveShadow', 'BackRightPerspectiveShadow', 'BottomLeftDropShadow', 'BottomRightDropShadow', 'FrontLeftPerspectiveShadow', 'FrontRightPerspectiveShadow', 'TopLeftSmallDropShadow'])
141
- unless validator.valid?(preset)
142
- fail ArgumentError, 'invalid value for "preset", must be one of #{validator.allowable_values}.'
143
- end
144
- @preset = preset
145
- end
146
-
147
- # Checks equality by comparing each attribute.
148
- # @param [Object] Object to be compared
149
- def ==(o)
150
- return true if self.equal?(o)
151
- self.class == o.class &&
152
- direction == o.direction &&
153
- distance == o.distance &&
154
- preset == o.preset &&
155
- shadow_color == o.shadow_color
156
- end
157
-
158
- # @see the `==` method
159
- # @param [Object] Object to be compared
160
- def eql?(o)
161
- self == o
162
- end
163
-
164
- # Calculates hash code according to all attributes.
165
- # @return [Fixnum] Hash code
166
- def hash
167
- [direction, distance, preset, shadow_color].hash
168
- end
169
-
170
- # Builds the object from hash
171
- # @param [Hash] attributes Model attributes in the form of hash
172
- # @return [Object] Returns the model itself
173
- def build_from_hash(attributes)
174
- return nil unless attributes.is_a?(Hash)
175
- self.class.swagger_types.each_pair do |key, type|
176
- mapKey = self.class.attribute_map[key]
177
- if !mapKey.nil?
178
- val = attributes[mapKey]
179
- if val.nil?
180
- mapKeyString = mapKey.to_s
181
- mapKeyString[0] = mapKeyString[0].downcase
182
- mapKey = mapKeyString.to_sym
183
- val = attributes[mapKey]
184
- end
185
- if !val.nil?
186
- if type =~ /\AArray<(.*)>/i
187
- # check to ensure the input is an array given that the the attribute
188
- # is documented as an array but the input is not
189
- if val.is_a?(Array)
190
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
191
- end
192
- else
193
- self.send("#{key}=", _deserialize(type, val))
194
- end
195
- end
196
- end
197
- end
198
-
199
- self
200
- end
201
-
202
- # Deserializes the data based on type
203
- # @param string type Data type
204
- # @param string value Value to be deserialized
205
- # @return [Object] Deserialized data
206
- def _deserialize(type, value)
207
- case type.to_sym
208
- when :DateTime
209
- DateTime.parse(value)
210
- when :Date
211
- Date.parse(value)
212
- when :String
213
- value.to_s
214
- when :Integer
215
- value.to_i
216
- when :Float
217
- value.to_f
218
- when :BOOLEAN
219
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
220
- true
221
- else
222
- false
223
- end
224
- when :Object
225
- # generic object (usually a Hash), return directly
226
- value
227
- when /\AArray<(?<inner_type>.+)>\z/
228
- inner_type = Regexp.last_match[:inner_type]
229
- value.map { |v| _deserialize(inner_type, v) }
230
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
231
- k_type = Regexp.last_match[:k_type]
232
- v_type = Regexp.last_match[:v_type]
233
- {}.tap do |hash|
234
- value.each do |k, v|
235
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
236
- end
237
- end
238
- else # model
239
- temp_model = AsposeSlidesCloud.const_get(type).new
240
- temp_model.build_from_hash(value)
241
- end
242
- end
243
-
244
- # Returns the string representation of the object
245
- # @return [String] String presentation of the object
246
- def to_s
247
- to_hash.to_s
248
- end
249
-
250
- # to_body is an alias to to_hash (backward compatibility)
251
- # @return [Hash] Returns the object in the form of hash
252
- def to_body
253
- to_hash
254
- end
255
-
256
- # Returns the object in the form of hash
257
- # @return [Hash] Returns the object in the form of hash
258
- def to_hash
259
- hash = {}
260
- self.class.attribute_map.each_pair do |attr, param|
261
- value = self.send(attr)
262
- next if value.nil?
263
- hash[param] = _to_hash(value)
264
- end
265
- hash
266
- end
267
-
268
- # Outputs non-array value in the form of hash
269
- # For object, use to_hash. Otherwise, just return the value
270
- # @param [Object] value Any valid value
271
- # @return [Hash] Returns the value in the form of hash
272
- def _to_hash(value)
273
- if value.is_a?(Array)
274
- value.compact.map { |v| _to_hash(v) }
275
- elsif value.is_a?(Hash)
276
- {}.tap do |hash|
277
- value.each { |k, v| hash[k] = _to_hash(v) }
278
- end
279
- elsif value.respond_to? :to_hash
280
- value.to_hash
281
- else
282
- value
283
- end
284
- end
285
- end
286
- end
1
+ =begin
2
+ Copyright (c) 2019 Aspose Pty Ltd
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in all
12
+ copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
+ SOFTWARE.
21
+ =end
22
+
23
+ require 'date'
24
+
25
+ module AsposeSlidesCloud
26
+ # Represents preset shadow effect
27
+ class PresetShadowEffect
28
+ # direction
29
+ attr_accessor :direction
30
+
31
+ # distance
32
+ attr_accessor :distance
33
+
34
+ # preset
35
+ attr_accessor :preset
36
+
37
+ # shadow color
38
+ attr_accessor :shadow_color
39
+
40
+ class EnumAttributeValidator
41
+ attr_reader :datatype
42
+ attr_reader :allowable_values
43
+
44
+ def initialize(datatype, allowable_values)
45
+ @allowable_values = allowable_values.map do |value|
46
+ case datatype.to_s
47
+ when /Integer/i
48
+ value.to_i
49
+ when /Float/i
50
+ value.to_f
51
+ else
52
+ value
53
+ end
54
+ end
55
+ end
56
+
57
+ def valid?(value)
58
+ !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
59
+ end
60
+ end
61
+
62
+ # Attribute mapping from ruby-style variable name to JSON key.
63
+ def self.attribute_map
64
+ {
65
+ :'direction' => :'Direction',
66
+ :'distance' => :'Distance',
67
+ :'preset' => :'Preset',
68
+ :'shadow_color' => :'ShadowColor',
69
+ }
70
+ end
71
+
72
+ # Attribute type mapping.
73
+ def self.swagger_types
74
+ {
75
+ :'direction' => :'Float',
76
+ :'distance' => :'Float',
77
+ :'preset' => :'String',
78
+ :'shadow_color' => :'String',
79
+ }
80
+ end
81
+
82
+ # Initializes the object
83
+ # @param [Hash] attributes Model attributes in the form of hash
84
+ def initialize(attributes = {})
85
+ return unless attributes.is_a?(Hash)
86
+
87
+ # convert string to symbol for hash key
88
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
89
+
90
+ if attributes.has_key?(:'Direction')
91
+ self.direction = attributes[:'Direction']
92
+ end
93
+
94
+ if attributes.has_key?(:'Distance')
95
+ self.distance = attributes[:'Distance']
96
+ end
97
+
98
+ if attributes.has_key?(:'Preset')
99
+ self.preset = attributes[:'Preset']
100
+ end
101
+
102
+ if attributes.has_key?(:'ShadowColor')
103
+ self.shadow_color = attributes[:'ShadowColor']
104
+ end
105
+ end
106
+
107
+ # Show invalid properties with the reasons. Usually used together with valid?
108
+ # @return Array for valid properties with the reasons
109
+ def list_invalid_properties
110
+ invalid_properties = Array.new
111
+ if @direction.nil?
112
+ invalid_properties.push('invalid value for "direction", direction cannot be nil.')
113
+ end
114
+
115
+ if @distance.nil?
116
+ invalid_properties.push('invalid value for "distance", distance cannot be nil.')
117
+ end
118
+
119
+ if @preset.nil?
120
+ invalid_properties.push('invalid value for "preset", preset cannot be nil.')
121
+ end
122
+
123
+ invalid_properties
124
+ end
125
+
126
+ # Check to see if the all the properties in the model are valid
127
+ # @return true if the model is valid
128
+ def valid?
129
+ return false if @direction.nil?
130
+ return false if @distance.nil?
131
+ return false if @preset.nil?
132
+ preset_validator = EnumAttributeValidator.new('String', ['TopLeftDropShadow', 'TopLeftLargeDropShadow', 'BackLeftLongPerspectiveShadow', 'BackRightLongPerspectiveShadow', 'TopLeftDoubleDropShadow', 'BottomRightSmallDropShadow', 'FrontLeftLongPerspectiveShadow', 'FrontRightLongPerspectiveShadow', 'OuterBoxShadow3D', 'InnerBoxShadow3D', 'BackCenterPerspectiveShadow', 'TopRightDropShadow', 'FrontBottomShadow', 'BackLeftPerspectiveShadow', 'BackRightPerspectiveShadow', 'BottomLeftDropShadow', 'BottomRightDropShadow', 'FrontLeftPerspectiveShadow', 'FrontRightPerspectiveShadow', 'TopLeftSmallDropShadow'])
133
+ return false unless preset_validator.valid?(@preset)
134
+ true
135
+ end
136
+
137
+ # Custom attribute writer method checking allowed values (enum).
138
+ # @param [Object] preset Object to be assigned
139
+ def preset=(preset)
140
+ validator = EnumAttributeValidator.new('String', ['TopLeftDropShadow', 'TopLeftLargeDropShadow', 'BackLeftLongPerspectiveShadow', 'BackRightLongPerspectiveShadow', 'TopLeftDoubleDropShadow', 'BottomRightSmallDropShadow', 'FrontLeftLongPerspectiveShadow', 'FrontRightLongPerspectiveShadow', 'OuterBoxShadow3D', 'InnerBoxShadow3D', 'BackCenterPerspectiveShadow', 'TopRightDropShadow', 'FrontBottomShadow', 'BackLeftPerspectiveShadow', 'BackRightPerspectiveShadow', 'BottomLeftDropShadow', 'BottomRightDropShadow', 'FrontLeftPerspectiveShadow', 'FrontRightPerspectiveShadow', 'TopLeftSmallDropShadow'])
141
+ unless validator.valid?(preset)
142
+ fail ArgumentError, 'invalid value for "preset", must be one of #{validator.allowable_values}.'
143
+ end
144
+ @preset = preset
145
+ end
146
+
147
+ # Checks equality by comparing each attribute.
148
+ # @param [Object] Object to be compared
149
+ def ==(o)
150
+ return true if self.equal?(o)
151
+ self.class == o.class &&
152
+ direction == o.direction &&
153
+ distance == o.distance &&
154
+ preset == o.preset &&
155
+ shadow_color == o.shadow_color
156
+ end
157
+
158
+ # @see the `==` method
159
+ # @param [Object] Object to be compared
160
+ def eql?(o)
161
+ self == o
162
+ end
163
+
164
+ # Calculates hash code according to all attributes.
165
+ # @return [Fixnum] Hash code
166
+ def hash
167
+ [direction, distance, preset, shadow_color].hash
168
+ end
169
+
170
+ # Builds the object from hash
171
+ # @param [Hash] attributes Model attributes in the form of hash
172
+ # @return [Object] Returns the model itself
173
+ def build_from_hash(attributes)
174
+ return nil unless attributes.is_a?(Hash)
175
+ self.class.swagger_types.each_pair do |key, type|
176
+ mapKey = self.class.attribute_map[key]
177
+ if !mapKey.nil?
178
+ val = attributes[mapKey]
179
+ if val.nil?
180
+ mapKeyString = mapKey.to_s
181
+ mapKeyString[0] = mapKeyString[0].downcase
182
+ mapKey = mapKeyString.to_sym
183
+ val = attributes[mapKey]
184
+ end
185
+ if !val.nil?
186
+ if type =~ /\AArray<(.*)>/i
187
+ # check to ensure the input is an array given that the the attribute
188
+ # is documented as an array but the input is not
189
+ if val.is_a?(Array)
190
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
191
+ end
192
+ else
193
+ self.send("#{key}=", _deserialize(type, val))
194
+ end
195
+ end
196
+ end
197
+ end
198
+
199
+ self
200
+ end
201
+
202
+ # Deserializes the data based on type
203
+ # @param string type Data type
204
+ # @param string value Value to be deserialized
205
+ # @return [Object] Deserialized data
206
+ def _deserialize(type, value)
207
+ case type.to_sym
208
+ when :DateTime
209
+ DateTime.parse(value)
210
+ when :Date
211
+ Date.parse(value)
212
+ when :String
213
+ value.to_s
214
+ when :Integer
215
+ value.to_i
216
+ when :Float
217
+ value.to_f
218
+ when :BOOLEAN
219
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
220
+ true
221
+ else
222
+ false
223
+ end
224
+ when :Object
225
+ # generic object (usually a Hash), return directly
226
+ value
227
+ when /\AArray<(?<inner_type>.+)>\z/
228
+ inner_type = Regexp.last_match[:inner_type]
229
+ value.map { |v| _deserialize(inner_type, v) }
230
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
231
+ k_type = Regexp.last_match[:k_type]
232
+ v_type = Regexp.last_match[:v_type]
233
+ {}.tap do |hash|
234
+ value.each do |k, v|
235
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
236
+ end
237
+ end
238
+ else # model
239
+ temp_model = AsposeSlidesCloud.const_get(type).new
240
+ temp_model.build_from_hash(value)
241
+ end
242
+ end
243
+
244
+ # Returns the string representation of the object
245
+ # @return [String] String presentation of the object
246
+ def to_s
247
+ to_hash.to_s
248
+ end
249
+
250
+ # to_body is an alias to to_hash (backward compatibility)
251
+ # @return [Hash] Returns the object in the form of hash
252
+ def to_body
253
+ to_hash
254
+ end
255
+
256
+ # Returns the object in the form of hash
257
+ # @return [Hash] Returns the object in the form of hash
258
+ def to_hash
259
+ hash = {}
260
+ self.class.attribute_map.each_pair do |attr, param|
261
+ value = self.send(attr)
262
+ next if value.nil?
263
+ hash[param] = _to_hash(value)
264
+ end
265
+ hash
266
+ end
267
+
268
+ # Outputs non-array value in the form of hash
269
+ # For object, use to_hash. Otherwise, just return the value
270
+ # @param [Object] value Any valid value
271
+ # @return [Hash] Returns the value in the form of hash
272
+ def _to_hash(value)
273
+ if value.is_a?(Array)
274
+ value.compact.map { |v| _to_hash(v) }
275
+ elsif value.is_a?(Hash)
276
+ {}.tap do |hash|
277
+ value.each { |k, v| hash[k] = _to_hash(v) }
278
+ end
279
+ elsif value.respond_to? :to_hash
280
+ value.to_hash
281
+ else
282
+ value
283
+ end
284
+ end
285
+ end
286
+ end