songtradr_api_client_ruby 1.13.4 → 1.13.6

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 (263) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +3 -3
  3. data/README.md +45 -26
  4. data/docs/AgeRange.md +20 -0
  5. data/docs/Beard.md +20 -0
  6. data/docs/BoundingBox.md +24 -0
  7. data/docs/ContextValue.md +18 -0
  8. data/docs/CuratePlaylistDTO.md +26 -0
  9. data/docs/CuratePlaylistResponseDTO.md +18 -0
  10. data/docs/DominantColor.md +30 -0
  11. data/docs/Emotion.md +20 -0
  12. data/docs/EyeDirection.md +22 -0
  13. data/docs/EyeOpen.md +20 -0
  14. data/docs/Eyeglasses.md +20 -0
  15. data/docs/FaceDetail.md +50 -0
  16. data/docs/FaceDetection.md +20 -0
  17. data/docs/FaceOccluded.md +20 -0
  18. data/docs/FileSmallDTO.md +11 -11
  19. data/docs/Gender.md +20 -0
  20. data/docs/ImageQuality.md +20 -0
  21. data/docs/ImageRecognitionResponse.md +20 -0
  22. data/docs/Instance.md +22 -0
  23. data/docs/Label.md +28 -0
  24. data/docs/{CreateApiKeyDTO.md → LabelAlias.md} +2 -2
  25. data/docs/LabelCategory.md +18 -0
  26. data/docs/LabelDetection.md +26 -0
  27. data/docs/Landmark.md +22 -0
  28. data/docs/MouthOpen.md +20 -0
  29. data/docs/MusicalFeaturesDTO.md +45 -45
  30. data/docs/Mustache.md +20 -0
  31. data/docs/Parent.md +18 -0
  32. data/docs/PlaylistApi.md +70 -0
  33. data/docs/PlaylistLargeDTO.md +5 -5
  34. data/docs/Pose.md +22 -0
  35. data/docs/ProductMediumDTO.md +2 -2
  36. data/docs/ProductPartyDTO.md +3 -3
  37. data/docs/RecordingGenrePredictionDTO.md +3 -3
  38. data/docs/RecordingLargeDTO.md +9 -9
  39. data/docs/RecordingMediumDTO.md +7 -7
  40. data/docs/RecordingPartyDTO.md +3 -3
  41. data/docs/RecordingSmallDTO.md +3 -3
  42. data/docs/SaveFileRecordingDTO.md +5 -1
  43. data/docs/Smile.md +20 -0
  44. data/docs/Sunglasses.md +20 -0
  45. data/docs/TagDTO.md +3 -3
  46. data/docs/UserApi.md +140 -0
  47. data/docs/VideoRecognitionResponse.md +20 -0
  48. data/lib/songtradr_api_client_ruby/api/allowed_values_api.rb +1 -1
  49. data/lib/songtradr_api_client_ruby/api/party_api.rb +1 -1
  50. data/lib/songtradr_api_client_ruby/api/playlist_api.rb +78 -1
  51. data/lib/songtradr_api_client_ruby/api/recording_api.rb +1 -1
  52. data/lib/songtradr_api_client_ruby/api/user_api.rb +137 -1
  53. data/lib/songtradr_api_client_ruby/api_client.rb +3 -2
  54. data/lib/songtradr_api_client_ruby/api_error.rb +1 -1
  55. data/lib/songtradr_api_client_ruby/configuration.rb +2 -1
  56. data/lib/songtradr_api_client_ruby/models/age_range.rb +223 -0
  57. data/lib/songtradr_api_client_ruby/models/beard.rb +223 -0
  58. data/lib/songtradr_api_client_ruby/models/bounding_box.rb +241 -0
  59. data/lib/songtradr_api_client_ruby/models/category_medium_dto.rb +1 -1
  60. data/lib/songtradr_api_client_ruby/models/category_minimal_dto.rb +1 -1
  61. data/lib/songtradr_api_client_ruby/models/config_access_dto.rb +1 -1
  62. data/lib/songtradr_api_client_ruby/models/config_identifier_dto.rb +1 -1
  63. data/lib/songtradr_api_client_ruby/models/context_value.rb +216 -0
  64. data/lib/songtradr_api_client_ruby/models/contributor_type_dto.rb +1 -1
  65. data/lib/songtradr_api_client_ruby/models/curate_playlist_dto.rb +256 -0
  66. data/lib/songtradr_api_client_ruby/models/curate_playlist_response_dto.rb +216 -0
  67. data/lib/songtradr_api_client_ruby/models/dominant_color.rb +268 -0
  68. data/lib/songtradr_api_client_ruby/models/emotion.rb +223 -0
  69. data/lib/songtradr_api_client_ruby/models/error_response.rb +1 -1
  70. data/lib/songtradr_api_client_ruby/models/eye_direction.rb +232 -0
  71. data/lib/songtradr_api_client_ruby/models/eye_open.rb +223 -0
  72. data/lib/songtradr_api_client_ruby/models/eyeglasses.rb +223 -0
  73. data/lib/songtradr_api_client_ruby/models/face_detail.rb +362 -0
  74. data/lib/songtradr_api_client_ruby/models/face_detection.rb +223 -0
  75. data/lib/songtradr_api_client_ruby/models/face_occluded.rb +223 -0
  76. data/lib/songtradr_api_client_ruby/models/field_summary_dto.rb +1 -1
  77. data/lib/songtradr_api_client_ruby/models/file_dto.rb +1 -1
  78. data/lib/songtradr_api_client_ruby/models/file_list_dto.rb +1 -1
  79. data/lib/songtradr_api_client_ruby/models/file_minimal_with_url_dto.rb +1 -1
  80. data/lib/songtradr_api_client_ruby/models/file_small_dto.rb +63 -63
  81. data/lib/songtradr_api_client_ruby/models/file_upload_dto.rb +1 -1
  82. data/lib/songtradr_api_client_ruby/models/file_w_ith_url_dto.rb +1 -1
  83. data/lib/songtradr_api_client_ruby/models/files_summary_dto.rb +1 -1
  84. data/lib/songtradr_api_client_ruby/models/forgot_password_dto.rb +1 -1
  85. data/lib/songtradr_api_client_ruby/models/gender.rb +223 -0
  86. data/lib/songtradr_api_client_ruby/models/genre_dto.rb +1 -1
  87. data/lib/songtradr_api_client_ruby/models/genre_minimal_dto.rb +1 -1
  88. data/lib/songtradr_api_client_ruby/models/genres_summary_dto.rb +1 -1
  89. data/lib/songtradr_api_client_ruby/models/image_quality.rb +223 -0
  90. data/lib/songtradr_api_client_ruby/models/image_recognition_response.rb +227 -0
  91. data/lib/songtradr_api_client_ruby/models/init_put_recording_audio_dto.rb +1 -1
  92. data/lib/songtradr_api_client_ruby/models/instance.rb +234 -0
  93. data/lib/songtradr_api_client_ruby/models/jwt_token_dto.rb +1 -1
  94. data/lib/songtradr_api_client_ruby/models/label.rb +267 -0
  95. data/lib/songtradr_api_client_ruby/models/{create_api_key_dto.rb → label_alias.rb} +4 -4
  96. data/lib/songtradr_api_client_ruby/models/label_category.rb +214 -0
  97. data/lib/songtradr_api_client_ruby/models/label_detection.rb +250 -0
  98. data/lib/songtradr_api_client_ruby/models/landmark.rb +232 -0
  99. data/lib/songtradr_api_client_ruby/models/login_dto.rb +1 -1
  100. data/lib/songtradr_api_client_ruby/models/{api_key_dto.rb → mouth_open.rb} +17 -56
  101. data/lib/songtradr_api_client_ruby/models/musical_features_dto.rb +353 -353
  102. data/lib/songtradr_api_client_ruby/models/mustache.rb +223 -0
  103. data/lib/songtradr_api_client_ruby/models/p_line_dto.rb +1 -1
  104. data/lib/songtradr_api_client_ruby/models/parent.rb +214 -0
  105. data/lib/songtradr_api_client_ruby/models/party_large_dto.rb +1 -1
  106. data/lib/songtradr_api_client_ruby/models/party_small_dto.rb +1 -1
  107. data/lib/songtradr_api_client_ruby/models/playlist_large_dto.rb +22 -22
  108. data/lib/songtradr_api_client_ruby/models/pose.rb +232 -0
  109. data/lib/songtradr_api_client_ruby/models/product_medium_dto.rb +11 -11
  110. data/lib/songtradr_api_client_ruby/models/product_party_dto.rb +16 -16
  111. data/lib/songtradr_api_client_ruby/models/recording_for_similarity_search_dto.rb +1 -1
  112. data/lib/songtradr_api_client_ruby/models/recording_genre_prediction_dto.rb +21 -21
  113. data/lib/songtradr_api_client_ruby/models/recording_large_dto.rb +51 -51
  114. data/lib/songtradr_api_client_ruby/models/recording_list_dto.rb +1 -1
  115. data/lib/songtradr_api_client_ruby/models/recording_medium_dto.rb +42 -42
  116. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_musical_features_dto.rb +1 -1
  117. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_taggrams_dto.rb +1 -1
  118. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_tagstrengths_dto.rb +1 -1
  119. data/lib/songtradr_api_client_ruby/models/recording_party_dto.rb +16 -16
  120. data/lib/songtradr_api_client_ruby/models/recording_playlist_dto.rb +1 -1
  121. data/lib/songtradr_api_client_ruby/models/recording_small_dto.rb +26 -26
  122. data/lib/songtradr_api_client_ruby/models/recording_tag_small_dto.rb +1 -1
  123. data/lib/songtradr_api_client_ruby/models/save_file_recording_dto.rb +23 -5
  124. data/lib/songtradr_api_client_ruby/models/save_playlist_dto.rb +1 -1
  125. data/lib/songtradr_api_client_ruby/models/save_recording_genre_dto.rb +1 -1
  126. data/lib/songtradr_api_client_ruby/models/save_recording_party_dto.rb +1 -1
  127. data/lib/songtradr_api_client_ruby/models/save_recording_playlist_dto.rb +1 -1
  128. data/lib/songtradr_api_client_ruby/models/save_recording_tag_dto.rb +1 -1
  129. data/lib/songtradr_api_client_ruby/models/save_referrer_dto.rb +1 -1
  130. data/lib/songtradr_api_client_ruby/models/save_taggrams_dto.rb +1 -1
  131. data/lib/songtradr_api_client_ruby/models/save_user_dto.rb +1 -1
  132. data/lib/songtradr_api_client_ruby/models/search_filter_values_dto.rb +1 -1
  133. data/lib/songtradr_api_client_ruby/models/search_recording_granular_abstraction_dto.rb +1 -1
  134. data/lib/songtradr_api_client_ruby/models/search_recording_granular_dto.rb +1 -1
  135. data/lib/songtradr_api_client_ruby/models/sign_up_dto.rb +1 -1
  136. data/lib/songtradr_api_client_ruby/models/smile.rb +223 -0
  137. data/lib/songtradr_api_client_ruby/models/sunglasses.rb +223 -0
  138. data/lib/songtradr_api_client_ruby/models/tag_dto.rb +16 -16
  139. data/lib/songtradr_api_client_ruby/models/tag_small_dto.rb +1 -1
  140. data/lib/songtradr_api_client_ruby/models/taggram_dto.rb +1 -1
  141. data/lib/songtradr_api_client_ruby/models/tags_summary_dto.rb +1 -1
  142. data/lib/songtradr_api_client_ruby/models/tagstrength_dto.rb +1 -1
  143. data/lib/songtradr_api_client_ruby/models/title_dto.rb +1 -1
  144. data/lib/songtradr_api_client_ruby/models/token_request.rb +1 -1
  145. data/lib/songtradr_api_client_ruby/models/track_dto.rb +1 -1
  146. data/lib/songtradr_api_client_ruby/models/track_to_medium_product_dto.rb +1 -1
  147. data/lib/songtradr_api_client_ruby/models/update_password_dto.rb +1 -1
  148. data/lib/songtradr_api_client_ruby/models/usage_dto.rb +1 -1
  149. data/lib/songtradr_api_client_ruby/models/user_dto.rb +1 -1
  150. data/lib/songtradr_api_client_ruby/models/video_recognition_response.rb +227 -0
  151. data/lib/songtradr_api_client_ruby/version.rb +2 -2
  152. data/lib/songtradr_api_client_ruby.rb +31 -5
  153. data/openapi-generator-config.yaml +1 -1
  154. data/songtradr_api_client_ruby.gemspec +1 -1
  155. data/spec/api/allowed_values_api_spec.rb +1 -1
  156. data/spec/api/party_api_spec.rb +1 -1
  157. data/spec/api/playlist_api_spec.rb +13 -1
  158. data/spec/api/recording_api_spec.rb +1 -1
  159. data/spec/api/user_api_spec.rb +25 -1
  160. data/spec/api_client_spec.rb +1 -1
  161. data/spec/configuration_spec.rb +1 -1
  162. data/spec/models/age_range_spec.rb +42 -0
  163. data/spec/models/beard_spec.rb +42 -0
  164. data/spec/models/{api_key_dto_spec.rb → bounding_box_spec.rb} +13 -11
  165. data/spec/models/category_medium_dto_spec.rb +4 -2
  166. data/spec/models/category_minimal_dto_spec.rb +4 -2
  167. data/spec/models/config_access_dto_spec.rb +4 -2
  168. data/spec/models/config_identifier_dto_spec.rb +4 -2
  169. data/spec/models/context_value_spec.rb +36 -0
  170. data/spec/models/contributor_type_dto_spec.rb +4 -2
  171. data/spec/{api/api_keys_api_spec.rb → models/curate_playlist_dto_spec.rb} +21 -31
  172. data/spec/models/curate_playlist_response_dto_spec.rb +36 -0
  173. data/spec/models/dominant_color_spec.rb +72 -0
  174. data/spec/models/emotion_spec.rb +42 -0
  175. data/spec/models/error_response_spec.rb +4 -2
  176. data/spec/models/eye_direction_spec.rb +48 -0
  177. data/spec/models/eye_open_spec.rb +42 -0
  178. data/spec/models/eyeglasses_spec.rb +42 -0
  179. data/spec/models/{admin_api_user_dto_spec.rb → face_detail_spec.rb} +25 -83
  180. data/spec/models/face_detection_spec.rb +42 -0
  181. data/spec/models/face_occluded_spec.rb +42 -0
  182. data/spec/models/field_summary_dto_spec.rb +4 -2
  183. data/spec/models/file_dto_spec.rb +4 -2
  184. data/spec/models/file_list_dto_spec.rb +4 -2
  185. data/spec/models/file_minimal_with_url_dto_spec.rb +4 -2
  186. data/spec/models/file_small_dto_spec.rb +22 -20
  187. data/spec/models/file_upload_dto_spec.rb +4 -2
  188. data/spec/models/file_w_ith_url_dto_spec.rb +4 -2
  189. data/spec/models/files_summary_dto_spec.rb +4 -2
  190. data/spec/models/forgot_password_dto_spec.rb +4 -2
  191. data/spec/models/gender_spec.rb +42 -0
  192. data/spec/models/genre_dto_spec.rb +4 -2
  193. data/spec/models/genre_minimal_dto_spec.rb +4 -2
  194. data/spec/models/genres_summary_dto_spec.rb +4 -2
  195. data/spec/models/image_quality_spec.rb +42 -0
  196. data/spec/models/image_recognition_response_spec.rb +42 -0
  197. data/spec/models/init_put_recording_audio_dto_spec.rb +4 -2
  198. data/spec/models/instance_spec.rb +48 -0
  199. data/spec/models/jwt_token_dto_spec.rb +4 -2
  200. data/spec/models/label_alias_spec.rb +36 -0
  201. data/spec/models/label_category_spec.rb +36 -0
  202. data/spec/models/label_detection_spec.rb +60 -0
  203. data/spec/models/label_spec.rb +66 -0
  204. data/spec/models/landmark_spec.rb +48 -0
  205. data/spec/models/login_dto_spec.rb +4 -2
  206. data/spec/models/mouth_open_spec.rb +42 -0
  207. data/spec/models/musical_features_dto_spec.rb +145 -143
  208. data/spec/models/mustache_spec.rb +42 -0
  209. data/spec/models/p_line_dto_spec.rb +4 -2
  210. data/spec/models/{create_api_key_dto_spec.rb → parent_spec.rb} +9 -7
  211. data/spec/models/party_large_dto_spec.rb +4 -2
  212. data/spec/models/party_small_dto_spec.rb +4 -2
  213. data/spec/models/playlist_large_dto_spec.rb +8 -6
  214. data/spec/models/pose_spec.rb +48 -0
  215. data/spec/models/product_medium_dto_spec.rb +7 -5
  216. data/spec/models/product_party_dto_spec.rb +6 -4
  217. data/spec/models/recording_for_similarity_search_dto_spec.rb +4 -2
  218. data/spec/models/recording_genre_prediction_dto_spec.rb +7 -5
  219. data/spec/models/recording_large_dto_spec.rb +14 -12
  220. data/spec/models/recording_list_dto_spec.rb +4 -2
  221. data/spec/models/recording_medium_dto_spec.rb +13 -11
  222. data/spec/models/recording_minimal_with_musical_features_dto_spec.rb +4 -2
  223. data/spec/models/recording_minimal_with_taggrams_dto_spec.rb +4 -2
  224. data/spec/models/recording_minimal_with_tagstrengths_dto_spec.rb +4 -2
  225. data/spec/models/recording_party_dto_spec.rb +6 -4
  226. data/spec/models/recording_playlist_dto_spec.rb +4 -2
  227. data/spec/models/recording_small_dto_spec.rb +6 -4
  228. data/spec/models/recording_tag_small_dto_spec.rb +4 -2
  229. data/spec/models/save_file_recording_dto_spec.rb +16 -2
  230. data/spec/models/save_playlist_dto_spec.rb +4 -2
  231. data/spec/models/save_recording_genre_dto_spec.rb +4 -2
  232. data/spec/models/save_recording_party_dto_spec.rb +4 -2
  233. data/spec/models/save_recording_playlist_dto_spec.rb +4 -2
  234. data/spec/models/save_recording_tag_dto_spec.rb +4 -2
  235. data/spec/models/save_referrer_dto_spec.rb +4 -2
  236. data/spec/models/save_taggrams_dto_spec.rb +4 -2
  237. data/spec/models/save_user_dto_spec.rb +4 -2
  238. data/spec/models/search_filter_values_dto_spec.rb +4 -2
  239. data/spec/models/search_recording_granular_abstraction_dto_spec.rb +4 -2
  240. data/spec/models/search_recording_granular_dto_spec.rb +4 -2
  241. data/spec/models/sign_up_dto_spec.rb +4 -2
  242. data/spec/models/smile_spec.rb +42 -0
  243. data/spec/models/sunglasses_spec.rb +42 -0
  244. data/spec/models/tag_dto_spec.rb +6 -4
  245. data/spec/models/tag_small_dto_spec.rb +4 -2
  246. data/spec/models/taggram_dto_spec.rb +4 -2
  247. data/spec/models/tags_summary_dto_spec.rb +4 -2
  248. data/spec/models/tagstrength_dto_spec.rb +4 -2
  249. data/spec/models/title_dto_spec.rb +4 -2
  250. data/spec/models/token_request_spec.rb +4 -2
  251. data/spec/models/track_dto_spec.rb +4 -2
  252. data/spec/models/track_to_medium_product_dto_spec.rb +4 -2
  253. data/spec/models/update_password_dto_spec.rb +4 -2
  254. data/spec/models/usage_dto_spec.rb +4 -2
  255. data/spec/models/user_dto_spec.rb +4 -2
  256. data/spec/models/video_recognition_response_spec.rb +42 -0
  257. data/spec/spec_helper.rb +1 -1
  258. metadata +177 -73
  259. data/docs/APIKeysApi.md +0 -217
  260. data/docs/AdminApiUserDTO.md +0 -70
  261. data/docs/ApiKeyDTO.md +0 -24
  262. data/lib/songtradr_api_client_ruby/api/api_keys_api.rb +0 -213
  263. data/lib/songtradr_api_client_ruby/models/admin_api_user_dto.rb +0 -448
