songtradr_api_client_ruby 1.13.3 → 1.13.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (279) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +3 -3
  3. data/README.md +48 -5
  4. data/docs/AdminApiCreateUserDTO.md +76 -0
  5. data/docs/AdminApiUpdateUserDTO.md +76 -0
  6. data/docs/AdminUsersControllerApi.md +355 -0
  7. data/docs/AgeRange.md +20 -0
  8. data/docs/Beard.md +20 -0
  9. data/docs/BoundingBox.md +24 -0
  10. data/docs/ContextValue.md +18 -0
  11. data/docs/CuratePlaylistDTO.md +26 -0
  12. data/docs/CuratePlaylistResponseDTO.md +18 -0
  13. data/docs/DominantColor.md +30 -0
  14. data/docs/Emotion.md +20 -0
  15. data/docs/EyeDirection.md +22 -0
  16. data/docs/EyeOpen.md +20 -0
  17. data/docs/Eyeglasses.md +20 -0
  18. data/docs/FaceDetail.md +50 -0
  19. data/docs/FaceDetection.md +20 -0
  20. data/docs/FaceOccluded.md +20 -0
  21. data/docs/FileSmallDTO.md +5 -5
  22. data/docs/Gender.md +20 -0
  23. data/docs/ImageQuality.md +20 -0
  24. data/docs/ImageRecognitionResponse.md +20 -0
  25. data/docs/Instance.md +22 -0
  26. data/docs/InternalApiApi.md +149 -0
  27. data/docs/Label.md +28 -0
  28. data/docs/LabelAlias.md +18 -0
  29. data/docs/LabelCategory.md +18 -0
  30. data/docs/LabelDetection.md +26 -0
  31. data/docs/Landmark.md +22 -0
  32. data/docs/MouthOpen.md +20 -0
  33. data/docs/MusicalFeaturesDTO.md +38 -38
  34. data/docs/Mustache.md +20 -0
  35. data/docs/Parent.md +18 -0
  36. data/docs/PlaylistApi.md +70 -0
  37. data/docs/PlaylistLargeDTO.md +5 -5
  38. data/docs/Pose.md +22 -0
  39. data/docs/ProductMediumDTO.md +3 -3
  40. data/docs/RecordingGenrePredictionDTO.md +4 -4
  41. data/docs/RecordingLargeDTO.md +5 -5
  42. data/docs/RecordingMediumDTO.md +2 -2
  43. data/docs/RecordingMinimalWithMusicalFeaturesDTO.md +3 -3
  44. data/docs/RecordingSmallDTO.md +3 -3
  45. data/docs/SaveFileDTO.md +42 -0
  46. data/docs/SaveFileRecordingDTO.md +5 -1
  47. data/docs/Smile.md +20 -0
  48. data/docs/Sunglasses.md +20 -0
  49. data/docs/UserApi.md +140 -0
  50. data/docs/VideoRecognitionResponse.md +20 -0
  51. data/lib/songtradr_api_client_ruby/api/admin_users_controller_api.rb +346 -0
  52. data/lib/songtradr_api_client_ruby/api/allowed_values_api.rb +2 -2
  53. data/lib/songtradr_api_client_ruby/api/api_keys_api.rb +2 -2
  54. data/lib/songtradr_api_client_ruby/api/internal_api_api.rb +169 -0
  55. data/lib/songtradr_api_client_ruby/api/party_api.rb +2 -2
  56. data/lib/songtradr_api_client_ruby/api/playlist_api.rb +79 -2
  57. data/lib/songtradr_api_client_ruby/api/recording_api.rb +2 -2
  58. data/lib/songtradr_api_client_ruby/api/user_api.rb +138 -2
  59. data/lib/songtradr_api_client_ruby/api_client.rb +4 -3
  60. data/lib/songtradr_api_client_ruby/api_error.rb +2 -2
  61. data/lib/songtradr_api_client_ruby/configuration.rb +3 -2
  62. data/lib/songtradr_api_client_ruby/models/admin_api_create_user_dto.rb +489 -0
  63. data/lib/songtradr_api_client_ruby/models/admin_api_update_user_dto.rb +475 -0
  64. data/lib/songtradr_api_client_ruby/models/admin_api_user_dto.rb +2 -2
  65. data/lib/songtradr_api_client_ruby/models/age_range.rb +223 -0
  66. data/lib/songtradr_api_client_ruby/models/api_key_dto.rb +2 -2
  67. data/lib/songtradr_api_client_ruby/models/beard.rb +223 -0
  68. data/lib/songtradr_api_client_ruby/models/bounding_box.rb +241 -0
  69. data/lib/songtradr_api_client_ruby/models/category_medium_dto.rb +2 -2
  70. data/lib/songtradr_api_client_ruby/models/category_minimal_dto.rb +2 -2
  71. data/lib/songtradr_api_client_ruby/models/config_access_dto.rb +2 -2
  72. data/lib/songtradr_api_client_ruby/models/config_identifier_dto.rb +2 -2
  73. data/lib/songtradr_api_client_ruby/models/context_value.rb +216 -0
  74. data/lib/songtradr_api_client_ruby/models/contributor_type_dto.rb +2 -2
  75. data/lib/songtradr_api_client_ruby/models/create_api_key_dto.rb +2 -2
  76. data/lib/songtradr_api_client_ruby/models/curate_playlist_dto.rb +256 -0
  77. data/lib/songtradr_api_client_ruby/models/curate_playlist_response_dto.rb +216 -0
  78. data/lib/songtradr_api_client_ruby/models/dominant_color.rb +268 -0
  79. data/lib/songtradr_api_client_ruby/models/emotion.rb +223 -0
  80. data/lib/songtradr_api_client_ruby/models/error_response.rb +2 -2
  81. data/lib/songtradr_api_client_ruby/models/eye_direction.rb +232 -0
  82. data/lib/songtradr_api_client_ruby/models/eye_open.rb +223 -0
  83. data/lib/songtradr_api_client_ruby/models/eyeglasses.rb +223 -0
  84. data/lib/songtradr_api_client_ruby/models/face_detail.rb +362 -0
  85. data/lib/songtradr_api_client_ruby/models/face_detection.rb +223 -0
  86. data/lib/songtradr_api_client_ruby/models/face_occluded.rb +223 -0
  87. data/lib/songtradr_api_client_ruby/models/field_summary_dto.rb +2 -2
  88. data/lib/songtradr_api_client_ruby/models/file_dto.rb +2 -2
  89. data/lib/songtradr_api_client_ruby/models/file_list_dto.rb +2 -2
  90. data/lib/songtradr_api_client_ruby/models/file_minimal_with_url_dto.rb +2 -2
  91. data/lib/songtradr_api_client_ruby/models/file_small_dto.rb +24 -24
  92. data/lib/songtradr_api_client_ruby/models/file_upload_dto.rb +2 -2
  93. data/lib/songtradr_api_client_ruby/models/file_w_ith_url_dto.rb +2 -2
  94. data/lib/songtradr_api_client_ruby/models/files_summary_dto.rb +2 -2
  95. data/lib/songtradr_api_client_ruby/models/forgot_password_dto.rb +2 -2
  96. data/lib/songtradr_api_client_ruby/models/gender.rb +223 -0
  97. data/lib/songtradr_api_client_ruby/models/genre_dto.rb +2 -2
  98. data/lib/songtradr_api_client_ruby/models/genre_minimal_dto.rb +2 -2
  99. data/lib/songtradr_api_client_ruby/models/genres_summary_dto.rb +2 -2
  100. data/lib/songtradr_api_client_ruby/models/image_quality.rb +223 -0
  101. data/lib/songtradr_api_client_ruby/models/image_recognition_response.rb +227 -0
  102. data/lib/songtradr_api_client_ruby/models/init_put_recording_audio_dto.rb +2 -2
  103. data/lib/songtradr_api_client_ruby/models/instance.rb +234 -0
  104. data/lib/songtradr_api_client_ruby/models/jwt_token_dto.rb +2 -2
  105. data/lib/songtradr_api_client_ruby/models/label.rb +267 -0
  106. data/lib/songtradr_api_client_ruby/models/label_alias.rb +214 -0
  107. data/lib/songtradr_api_client_ruby/models/label_category.rb +214 -0
  108. data/lib/songtradr_api_client_ruby/models/label_detection.rb +250 -0
  109. data/lib/songtradr_api_client_ruby/models/landmark.rb +232 -0
  110. data/lib/songtradr_api_client_ruby/models/login_dto.rb +2 -2
  111. data/lib/songtradr_api_client_ruby/models/mouth_open.rb +223 -0
  112. data/lib/songtradr_api_client_ruby/models/musical_features_dto.rb +285 -285
  113. data/lib/songtradr_api_client_ruby/models/mustache.rb +223 -0
  114. data/lib/songtradr_api_client_ruby/models/p_line_dto.rb +2 -2
  115. data/lib/songtradr_api_client_ruby/models/parent.rb +214 -0
  116. data/lib/songtradr_api_client_ruby/models/party_large_dto.rb +2 -2
  117. data/lib/songtradr_api_client_ruby/models/party_small_dto.rb +2 -2
  118. data/lib/songtradr_api_client_ruby/models/playlist_large_dto.rb +24 -24
  119. data/lib/songtradr_api_client_ruby/models/pose.rb +232 -0
  120. data/lib/songtradr_api_client_ruby/models/product_medium_dto.rb +15 -15
  121. data/lib/songtradr_api_client_ruby/models/product_party_dto.rb +2 -2
  122. data/lib/songtradr_api_client_ruby/models/recording_for_similarity_search_dto.rb +2 -2
  123. data/lib/songtradr_api_client_ruby/models/recording_genre_prediction_dto.rb +23 -23
  124. data/lib/songtradr_api_client_ruby/models/recording_large_dto.rb +26 -26
  125. data/lib/songtradr_api_client_ruby/models/recording_list_dto.rb +2 -2
  126. data/lib/songtradr_api_client_ruby/models/recording_medium_dto.rb +14 -14
  127. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_musical_features_dto.rb +17 -17
  128. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_taggrams_dto.rb +2 -2
  129. data/lib/songtradr_api_client_ruby/models/recording_minimal_with_tagstrengths_dto.rb +2 -2
  130. data/lib/songtradr_api_client_ruby/models/recording_party_dto.rb +2 -2
  131. data/lib/songtradr_api_client_ruby/models/recording_playlist_dto.rb +2 -2
  132. data/lib/songtradr_api_client_ruby/models/recording_small_dto.rb +17 -17
  133. data/lib/songtradr_api_client_ruby/models/recording_tag_small_dto.rb +2 -2
  134. data/lib/songtradr_api_client_ruby/models/save_file_dto.rb +323 -0
  135. data/lib/songtradr_api_client_ruby/models/save_file_recording_dto.rb +30 -12
  136. data/lib/songtradr_api_client_ruby/models/save_playlist_dto.rb +2 -2
  137. data/lib/songtradr_api_client_ruby/models/save_recording_genre_dto.rb +2 -2
  138. data/lib/songtradr_api_client_ruby/models/save_recording_party_dto.rb +2 -2
  139. data/lib/songtradr_api_client_ruby/models/save_recording_playlist_dto.rb +2 -2
  140. data/lib/songtradr_api_client_ruby/models/save_recording_tag_dto.rb +2 -2
  141. data/lib/songtradr_api_client_ruby/models/save_referrer_dto.rb +2 -2
  142. data/lib/songtradr_api_client_ruby/models/save_taggrams_dto.rb +2 -2
  143. data/lib/songtradr_api_client_ruby/models/save_user_dto.rb +2 -2
  144. data/lib/songtradr_api_client_ruby/models/search_filter_values_dto.rb +2 -2
  145. data/lib/songtradr_api_client_ruby/models/search_recording_granular_abstraction_dto.rb +2 -2
  146. data/lib/songtradr_api_client_ruby/models/search_recording_granular_dto.rb +2 -2
  147. data/lib/songtradr_api_client_ruby/models/sign_up_dto.rb +2 -2
  148. data/lib/songtradr_api_client_ruby/models/smile.rb +223 -0
  149. data/lib/songtradr_api_client_ruby/models/sunglasses.rb +223 -0
  150. data/lib/songtradr_api_client_ruby/models/tag_dto.rb +2 -2
  151. data/lib/songtradr_api_client_ruby/models/tag_small_dto.rb +2 -2
  152. data/lib/songtradr_api_client_ruby/models/taggram_dto.rb +2 -2
  153. data/lib/songtradr_api_client_ruby/models/tags_summary_dto.rb +2 -2
  154. data/lib/songtradr_api_client_ruby/models/tagstrength_dto.rb +2 -2
  155. data/lib/songtradr_api_client_ruby/models/title_dto.rb +2 -2
  156. data/lib/songtradr_api_client_ruby/models/token_request.rb +2 -2
  157. data/lib/songtradr_api_client_ruby/models/track_dto.rb +2 -2
  158. data/lib/songtradr_api_client_ruby/models/track_to_medium_product_dto.rb +2 -2
  159. data/lib/songtradr_api_client_ruby/models/update_password_dto.rb +2 -2
  160. data/lib/songtradr_api_client_ruby/models/usage_dto.rb +2 -2
  161. data/lib/songtradr_api_client_ruby/models/user_dto.rb +2 -2
  162. data/lib/songtradr_api_client_ruby/models/video_recognition_response.rb +227 -0
  163. data/lib/songtradr_api_client_ruby/version.rb +3 -3
  164. data/lib/songtradr_api_client_ruby.rb +37 -2
  165. data/openapi-generator-config.yaml +1 -1
  166. data/songtradr_api_client_ruby.gemspec +2 -2
  167. data/spec/api/admin_users_controller_api_spec.rb +93 -0
  168. data/spec/api/allowed_values_api_spec.rb +2 -2
  169. data/spec/api/api_keys_api_spec.rb +2 -2
  170. data/spec/api/internal_api_api_spec.rb +58 -0
  171. data/spec/api/party_api_spec.rb +2 -2
  172. data/spec/api/playlist_api_spec.rb +14 -2
  173. data/spec/api/recording_api_spec.rb +2 -2
  174. data/spec/api/user_api_spec.rb +26 -2
  175. data/spec/api_client_spec.rb +2 -2
  176. data/spec/configuration_spec.rb +2 -2
  177. data/spec/models/admin_api_create_user_dto_spec.rb +210 -0
  178. data/spec/models/admin_api_update_user_dto_spec.rb +210 -0
  179. data/spec/models/admin_api_user_dto_spec.rb +5 -3
  180. data/spec/models/age_range_spec.rb +42 -0
  181. data/spec/models/api_key_dto_spec.rb +5 -3
  182. data/spec/models/beard_spec.rb +42 -0
  183. data/spec/models/bounding_box_spec.rb +54 -0
  184. data/spec/models/category_medium_dto_spec.rb +5 -3
  185. data/spec/models/category_minimal_dto_spec.rb +5 -3
  186. data/spec/models/config_access_dto_spec.rb +5 -3
  187. data/spec/models/config_identifier_dto_spec.rb +5 -3
  188. data/spec/models/context_value_spec.rb +36 -0
  189. data/spec/models/contributor_type_dto_spec.rb +5 -3
  190. data/spec/models/create_api_key_dto_spec.rb +5 -3
  191. data/spec/models/curate_playlist_dto_spec.rb +60 -0
  192. data/spec/models/curate_playlist_response_dto_spec.rb +36 -0
  193. data/spec/models/dominant_color_spec.rb +72 -0
  194. data/spec/models/emotion_spec.rb +42 -0
  195. data/spec/models/error_response_spec.rb +5 -3
  196. data/spec/models/eye_direction_spec.rb +48 -0
  197. data/spec/models/eye_open_spec.rb +42 -0
  198. data/spec/models/eyeglasses_spec.rb +42 -0
  199. data/spec/models/face_detail_spec.rb +132 -0
  200. data/spec/models/face_detection_spec.rb +42 -0
  201. data/spec/models/face_occluded_spec.rb +42 -0
  202. data/spec/models/field_summary_dto_spec.rb +5 -3
  203. data/spec/models/file_dto_spec.rb +5 -3
  204. data/spec/models/file_list_dto_spec.rb +5 -3
  205. data/spec/models/file_minimal_with_url_dto_spec.rb +5 -3
  206. data/spec/models/file_small_dto_spec.rb +17 -15
  207. data/spec/models/file_upload_dto_spec.rb +5 -3
  208. data/spec/models/file_w_ith_url_dto_spec.rb +5 -3
  209. data/spec/models/files_summary_dto_spec.rb +5 -3
  210. data/spec/models/forgot_password_dto_spec.rb +5 -3
  211. data/spec/models/gender_spec.rb +42 -0
  212. data/spec/models/genre_dto_spec.rb +5 -3
  213. data/spec/models/genre_minimal_dto_spec.rb +5 -3
  214. data/spec/models/genres_summary_dto_spec.rb +5 -3
  215. data/spec/models/image_quality_spec.rb +42 -0
  216. data/spec/models/image_recognition_response_spec.rb +42 -0
  217. data/spec/models/init_put_recording_audio_dto_spec.rb +5 -3
  218. data/spec/models/instance_spec.rb +48 -0
  219. data/spec/models/jwt_token_dto_spec.rb +5 -3
  220. data/spec/models/label_alias_spec.rb +36 -0
  221. data/spec/models/label_category_spec.rb +36 -0
  222. data/spec/models/label_detection_spec.rb +60 -0
  223. data/spec/models/label_spec.rb +66 -0
  224. data/spec/models/landmark_spec.rb +48 -0
  225. data/spec/models/login_dto_spec.rb +5 -3
  226. data/spec/models/mouth_open_spec.rb +42 -0
  227. data/spec/models/musical_features_dto_spec.rb +114 -112
  228. data/spec/models/mustache_spec.rb +42 -0
  229. data/spec/models/p_line_dto_spec.rb +5 -3
  230. data/spec/models/parent_spec.rb +36 -0
  231. data/spec/models/party_large_dto_spec.rb +5 -3
  232. data/spec/models/party_small_dto_spec.rb +5 -3
  233. data/spec/models/playlist_large_dto_spec.rb +14 -12
  234. data/spec/models/pose_spec.rb +48 -0
  235. data/spec/models/product_medium_dto_spec.rb +11 -9
  236. data/spec/models/product_party_dto_spec.rb +5 -3
  237. data/spec/models/recording_for_similarity_search_dto_spec.rb +5 -3
  238. data/spec/models/recording_genre_prediction_dto_spec.rb +7 -5
  239. data/spec/models/recording_large_dto_spec.rb +13 -11
  240. data/spec/models/recording_list_dto_spec.rb +5 -3
  241. data/spec/models/recording_medium_dto_spec.rb +10 -8
  242. data/spec/models/recording_minimal_with_musical_features_dto_spec.rb +7 -5
  243. data/spec/models/recording_minimal_with_taggrams_dto_spec.rb +5 -3
  244. data/spec/models/recording_minimal_with_tagstrengths_dto_spec.rb +5 -3
  245. data/spec/models/recording_party_dto_spec.rb +5 -3
  246. data/spec/models/recording_playlist_dto_spec.rb +5 -3
  247. data/spec/models/recording_small_dto_spec.rb +8 -6
  248. data/spec/models/recording_tag_small_dto_spec.rb +5 -3
  249. data/spec/models/save_file_dto_spec.rb +108 -0
  250. data/spec/models/save_file_recording_dto_spec.rb +20 -6
  251. data/spec/models/save_playlist_dto_spec.rb +5 -3
  252. data/spec/models/save_recording_genre_dto_spec.rb +5 -3
  253. data/spec/models/save_recording_party_dto_spec.rb +5 -3
  254. data/spec/models/save_recording_playlist_dto_spec.rb +5 -3
  255. data/spec/models/save_recording_tag_dto_spec.rb +5 -3
  256. data/spec/models/save_referrer_dto_spec.rb +5 -3
  257. data/spec/models/save_taggrams_dto_spec.rb +5 -3
  258. data/spec/models/save_user_dto_spec.rb +5 -3
  259. data/spec/models/search_filter_values_dto_spec.rb +5 -3
  260. data/spec/models/search_recording_granular_abstraction_dto_spec.rb +5 -3
  261. data/spec/models/search_recording_granular_dto_spec.rb +5 -3
  262. data/spec/models/sign_up_dto_spec.rb +5 -3
  263. data/spec/models/smile_spec.rb +42 -0
  264. data/spec/models/sunglasses_spec.rb +42 -0
  265. data/spec/models/tag_dto_spec.rb +5 -3
  266. data/spec/models/tag_small_dto_spec.rb +5 -3
  267. data/spec/models/taggram_dto_spec.rb +5 -3
  268. data/spec/models/tags_summary_dto_spec.rb +5 -3
  269. data/spec/models/tagstrength_dto_spec.rb +5 -3
  270. data/spec/models/title_dto_spec.rb +5 -3
  271. data/spec/models/token_request_spec.rb +5 -3
  272. data/spec/models/track_dto_spec.rb +5 -3
  273. data/spec/models/track_to_medium_product_dto_spec.rb +5 -3
  274. data/spec/models/update_password_dto_spec.rb +5 -3
  275. data/spec/models/usage_dto_spec.rb +5 -3
  276. data/spec/models/user_dto_spec.rb +5 -3
  277. data/spec/models/video_recognition_response_spec.rb +42 -0
  278. data/spec/spec_helper.rb +2 -2
  279. metadata +201 -61
