songtradr_api_client_ruby 1.13.4 → 1.13.6

Sign up to get free protection for your applications and to get access to all the features.
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,250 @@
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 LabelDetection
18
+ attr_accessor :timestamp
19
+
20
+ attr_accessor :label
21
+
22
+ attr_accessor :start_timestamp_millis
23
+
24
+ attr_accessor :end_timestamp_millis
25
+
26
+ attr_accessor :duration_millis
27
+
28
+ # Attribute mapping from ruby-style variable name to JSON key.
29
+ def self.attribute_map
30
+ {
31
+ :'timestamp' => :'timestamp',
32
+ :'label' => :'label',
33
+ :'start_timestamp_millis' => :'startTimestampMillis',
34
+ :'end_timestamp_millis' => :'endTimestampMillis',
35
+ :'duration_millis' => :'durationMillis'
36
+ }
37
+ end
38
+
39
+ # Returns all the JSON keys this model knows about
40
+ def self.acceptable_attributes
41
+ attribute_map.values
42
+ end
43
+
44
+ # Attribute type mapping.
45
+ def self.openapi_types
46
+ {
47
+ :'timestamp' => :'Integer',
48
+ :'label' => :'Label',
49
+ :'start_timestamp_millis' => :'Integer',
50
+ :'end_timestamp_millis' => :'Integer',
51
+ :'duration_millis' => :'Integer'
52
+ }
53
+ end
54
+
55
+ # List of attributes with nullable: true
56
+ def self.openapi_nullable
57
+ Set.new([
58
+ ])
59
+ end
60
+
61
+ # Initializes the object
62
+ # @param [Hash] attributes Model attributes in the form of hash
63
+ def initialize(attributes = {})
64
+ if (!attributes.is_a?(Hash))
65
+ fail ArgumentError, "The input argument (attributes) must be a hash in `SongtradrApiClientRuby::LabelDetection` initialize method"
66
+ end
67
+
68
+ # check to see if the attribute exists and convert string to symbol for hash key
69
+ attributes = attributes.each_with_object({}) { |(k, v), h|
70
+ if (!self.class.attribute_map.key?(k.to_sym))
71
+ fail ArgumentError, "`#{k}` is not a valid attribute in `SongtradrApiClientRuby::LabelDetection`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
72
+ end
73
+ h[k.to_sym] = v
74
+ }
75
+
76
+ if attributes.key?(:'timestamp')
77
+ self.timestamp = attributes[:'timestamp']
78
+ end
79
+
80
+ if attributes.key?(:'label')
81
+ self.label = attributes[:'label']
82
+ end
83
+
84
+ if attributes.key?(:'start_timestamp_millis')
85
+ self.start_timestamp_millis = attributes[:'start_timestamp_millis']
86
+ end
87
+
88
+ if attributes.key?(:'end_timestamp_millis')
89
+ self.end_timestamp_millis = attributes[:'end_timestamp_millis']
90
+ end
91
+
92
+ if attributes.key?(:'duration_millis')
93
+ self.duration_millis = attributes[:'duration_millis']
94
+ end
95
+ end
96
+
97
+ # Show invalid properties with the reasons. Usually used together with valid?
98
+ # @return Array for valid properties with the reasons
99
+ def list_invalid_properties
100
+ warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
101
+ invalid_properties = Array.new
102
+ invalid_properties
103
+ end
104
+
105
+ # Check to see if the all the properties in the model are valid
106
+ # @return true if the model is valid
107
+ def valid?
108
+ warn '[DEPRECATED] the `valid?` method is obsolete'
109
+ true
110
+ end
111
+
112
+ # Checks equality by comparing each attribute.
113
+ # @param [Object] Object to be compared
114
+ def ==(o)
115
+ return true if self.equal?(o)
116
+ self.class == o.class &&
117
+ timestamp == o.timestamp &&
118
+ label == o.label &&
119
+ start_timestamp_millis == o.start_timestamp_millis &&
120
+ end_timestamp_millis == o.end_timestamp_millis &&
121
+ duration_millis == o.duration_millis
122
+ end
123
+
124
+ # @see the `==` method
125
+ # @param [Object] Object to be compared
126
+ def eql?(o)
127
+ self == o
128
+ end
129
+
130
+ # Calculates hash code according to all attributes.
131
+ # @return [Integer] Hash code
132
+ def hash
133
+ [timestamp, label, start_timestamp_millis, end_timestamp_millis, duration_millis].hash
134
+ end
135
+
136
+ # Builds the object from hash
137
+ # @param [Hash] attributes Model attributes in the form of hash
138
+ # @return [Object] Returns the model itself
139
+ def self.build_from_hash(attributes)
140
+ return nil unless attributes.is_a?(Hash)
141
+ attributes = attributes.transform_keys(&:to_sym)
142
+ transformed_hash = {}
143
+ openapi_types.each_pair do |key, type|
144
+ if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
145
+ transformed_hash["#{key}"] = nil
146
+ elsif type =~ /\AArray<(.*)>/i
147
+ # check to ensure the input is an array given that the attribute
148
+ # is documented as an array but the input is not
149
+ if attributes[attribute_map[key]].is_a?(Array)
150
+ transformed_hash["#{key}"] = attributes[attribute_map[key]].map { |v| _deserialize($1, v) }
151
+ end
152
+ elsif !attributes[attribute_map[key]].nil?
153
+ transformed_hash["#{key}"] = _deserialize(type, attributes[attribute_map[key]])
154
+ end
155
+ end
156
+ new(transformed_hash)
157
+ end
158
+
159
+ # Deserializes the data based on type
160
+ # @param string type Data type
161
+ # @param string value Value to be deserialized
162
+ # @return [Object] Deserialized data
163
+ def self._deserialize(type, value)
164
+ case type.to_sym
165
+ when :Time
166
+ Time.parse(value)
167
+ when :Date
168
+ Date.parse(value)
169
+ when :String
170
+ value.to_s
171
+ when :Integer
172
+ value.to_i
173
+ when :Float
174
+ value.to_f
175
+ when :Boolean
176
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
177
+ true
178
+ else
179
+ false
180
+ end
181
+ when :Object
182
+ # generic object (usually a Hash), return directly
183
+ value
184
+ when /\AArray<(?<inner_type>.+)>\z/
185
+ inner_type = Regexp.last_match[:inner_type]
186
+ value.map { |v| _deserialize(inner_type, v) }
187
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
188
+ k_type = Regexp.last_match[:k_type]
189
+ v_type = Regexp.last_match[:v_type]
190
+ {}.tap do |hash|
191
+ value.each do |k, v|
192
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
193
+ end
194
+ end
195
+ else # model
196
+ # models (e.g. Pet) or oneOf
197
+ klass = SongtradrApiClientRuby.const_get(type)
198
+ klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass.build_from_hash(value)
199
+ end
200
+ end
201
+
202
+ # Returns the string representation of the object
203
+ # @return [String] String presentation of the object
204
+ def to_s
205
+ to_hash.to_s
206
+ end
207
+
208
+ # to_body is an alias to to_hash (backward compatibility)
209
+ # @return [Hash] Returns the object in the form of hash
210
+ def to_body
211
+ to_hash
212
+ end
213
+
214
+ # Returns the object in the form of hash
215
+ # @return [Hash] Returns the object in the form of hash
216
+ def to_hash
217
+ hash = {}
218
+ self.class.attribute_map.each_pair do |attr, param|
219
+ value = self.send(attr)
220
+ if value.nil?
221
+ is_nullable = self.class.openapi_nullable.include?(attr)
222
+ next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
223
+ end
224
+
225
+ hash[param] = _to_hash(value)
226
+ end
227
+ hash
228
+ end
229
+
230
+ # Outputs non-array value in the form of hash
231
+ # For object, use to_hash. Otherwise, just return the value
232
+ # @param [Object] value Any valid value
233
+ # @return [Hash] Returns the value in the form of hash
234
+ def _to_hash(value)
235
+ if value.is_a?(Array)
236
+ value.compact.map { |v| _to_hash(v) }
237
+ elsif value.is_a?(Hash)
238
+ {}.tap do |hash|
239
+ value.each { |k, v| hash[k] = _to_hash(v) }
240
+ end
241
+ elsif value.respond_to? :to_hash
242
+ value.to_hash
243
+ else
244
+ value
245
+ end
246
+ end
247
+
248
+ end
249
+
250
+ end
@@ -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 Landmark
18
+ attr_accessor :type
19
+
20
+ attr_accessor :x
21
+
22
+ attr_accessor :y
23
+
24
+ # Attribute mapping from ruby-style variable name to JSON key.
25
+ def self.attribute_map
26
+ {
27
+ :'type' => :'type',
28
+ :'x' => :'x',
29
+ :'y' => :'y'
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
+ :'type' => :'String',
42
+ :'x' => :'Float',
43
+ :'y' => :'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::Landmark` 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::Landmark`. 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?(:'type')
69
+ self.type = attributes[:'type']
70
+ end
71
+
72
+ if attributes.key?(:'x')
73
+ self.x = attributes[:'x']
74
+ end
75
+
76
+ if attributes.key?(:'y')
77
+ self.y = attributes[:'y']
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
+ type == o.type &&
102
+ x == o.x &&
103
+ y == o.y
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
+ [type, x, y].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
@@ -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
@@ -14,22 +14,16 @@ require 'date'
14
14
  require 'time'
15
15
 
16
16
  module SongtradrApiClientRuby
17
- class ApiKeyDTO
18
- attr_accessor :name
17
+ class MouthOpen
18
+ attr_accessor :value
19
19
 
20
- attr_accessor :id
21
-
22
- attr_accessor :last_used_at
23
-
24
- attr_accessor :created_at
20
+ attr_accessor :confidence
25
21
 
26
22
  # Attribute mapping from ruby-style variable name to JSON key.
27
23
  def self.attribute_map
28
24
  {
29
- :'name' => :'name',
30
- :'id' => :'id',
31
- :'last_used_at' => :'lastUsedAt',
32
- :'created_at' => :'createdAt'
25
+ :'value' => :'value',
26
+ :'confidence' => :'confidence'
33
27
  }
34
28
  end
35
29
 
@@ -41,10 +35,8 @@ module SongtradrApiClientRuby
41
35
  # Attribute type mapping.
42
36
  def self.openapi_types
43
37
  {
44
- :'name' => :'String',
45
- :'id' => :'String',
46
- :'last_used_at' => :'Time',
47
- :'created_at' => :'Time'
38
+ :'value' => :'Boolean',
39
+ :'confidence' => :'Float'
48
40
  }
49
41
  end
50
42
 
@@ -58,37 +50,23 @@ module SongtradrApiClientRuby
58
50
  # @param [Hash] attributes Model attributes in the form of hash
59
51
  def initialize(attributes = {})
60
52
  if (!attributes.is_a?(Hash))
61
- fail ArgumentError, "The input argument (attributes) must be a hash in `SongtradrApiClientRuby::ApiKeyDTO` initialize method"
53
+ fail ArgumentError, "The input argument (attributes) must be a hash in `SongtradrApiClientRuby::MouthOpen` initialize method"
62
54
  end
63
55
 
64
56
  # check to see if the attribute exists and convert string to symbol for hash key
65
57
  attributes = attributes.each_with_object({}) { |(k, v), h|
66
58
  if (!self.class.attribute_map.key?(k.to_sym))
67
- fail ArgumentError, "`#{k}` is not a valid attribute in `SongtradrApiClientRuby::ApiKeyDTO`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
59
+ fail ArgumentError, "`#{k}` is not a valid attribute in `SongtradrApiClientRuby::MouthOpen`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
68
60
  end
69
61
  h[k.to_sym] = v
70
62
  }
71
63
 
72
- if attributes.key?(:'name')
73
- self.name = attributes[:'name']
74
- else
75
- self.name = nil
76
- end
77
-
78
- if attributes.key?(:'id')
79
- self.id = attributes[:'id']
80
- else
81
- self.id = nil
64
+ if attributes.key?(:'value')
65
+ self.value = attributes[:'value']
82
66
  end
83
67
 
84
- if attributes.key?(:'last_used_at')
85
- self.last_used_at = attributes[:'last_used_at']
86
- end
87
-
88
- if attributes.key?(:'created_at')
89
- self.created_at = attributes[:'created_at']
90
- else
91
- self.created_at = nil
68
+ if attributes.key?(:'confidence')
69
+ self.confidence = attributes[:'confidence']
92
70
  end
93
71
  end
94
72
 
@@ -97,18 +75,6 @@ module SongtradrApiClientRuby
97
75
  def list_invalid_properties
98
76
  warn '[DEPRECATED] the `list_invalid_properties` method is obsolete'
99
77
  invalid_properties = Array.new
100
- if @name.nil?
101
- invalid_properties.push('invalid value for "name", name cannot be nil.')
102
- end
103
-
104
- if @id.nil?
105
- invalid_properties.push('invalid value for "id", id cannot be nil.')
106
- end
107
-
108
- if @created_at.nil?
109
- invalid_properties.push('invalid value for "created_at", created_at cannot be nil.')
110
- end
111
-
112
78
  invalid_properties
113
79
  end
114
80
 
@@ -116,9 +82,6 @@ module SongtradrApiClientRuby
116
82
  # @return true if the model is valid
117
83
  def valid?
118
84
  warn '[DEPRECATED] the `valid?` method is obsolete'
119
- return false if @name.nil?
120
- return false if @id.nil?
121
- return false if @created_at.nil?
122
85
  true
123
86
  end
124
87
 
@@ -127,10 +90,8 @@ module SongtradrApiClientRuby
127
90
  def ==(o)
128
91
  return true if self.equal?(o)
129
92
  self.class == o.class &&
130
- name == o.name &&
131
- id == o.id &&
132
- last_used_at == o.last_used_at &&
133
- created_at == o.created_at
93
+ value == o.value &&
94
+ confidence == o.confidence
134
95
  end
135
96
 
136
97
  # @see the `==` method
@@ -142,7 +103,7 @@ module SongtradrApiClientRuby
142
103
  # Calculates hash code according to all attributes.
143
104
  # @return [Integer] Hash code
144
105
  def hash
145
- [name, id, last_used_at, created_at].hash
106
+ [value, confidence].hash
146
107
  end
147
108
 
148
109
  # Builds the object from hash