@@ -0,0 +1,232 @@
1
+ =begin
2
+ #Songtradr API
3
+
4
+ #This is the Songtradr API. Use it to retrieve deep music metadata and trigger processes like auto-tagging. You can also use the API to manage your account and musicube cloud data. **Authentication** 1. Reach out to support@songtradr.com to receive a free account or use your login data if you are already signed up. 2. To authenticate, you need to login via the POST /api/v1/user/login endpoint. 3. The endpoint responds with a jwtToken which you can use in all following API requests as a bearer token. **Rate Limiting** The current limit is 120 Requests per minute. Reach out to us via support@songtradr.com if you need to request more. **Getting Started with auto-tagging** 1. If you want to get your own files auto-tagged, use the POST /api/v1/user/file/{name}/initUpload endpoint. It responds with a presigned S3 link where you can upload your file. 2. You can check the processing status of your file via the GET /api/v1/user/file/{name}/filesStatus endpoint. 3. As soon as processing is done, you can request the generated data via the GET /api/v1/user/files endpoint. **Getting Started with search** You can either search the released music via the /public/recording endpoints or your own private uploaded music via the /user/file/ endpoints. 1. If you want to search the world's released music, a good starting point is the GET /api/v1/public/recording/search endpoint. Please find the extensive list of parameters that serve as semantic search filters. 2. If you want to search your own previously uploaded music, a good starting point is the GET GET /api/v1/user/files endpoint. It has the same extensive list of parameters that serve as semantic search filters.
5
+
6
+ The version of the OpenAPI document: 1.13.6
7
+ Contact: info@songtradr.com
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 7.1.0-SNAPSHOT
10
+
11
+ =end
12
+
13
+ require 'date'
14
+ require 'time'
15
+
16
+ module SongtradrApiClientRuby
17
+ class Pose
18
+ attr_accessor :roll
19
+
20
+ attr_accessor :yaw
21
+
22
+ attr_accessor :pitch
23
+
24
+ # Attribute mapping from ruby-style variable name to JSON key.
25
+ def self.attribute_map
26
+ {
27
+ :'roll' => :'roll',
28
+ :'yaw' => :'yaw',
29
+ :'pitch' => :'pitch'
30
+ }
31
+ end
32
+
33
+ # Returns all the JSON keys this model knows about
34
+ def self.acceptable_attributes
35
+ attribute_map.values
36
+ end
37
+
38
+ # Attribute type mapping.
39
+ def self.openapi_types
40
+ {
41
+ :'roll' => :'Float',
42
+ :'yaw' => :'Float',
43
+ :'pitch' => :'Float'
44
+ }
45
+ end
46
+
47
+ # List of attributes with nullable: true
48
+ def self.openapi_nullable
49
+ Set.new([
50
+ ])
51
+ end
52
+
53
+ # Initializes the object
54
+ # @param [Hash] attributes Model attributes in the form of hash
55
+ def initialize(attributes = {})
56
+ if (!attributes.is_a?(Hash))
57
+ fail ArgumentError, "The input argument (attributes) must be a hash in `SongtradrApiClientRuby::Pose` initialize method"
58
+ end
59
+
60
+ # check to see if the attribute exists and convert string to symbol for hash key
61
+ attributes = attributes.each_with_object({}) { |(k, v), h|
62
+ if (!self.class.attribute_map.key?(k.to_sym))
63
+ fail ArgumentError, "`#{k}` is not a valid attribute in `SongtradrApiClientRuby::Pose`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
64
+ end
65
+ h[k.to_sym] = v
66
+ }
67
+
68
+ if attributes.key?(:'roll')
69
+ self.roll = attributes[:'roll']
70
+ end
71
+
72
+ if attributes.key?(:'yaw')
73
+ self.yaw = attributes[:'yaw']
74
+ end
75
+
76
+ if attributes.key?(:'pitch')
77
+ self.pitch = attributes[:'pitch']
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
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
85
+ invalid_properties = Array.new
86
+ invalid_properties
87
+ end
88
+
89
+ # Check to see if the all the properties in the model are valid
90
+ # @return true if the model is valid
91
+ def valid?
92
+ warn '[DEPRECATED] the `valid?` method is obsolete'
93
+ true
94
+ end
95
+
96
+ # Checks equality by comparing each attribute.
97
+ # @param [Object] Object to be compared
98
+ def ==(o)
99
+ return true if self.equal?(o)
100
+ self.class == o.class &&
101
+ roll == o.roll &&
102
+ yaw == o.yaw &&
103
+ pitch == o.pitch
104
+ end
105
+
106
+ # @see the `==` method
107
+ # @param [Object] Object to be compared
108
+ def eql?(o)
109
+ self == o
110
+ end
111
+
112
+ # Calculates hash code according to all attributes.
113
+ # @return [Integer] Hash code
114
+ def hash
115
+ [roll, yaw, pitch].hash
116
+ end
117
+
118
+ # Builds the object from hash
119
+ # @param [Hash] attributes Model attributes in the form of hash
120
+ # @return [Object] Returns the model itself
121
+ def self.build_from_hash(attributes)
122
+ return nil unless attributes.is_a?(Hash)
123
+ attributes = attributes.transform_keys(&:to_sym)
124
+ transformed_hash = {}
125
+ openapi_types.each_pair do |key, type|
126
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
127
+ transformed_hash["#{key}"] = nil
128
+ elsif type =~ /\AArray<(.*)>/i
129
+ # check to ensure the input is an array given that the attribute
130
+ # is documented as an array but the input is not
131
+ if attributes[attribute_map[key]].is_a?(Array)
132
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
133
+ end
134
+ elsif !attributes[attribute_map[key]].nil?
135
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
136
+ end
137
+ end
138
+ new(transformed_hash)
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 self._deserialize(type, value)
146
+ case type.to_sym
147
+ when :Time
148
+ Time.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
+ # models (e.g. Pet) or oneOf
179
+ klass = SongtradrApiClientRuby.const_get(type)
180
+ klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
181
+ end
182
+ end
183
+
184
+ # Returns the string representation of the object
185
+ # @return [String] String presentation of the object
186
+ def to_s
187
+ to_hash.to_s
188
+ end
189
+
190
+ # to_body is an alias to to_hash (backward compatibility)
191
+ # @return [Hash] Returns the object in the form of hash
192
+ def to_body
193
+ to_hash
194
+ end
195
+
196
+ # Returns the object in the form of hash
197
+ # @return [Hash] Returns the object in the form of hash
198
+ def to_hash
199
+ hash = {}
200
+ self.class.attribute_map.each_pair do |attr, param|
201
+ value = self.send(attr)
202
+ if value.nil?
203
+ is_nullable = self.class.openapi_nullable.include?(attr)
204
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
205
+ end
206
+
207
+ hash[param] = _to_hash(value)
208
+ end
209
+ hash
210
+ end
211
+
212
+ # Outputs non-array value in the form of hash
213
+ # For object, use to_hash. Otherwise, just return the value
214
+ # @param [Object] value Any valid value
215
+ # @return [Hash] Returns the value in the form of hash
216
+ def _to_hash(value)
217
+ if value.is_a?(Array)
218
+ value.compact.map { |v| _to_hash(v) }
219
+ elsif value.is_a?(Hash)
220
+ {}.tap do |hash|
221
+ value.each { |k, v| hash[k] = _to_hash(v) }
222
+ end
223
+ elsif value.respond_to? :to_hash
224
+ value.to_hash
225
+ else
226
+ value
227
+ end
228
+ end
229
+
230
+ end
231
+
232
+ end
@@ -3,7 +3,7 @@
3
3
 