@@ -0,0 +1,227 @@
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.5
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 ImageRecognitionResponse
18
+ attr_accessor :labels
19
+
20
+ attr_accessor :faces
21
+
22
+ # Attribute mapping from ruby-style variable name to JSON key.
23
+ def self.attribute_map
24
+ {
25
+ :'labels' => :'labels',
26
+ :'faces' => :'faces'
27
+ }
28
+ end
29
+
30
+ # Returns all the JSON keys this model knows about
31
+ def self.acceptable_attributes
32
+ attribute_map.values
33
+ end
34
+
35
+ # Attribute type mapping.
36
+ def self.openapi_types
37
+ {
38
+ :'labels' => :'Array<Label>',
39
+ :'faces' => :'Array<FaceDetail>'
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 `SongtradrApiClientRuby::ImageRecognitionResponse` 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 `SongtradrApiClientRuby::ImageRecognitionResponse`. 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?(:'labels')
65
+ if (value = attributes[:'labels']).is_a?(Array)
66
+ self.labels = value
67
+ end
68
+ end
69
+
70
+ if attributes.key?(:'faces')
71
+ if (value = attributes[:'faces']).is_a?(Array)
72
+ self.faces = value
73
+ end
74
+ end
75
+ end
76
+
77
+ # Show invalid properties with the reasons. Usually used together with valid?
78
+ # @return Array for valid properties with the reasons
79
+ def list_invalid_properties
80
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
81
+ invalid_properties = Array.new
82
+ invalid_properties
83
+ end
84
+
85
+ # Check to see if the all the properties in the model are valid
86
+ # @return true if the model is valid
87
+ def valid?
88
+ warn '[DEPRECATED] the `valid?` method is obsolete'
89
+ true
90
+ end
91
+
92
+ # Checks equality by comparing each attribute.
93
+ # @param [Object] Object to be compared
94
+ def ==(o)
95
+ return true if self.equal?(o)
96
+ self.class == o.class &&
97
+ labels == o.labels &&
98
+ faces == o.faces
99
+ end
100
+
101
+ # @see the `==` method
102
+ # @param [Object] Object to be compared
103
+ def eql?(o)
104
+ self == o
105
+ end
106
+
107
+ # Calculates hash code according to all attributes.
108
+ # @return [Integer] Hash code
109
+ def hash
110
+ [labels, faces].hash
111
+ end
112
+
113
+ # Builds the object from hash
114
+ # @param [Hash] attributes Model attributes in the form of hash
115
+ # @return [Object] Returns the model itself
116
+ def self.build_from_hash(attributes)
117
+ return nil unless attributes.is_a?(Hash)
118
+ attributes = attributes.transform_keys(&:to_sym)
119
+ transformed_hash = {}
120
+ openapi_types.each_pair do |key, type|
121
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
122
+ transformed_hash["#{key}"] = nil
123
+ elsif type =~ /\AArray<(.*)>/i
124
+ # check to ensure the input is an array given that the attribute
125
+ # is documented as an array but the input is not
126
+ if attributes[attribute_map[key]].is_a?(Array)
127
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
128
+ end
129
+ elsif !attributes[attribute_map[key]].nil?
130
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
131
+ end
132
+ end
133
+ new(transformed_hash)
134
+ end
135
+
136
+ # Deserializes the data based on type
137
+ # @param string type Data type
138
+ # @param string value Value to be deserialized
139
+ # @return [Object] Deserialized data
140
+ def self._deserialize(type, value)
141
+ case type.to_sym
142
+ when :Time
143
+ Time.parse(value)
144
+ when :Date
145
+ Date.parse(value)
146
+ when :String
147
+ value.to_s
148
+ when :Integer
149
+ value.to_i
150
+ when :Float
151
+ value.to_f
152
+ when :Boolean
153
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
154
+ true
155
+ else
156
+ false
157
+ end
158
+ when :Object
159
+ # generic object (usually a Hash), return directly
160
+ value
161
+ when /\AArray<(?<inner_type>.+)>\z/
162
+ inner_type = Regexp.last_match[:inner_type]
163
+ value.map { |v| _deserialize(inner_type, v) }
164
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
165
+ k_type = Regexp.last_match[:k_type]
166
+ v_type = Regexp.last_match[:v_type]
167
+ {}.tap do |hash|
168
+ value.each do |k, v|
169
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
170
+ end
171
+ end
172
+ else # model
173
+ # models (e.g. Pet) or oneOf
174
+ klass = SongtradrApiClientRuby.const_get(type)
175
+ klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.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
+ if value.nil?
198
+ is_nullable = self.class.openapi_nullable.include?(attr)
199
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
200
+ end
201
+
202
+ hash[param] = _to_hash(value)
203
+ end
204
+ hash
205
+ end
206
+
207
+ # Outputs non-array value in the form of hash
208
+ # For object, use to_hash. Otherwise, just return the value
209
+ # @param [Object] value Any valid value
210
+ # @return [Hash] Returns the value in the form of hash
211
+ def _to_hash(value)
212
+ if value.is_a?(Array)
213
+ value.compact.map { |v| _to_hash(v) }
214
+ elsif value.is_a?(Hash)
215
+ {}.tap do |hash|
216
+ value.each { |k, v| hash[k] = _to_hash(v) }
217
+ end
218
+ elsif value.respond_to? :to_hash
219
+ value.to_hash
220
+ else
221
+ value
222
+ end
223
+ end
224
+
225
+ end
226
+
227
+ end
@@ -3,10 +3,10 @@
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.3
6
+ The version of the OpenAPI document: 1.13.5
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
- OpenAPI Generator version: 7.0.1-SNAPSHOT
9
+ OpenAPI Generator version: 7.1.0-SNAPSHOT
10
10
 
11
11
  =end
12
12
 
@@ -0,0 +1,234 @@
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.5
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 Instance
18
+ attr_accessor :bounding_box
19
+
20
+ attr_accessor :confidence
21
+
22
+ attr_accessor :dominant_colors
23
+
24
+ # Attribute mapping from ruby-style variable name to JSON key.
25
+ def self.attribute_map
26
+ {
27
+ :'bounding_box' => :'boundingBox',
28
+ :'confidence' => :'confidence',
29
+ :'dominant_colors' => :'dominantColors'
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
+ :'bounding_box' => :'BoundingBox',
42
+ :'confidence' => :'Float',
43
+ :'dominant_colors' => :'Array<DominantColor>'
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::Instance` 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::Instance`. 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?(:'bounding_box')
69
+ self.bounding_box = attributes[:'bounding_box']
70
+ end
71
+
72
+ if attributes.key?(:'confidence')
73
+ self.confidence = attributes[:'confidence']
74
+ end
75
+
76
+ if attributes.key?(:'dominant_colors')
77
+ if (value = attributes[:'dominant_colors']).is_a?(Array)
78
+ self.dominant_colors = value
79
+ end
80
+ end
81
+ end
82
+
83
+ # Show invalid properties with the reasons. Usually used together with valid?
84
+ # @return Array for valid properties with the reasons
85
+ def list_invalid_properties
86
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
87
+ invalid_properties = Array.new
88
+ invalid_properties
89
+ end
90
+
91
+ # Check to see if the all the properties in the model are valid
92
+ # @return true if the model is valid
93
+ def valid?
94
+ warn '[DEPRECATED] the `valid?` method is obsolete'
95
+ true
96
+ end
97
+
98
+ # Checks equality by comparing each attribute.
99
+ # @param [Object] Object to be compared
100
+ def ==(o)
101
+ return true if self.equal?(o)
102
+ self.class == o.class &&
103
+ bounding_box == o.bounding_box &&
104
+ confidence == o.confidence &&
105
+ dominant_colors == o.dominant_colors
106
+ end
107
+
108
+ # @see the `==` method
109
+ # @param [Object] Object to be compared
110
+ def eql?(o)
111
+ self == o
112
+ end
113
+
114
+ # Calculates hash code according to all attributes.
115
+ # @return [Integer] Hash code
116
+ def hash
117
+ [bounding_box, confidence, dominant_colors].hash
118
+ end
119
+
120
+ # Builds the object from hash
121
+ # @param [Hash] attributes Model attributes in the form of hash
122
+ # @return [Object] Returns the model itself
123
+ def self.build_from_hash(attributes)
124
+ return nil unless attributes.is_a?(Hash)
125
+ attributes = attributes.transform_keys(&:to_sym)
126
+ transformed_hash = {}
127
+ openapi_types.each_pair do |key, type|
128
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
129
+ transformed_hash["#{key}"] = nil
130
+ elsif type =~ /\AArray<(.*)>/i
131
+ # check to ensure the input is an array given that the attribute
132
+ # is documented as an array but the input is not
133
+ if attributes[attribute_map[key]].is_a?(Array)
134
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
135
+ end
136
+ elsif !attributes[attribute_map[key]].nil?
137
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
138
+ end
139
+ end
140
+ new(transformed_hash)
141
+ end
142
+
143
+ # Deserializes the data based on type
144
+ # @param string type Data type
145
+ # @param string value Value to be deserialized
146
+ # @return [Object] Deserialized data
147
+ def self._deserialize(type, value)
148
+ case type.to_sym
149
+ when :Time
150
+ Time.parse(value)
151
+ when :Date
152
+ Date.parse(value)
153
+ when :String
154
+ value.to_s
155
+ when :Integer
156
+ value.to_i
157
+ when :Float
158
+ value.to_f
159
+ when :Boolean
160
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
161
+ true
162
+ else
163
+ false
164
+ end
165
+ when :Object
166
+ # generic object (usually a Hash), return directly
167
+ value
168
+ when /\AArray<(?<inner_type>.+)>\z/
169
+ inner_type = Regexp.last_match[:inner_type]
170
+ value.map { |v| _deserialize(inner_type, v) }
171
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
172
+ k_type = Regexp.last_match[:k_type]
173
+ v_type = Regexp.last_match[:v_type]
174
+ {}.tap do |hash|
175
+ value.each do |k, v|
176
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
177
+ end
178
+ end
179
+ else # model
180
+ # models (e.g. Pet) or oneOf
181
+ klass = SongtradrApiClientRuby.const_get(type)
182
+ klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
183
+ end
184
+ end
185
+
186
+ # Returns the string representation of the object
187
+ # @return [String] String presentation of the object
188
+ def to_s
189
+ to_hash.to_s
190
+ end
191
+
192
+ # to_body is an alias to to_hash (backward compatibility)
193
+ # @return [Hash] Returns the object in the form of hash
194
+ def to_body
195
+ to_hash
196
+ end
197
+
198
+ # Returns the object in the form of hash
199
+ # @return [Hash] Returns the object in the form of hash
200
+ def to_hash
201
+ hash = {}
202
+ self.class.attribute_map.each_pair do |attr, param|
203
+ value = self.send(attr)
204
+ if value.nil?
205
+ is_nullable = self.class.openapi_nullable.include?(attr)
206
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
207
+ end
208
+
209
+ hash[param] = _to_hash(value)
210
+ end
211
+ hash
212
+ end
213
+
214
+ # Outputs non-array value in the form of hash
215
+ # For object, use to_hash. Otherwise, just return the value
216
+ # @param [Object] value Any valid value
217
+ # @return [Hash] Returns the value in the form of hash
218
+ def _to_hash(value)
219
+ if value.is_a?(Array)
220
+ value.compact.map { |v| _to_hash(v) }
221
+ elsif value.is_a?(Hash)
222
+ {}.tap do |hash|
223
+ value.each { |k, v| hash[k] = _to_hash(v) }
224
+ end
225
+ elsif value.respond_to? :to_hash
226
+ value.to_hash
227
+ else
228
+ value
229
+ end
230
+ end
231
+
232
+ end
233
+
234
+ end
@@ -3,10 +3,10 @@
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.3
6
+ The version of the OpenAPI document: 1.13.5
7
7
  Contact: info@songtradr.com
8
8
  Generated by: https://openapi-generator.tech
9
- OpenAPI Generator version: 7.0.1-SNAPSHOT
9
+ OpenAPI Generator version: 7.1.0-SNAPSHOT
10
10
 
11
11
  =end
12
12