4
4
  #This is the Songtradr API. Use it to retrieve deep music metadata and trigger processes like auto-tagging. You can also use the API to manage your account and musicube cloud data. **Authentication** 1. Reach out to support@songtradr.com to receive a free account or use your login data if you are already signed up. 2. To authenticate, you need to login via the POST /api/v1/user/login endpoint. 3. The endpoint responds with a jwtToken which you can use in all following API requests as a bearer token. **Rate Limiting** The current limit is 120 Requests per minute. Reach out to us via support@songtradr.com if you need to request more. **Getting Started with auto-tagging** 1. If you want to get your own files auto-tagged, use the POST /api/v1/user/file/{name}/initUpload endpoint. It responds with a presigned S3 link where you can upload your file. 2. You can check the processing status of your file via the GET /api/v1/user/file/{name}/filesStatus endpoint. 3. As soon as processing is done, you can request the generated data via the GET /api/v1/user/files endpoint. **Getting Started with search** You can either search the released music via the /public/recording endpoints or your own private uploaded music via the /user/file/ endpoints. 1. If you want to search the world's released music, a good starting point is the GET /api/v1/public/recording/search endpoint. Please find the extensive list of parameters that serve as semantic search filters. 2. If you want to search your own previously uploaded music, a good starting point is the GET GET /api/v1/user/files endpoint. It has the same extensive list of parameters that serve as semantic search filters.
5
5
 
6
- The version of the OpenAPI document: 1.13.4
6
+ The version of the OpenAPI document: 1.13.6
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
9
  OpenAPI Generator version: 7.1.0-SNAPSHOT
@@ -18,12 +18,12 @@ module SongtradrApiClientRuby
18
18
  class ProductMediumDTO
19
19
  attr_accessor :duration
20
20
 
21
- attr_accessor :pline
22
-
23
21
  attr_accessor :genres
24
22
 
25
23
  attr_accessor :titles
26
24
 
25
+ attr_accessor :pline
26
+
27
27
  attr_accessor :gtin
28
28
 
29
29
  attr_accessor :grid
@@ -38,9 +38,9 @@ module SongtradrApiClientRuby
38
38
  def self.attribute_map
39
39
  {
40
40
  :'duration' => :'duration',
41
- :'pline' => :'pline',
42
41
  :'genres' => :'genres',
43
42
  :'titles' => :'titles',
43
+ :'pline' => :'pline',
44
44
  :'gtin' => :'gtin',
45
45
  :'grid' => :'grid',
46
46
  :'release_date' => :'releaseDate',
@@ -58,9 +58,9 @@ module SongtradrApiClientRuby
58
58
  def self.openapi_types
59
59
  {
60
60
  :'duration' => :'Time',
61
- :'pline' => :'PLineDTO',
62
61
  :'genres' => :'Array<GenreMinimalDTO>',
63
62
  :'titles' => :'Array<TitleDTO>',
63
+ :'pline' => :'PLineDTO',
64
64
  :'gtin' => :'String',
65
65
  :'grid' => :'String',
66
66
  :'release_date' => :'Time',
@@ -94,10 +94,6 @@ module SongtradrApiClientRuby
94
94
  self.duration = attributes[:'duration']
95
95
  end
96
96
 
97
- if attributes.key?(:'pline')
98
- self.pline = attributes[:'pline']
99
- end
100
-
101
97
  if attributes.key?(:'genres')
102
98
  if (value = attributes[:'genres']).is_a?(Array)
103
99
  self.genres = value
@@ -110,6 +106,10 @@ module SongtradrApiClientRuby
110
106
  end
111
107
  end
112
108
 
109
+ if attributes.key?(:'pline')
110
+ self.pline = attributes[:'pline']
111
+ end
112
+
113
113
  if attributes.key?(:'gtin')
114
114
  self.gtin = attributes[:'gtin']
115
115
  end
@@ -184,9 +184,9 @@ module SongtradrApiClientRuby
184
184
  return true if self.equal?(o)
185
185
  self.class == o.class &&
186
186
  duration == o.duration &&
187
- pline == o.pline &&
188
187
  genres == o.genres &&
189
188
  titles == o.titles &&
189
+ pline == o.pline &&
190
190
  gtin == o.gtin &&
191
191
  grid == o.grid &&
192
192
  release_date == o.release_date &&
@@ -203,7 +203,7 @@ module SongtradrApiClientRuby
203
203
  # Calculates hash code according to all attributes.
204
204
  # @return [Integer] Hash code
205
205
  def hash
206
- [duration, pline, genres, titles, gtin, grid, release_date, takedown_date, parties].hash
206
+ [duration, genres, titles, pline, gtin, grid, release_date, takedown_date, parties].hash
207
207
  end
208
208
 
209
209
  # Builds the object from hash
@@ -3,7 +3,7 @@
3
3
 
4
4
  #This is the Songtradr API. Use it to retrieve deep music metadata and trigger processes like auto-tagging. You can also use the API to manage your account and musicube cloud data. **Authentication** 1. Reach out to support@songtradr.com to receive a free account or use your login data if you are already signed up. 2. To authenticate, you need to login via the POST /api/v1/user/login endpoint. 3. The endpoint responds with a jwtToken which you can use in all following API requests as a bearer token. **Rate Limiting** The current limit is 120 Requests per minute. Reach out to us via support@songtradr.com if you need to request more. **Getting Started with auto-tagging** 1. If you want to get your own files auto-tagged, use the POST /api/v1/user/file/{name}/initUpload endpoint. It responds with a presigned S3 link where you can upload your file. 2. You can check the processing status of your file via the GET /api/v1/user/file/{name}/filesStatus endpoint. 3. As soon as processing is done, you can request the generated data via the GET /api/v1/user/files endpoint. **Getting Started with search** You can either search the released music via the /public/recording endpoints or your own private uploaded music via the /user/file/ endpoints. 1. If you want to search the world's released music, a good starting point is the GET /api/v1/public/recording/search endpoint. Please find the extensive list of parameters that serve as semantic search filters. 2. If you want to search your own previously uploaded music, a good starting point is the GET GET /api/v1/user/files endpoint. It has the same extensive list of parameters that serve as semantic search filters.
5
5
 
6
- The version of the OpenAPI document: 1.13.4
6
+ The version of the OpenAPI document: 1.13.6
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
9
  OpenAPI Generator version: 7.1.0-SNAPSHOT
@@ -16,15 +16,15 @@ require 'time'
16
16
  module SongtradrApiClientRuby
17
17
  # Parties (persons, groups or organizations) that have contributed to a product.
18
18
  class ProductPartyDTO
19
- attr_accessor :contributor_types
20
-
21
19
  attr_accessor :party
22
20
 
21
+ attr_accessor :contributor_types
22
+
23
23
  # Attribute mapping from ruby-style variable name to JSON key.
24
24
  def self.attribute_map
25
25
  {
26
- :'contributor_types' => :'contributorTypes',
27
- :'party' => :'party'
26
+ :'party' => :'party',
27
+ :'contributor_types' => :'contributorTypes'
28
28
  }
29
29
  end
30
30
 
@@ -36,8 +36,8 @@ module SongtradrApiClientRuby
36
36
  # Attribute type mapping.
37
37
  def self.openapi_types
38
38
  {
39
- :'contributor_types' => :'Array<ContributorTypeDTO>',
40
- :'party' => :'PartySmallDTO'
39
+ :'party' => :'PartySmallDTO',
40
+ :'contributor_types' => :'Array<ContributorTypeDTO>'
41
41
  }
42
42
  end
43
43
 
@@ -62,17 +62,17 @@ module SongtradrApiClientRuby
62
62
  h[k.to_sym] = v
63
63
  }
64
64
 
65
- if attributes.key?(:'contributor_types')
66
- if (value = attributes[:'contributor_types']).is_a?(Array)
67
- self.contributor_types = value
68
- end
69
- end
70
-
71
65
  if attributes.key?(:'party')
72
66
  self.party = attributes[:'party']
73
67
  else
74
68
  self.party = nil
75
69
  end
70
+
71
+ if attributes.key?(:'contributor_types')
72
+ if (value = attributes[:'contributor_types']).is_a?(Array)
73
+ self.contributor_types = value
74
+ end
75
+ end
76
76
  end
77
77
 
78
78
  # Show invalid properties with the reasons. Usually used together with valid?
@@ -100,8 +100,8 @@ module SongtradrApiClientRuby
100
100
  def ==(o)
101
101
  return true if self.equal?(o)
102
102
  self.class == o.class &&
103
- contributor_types == o.contributor_types &&
104
- party == o.party
103
+ party == o.party &&
104
+ contributor_types == o.contributor_types
105
105
  end
106
106
 
107
107
  # @see the `==` method
@@ -113,7 +113,7 @@ module SongtradrApiClientRuby
113
113
  # Calculates hash code according to all attributes.
114
114
  # @return [Integer] Hash code
115
115
  def hash
116
- [contributor_types, party].hash
116
+ [party, contributor_types].hash
117
117
  end
118
118
 
119
119
  # Builds the object from hash
@@ -3,7 +3,7 @@
3
3
 
4
4
  #This is the Songtradr API. Use it to retrieve deep music metadata and trigger processes like auto-tagging. You can also use the API to manage your account and musicube cloud data. **Authentication** 1. Reach out to support@songtradr.com to receive a free account or use your login data if you are already signed up. 2. To authenticate, you need to login via the POST /api/v1/user/login endpoint. 3. The endpoint responds with a jwtToken which you can use in all following API requests as a bearer token. **Rate Limiting** The current limit is 120 Requests per minute. Reach out to us via support@songtradr.com if you need to request more. **Getting Started with auto-tagging** 1. If you want to get your own files auto-tagged, use the POST /api/v1/user/file/{name}/initUpload endpoint. It responds with a presigned S3 link where you can upload your file. 2. You can check the processing status of your file via the GET /api/v1/user/file/{name}/filesStatus endpoint. 3. As soon as processing is done, you can request the generated data via the GET /api/v1/user/files endpoint. **Getting Started with search** You can either search the released music via the /public/recording endpoints or your own private uploaded music via the /user/file/ endpoints. 1. If you want to search the world's released music, a good starting point is the GET /api/v1/public/recording/search endpoint. Please find the extensive list of parameters that serve as semantic search filters. 2. If you want to search your own previously uploaded music, a good starting point is the GET GET /api/v1/user/files endpoint. It has the same extensive list of parameters that serve as semantic search filters.
5
5
 
6
- The version of the OpenAPI document: 1.13.4
6
+ The version of the OpenAPI document: 1.13.6
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
9
  OpenAPI Generator version: 7.1.0-SNAPSHOT
@@ -3,7 +3,7 @@
3
3
 
4
4
  #This is the Songtradr API. Use it to retrieve deep music metadata and trigger processes like auto-tagging. You can also use the API to manage your account and musicube cloud data. **Authentication** 1. Reach out to support@songtradr.com to receive a free account or use your login data if you are already signed up. 2. To authenticate, you need to login via the POST /api/v1/user/login endpoint. 3. The endpoint responds with a jwtToken which you can use in all following API requests as a bearer token. **Rate Limiting** The current limit is 120 Requests per minute. Reach out to us via support@songtradr.com if you need to request more. **Getting Started with auto-tagging** 1. If you want to get your own files auto-tagged, use the POST /api/v1/user/file/{name}/initUpload endpoint. It responds with a presigned S3 link where you can upload your file. 2. You can check the processing status of your file via the GET /api/v1/user/file/{name}/filesStatus endpoint. 3. As soon as processing is done, you can request the generated data via the GET /api/v1/user/files endpoint. **Getting Started with search** You can either search the released music via the /public/recording endpoints or your own private uploaded music via the /user/file/ endpoints. 1. If you want to search the world's released music, a good starting point is the GET /api/v1/public/recording/search endpoint. Please find the extensive list of parameters that serve as semantic search filters. 2. If you want to search your own previously uploaded music, a good starting point is the GET GET /api/v1/user/files endpoint. It has the same extensive list of parameters that serve as semantic search filters.
5
5
 
6
- The version of the OpenAPI document: 1.13.4
6
+ The version of the OpenAPI document: 1.13.6
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
9
  OpenAPI Generator version: 7.1.0-SNAPSHOT
@@ -16,18 +16,18 @@ require 'time'
16
16
  module SongtradrApiClientRuby
17
17
  # AI-predicted Genres for a recording
18
18
  class RecordingGenrePredictionDTO
19
+ attr_accessor :genre_type
20
+
19
21
  attr_accessor :genre
20
22
 
21
23
  attr_accessor :probability
22
24
 
23
- attr_accessor :genre_type
24
-
25
25
  # Attribute mapping from ruby-style variable name to JSON key.
26
26
  def self.attribute_map
27
27
  {
28
+ :'genre_type' => :'genreType',
28
29
  :'genre' => :'genre',
29
- :'probability' => :'probability',
30
- :'genre_type' => :'genreType'
30
+ :'probability' => :'probability'
31
31
  }
32
32
  end
33
33
 
@@ -39,9 +39,9 @@ module SongtradrApiClientRuby
39
39
  # Attribute type mapping.
40
40
  def self.openapi_types
41
41
  {
42
+ :'genre_type' => :'String',
42
43
  :'genre' => :'GenreMinimalDTO',
43
- :'probability' => :'Float',
44
- :'genre_type' => :'String'
44
+ :'probability' => :'Float'
45
45
  }
46
46
  end
47
47
 
@@ -66,6 +66,12 @@ module SongtradrApiClientRuby
66
66
  h[k.to_sym] = v
67
67
  }
68
68
 
69
+ if attributes.key?(:'genre_type')
70
+ self.genre_type = attributes[:'genre_type']
71
+ else
72
+ self.genre_type = nil
73
+ end
74
+
69
75
  if attributes.key?(:'genre')
70
76
  self.genre = attributes[:'genre']
71
77
  else
@@ -77,12 +83,6 @@ module SongtradrApiClientRuby
77
83
  else
78
84
  self.probability = nil
79
85
  end
80
-
81
- if attributes.key?(:'genre_type')
82
- self.genre_type = attributes[:'genre_type']
83
- else
84
- self.genre_type = nil
85
- end
86
86
  end
87
87
 
88
88
  # Show invalid properties with the reasons. Usually used together with valid?
@@ -90,6 +90,10 @@ module SongtradrApiClientRuby
90
90
  def list_invalid_properties
91
91
  warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
92
92
  invalid_properties = Array.new
93
+ if @genre_type.nil?
94
+ invalid_properties.push('invalid value for "genre_type", genre_type cannot be nil.')
95
+ end
96
+
93
97
  if @genre.nil?
94
98
  invalid_properties.push('invalid value for "genre", genre cannot be nil.')
95
99
  end
@@ -98,10 +102,6 @@ module SongtradrApiClientRuby
98
102
  invalid_properties.push('invalid value for "probability", probability cannot be nil.')
99
103
  end
100
104
 
101
- if @genre_type.nil?
102
- invalid_properties.push('invalid value for "genre_type", genre_type cannot be nil.')
103
- end
104
-
105
105
  invalid_properties
106
106
  end
107
107
 
@@ -109,9 +109,9 @@ module SongtradrApiClientRuby
109
109
  # @return true if the model is valid
110
110
  def valid?
111
111
  warn '[DEPRECATED] the `valid?` method is obsolete'
112
+ return false if @genre_type.nil?
112
113
  return false if @genre.nil?
113
114
  return false if @probability.nil?
114
- return false if @genre_type.nil?
115
115
  true
116
116
  end
117
117
 
@@ -120,9 +120,9 @@ module SongtradrApiClientRuby
120
120
  def ==(o)
121
121
  return true if self.equal?(o)
122
122
  self.class == o.class &&
123
+ genre_type == o.genre_type &&
123
124
  genre == o.genre &&
124
- probability == o.probability &&
125
- genre_type == o.genre_type
125
+ probability == o.probability
126
126
  end
127
127
 
128
128
  # @see the `==` method
@@ -134,7 +134,7 @@ module SongtradrApiClientRuby
134
134
  # Calculates hash code according to all attributes.
135
135
  # @return [Integer] Hash code
136
136
  def hash
137
- [genre, probability, genre_type].hash
137
+ [genre_type, genre, probability].hash
138
138
  end
139
139
 
140
140
  # Builds the object from hash