spotted 0.4.0 → 0.6.0

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 (85) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +26 -0
  3. data/README.md +1 -1
  4. data/lib/spotted/client.rb +0 -4
  5. data/lib/spotted/internal/transport/pooled_net_requester.rb +6 -2
  6. data/lib/spotted/models/{album_list_params.rb → album_bulk_retrieve_params.rb} +3 -3
  7. data/lib/spotted/models/{album_list_response.rb → album_bulk_retrieve_response.rb} +24 -23
  8. data/lib/spotted/models/me/album_remove_params.rb +4 -4
  9. data/lib/spotted/models/me/album_save_params.rb +4 -4
  10. data/lib/spotted/models/me/episode_remove_params.rb +4 -4
  11. data/lib/spotted/models/me/episode_save_params.rb +4 -4
  12. data/lib/spotted/models/me/following_follow_params.rb +4 -23
  13. data/lib/spotted/models/me/following_unfollow_params.rb +4 -23
  14. data/lib/spotted/models/me/show_remove_params.rb +4 -20
  15. data/lib/spotted/models/me/show_save_params.rb +4 -4
  16. data/lib/spotted/models/me/track_remove_params.rb +4 -4
  17. data/lib/spotted/models/playlists/track_add_params.rb +7 -7
  18. data/lib/spotted/models/playlists/track_update_params.rb +8 -8
  19. data/lib/spotted/models.rb +1 -6
  20. data/lib/spotted/resources/albums.rb +7 -7
  21. data/lib/spotted/resources/me/albums.rb +6 -22
  22. data/lib/spotted/resources/me/episodes.rb +6 -16
  23. data/lib/spotted/resources/me/following.rb +7 -21
  24. data/lib/spotted/resources/me/shows.rb +6 -24
  25. data/lib/spotted/resources/me/tracks.rb +3 -11
  26. data/lib/spotted/resources/playlists/tracks.rb +13 -17
  27. data/lib/spotted/version.rb +1 -1
  28. data/lib/spotted.rb +3 -5
  29. data/manifest.yaml +1 -0
  30. data/rbi/spotted/client.rbi +0 -3
  31. data/rbi/spotted/internal/transport/pooled_net_requester.rbi +6 -2
  32. data/rbi/spotted/models/{album_list_params.rbi → album_bulk_retrieve_params.rbi} +2 -2
  33. data/rbi/spotted/models/{album_list_response.rbi → album_bulk_retrieve_response.rbi} +51 -33
  34. data/rbi/spotted/models/me/album_remove_params.rbi +6 -9
  35. data/rbi/spotted/models/me/album_save_params.rbi +6 -9
  36. data/rbi/spotted/models/me/episode_remove_params.rbi +6 -9
  37. data/rbi/spotted/models/me/episode_save_params.rbi +4 -7
  38. data/rbi/spotted/models/me/following_follow_params.rbi +4 -42
  39. data/rbi/spotted/models/me/following_unfollow_params.rbi +6 -47
  40. data/rbi/spotted/models/me/show_remove_params.rbi +6 -36
  41. data/rbi/spotted/models/me/show_save_params.rbi +6 -9
  42. data/rbi/spotted/models/me/track_remove_params.rbi +6 -9
  43. data/rbi/spotted/models/playlists/track_add_params.rbi +12 -12
  44. data/rbi/spotted/models/playlists/track_update_params.rbi +9 -9
  45. data/rbi/spotted/models.rbi +1 -9
  46. data/rbi/spotted/resources/albums.rbi +2 -2
  47. data/rbi/spotted/resources/me/albums.rbi +6 -6
  48. data/rbi/spotted/resources/me/episodes.rbi +6 -6
  49. data/rbi/spotted/resources/me/following.rbi +6 -12
  50. data/rbi/spotted/resources/me/shows.rbi +6 -17
  51. data/rbi/spotted/resources/me/tracks.rbi +3 -3
  52. data/rbi/spotted/resources/playlists/tracks.rbi +28 -31
  53. data/sig/spotted/client.rbs +0 -2
  54. data/sig/spotted/internal/transport/pooled_net_requester.rbs +4 -1
  55. data/sig/spotted/models/{album_list_params.rbs → album_bulk_retrieve_params.rbs} +2 -2
  56. data/sig/spotted/models/{album_list_response.rbs → album_bulk_retrieve_response.rbs} +27 -27
  57. data/sig/spotted/models/me/album_remove_params.rbs +5 -6
  58. data/sig/spotted/models/me/album_save_params.rbs +5 -6
  59. data/sig/spotted/models/me/episode_remove_params.rbs +5 -6
  60. data/sig/spotted/models/me/episode_save_params.rbs +4 -5
  61. data/sig/spotted/models/me/following_follow_params.rbs +4 -23
  62. data/sig/spotted/models/me/following_unfollow_params.rbs +5 -24
  63. data/sig/spotted/models/me/show_remove_params.rbs +5 -12
  64. data/sig/spotted/models/me/show_save_params.rbs +5 -6
  65. data/sig/spotted/models/me/track_remove_params.rbs +5 -6
  66. data/sig/spotted/models/playlists/track_add_params.rbs +9 -9
  67. data/sig/spotted/models/playlists/track_update_params.rbs +8 -8
  68. data/sig/spotted/models.rbs +1 -5
  69. data/sig/spotted/resources/albums.rbs +2 -2
  70. data/sig/spotted/resources/me/albums.rbs +2 -2
  71. data/sig/spotted/resources/me/episodes.rbs +2 -2
  72. data/sig/spotted/resources/me/following.rbs +2 -4
  73. data/sig/spotted/resources/me/shows.rbs +2 -3
  74. data/sig/spotted/resources/me/tracks.rbs +1 -1
  75. data/sig/spotted/resources/playlists/tracks.rbs +3 -3
  76. metadata +8 -17
  77. data/lib/spotted/models/unwrap_webhook_event.rb +0 -8
  78. data/lib/spotted/models/webhook_unwrap_params.rb +0 -14
  79. data/lib/spotted/resources/webhooks.rb +0 -22
  80. data/rbi/spotted/models/unwrap_webhook_event.rbi +0 -7
  81. data/rbi/spotted/models/webhook_unwrap_params.rbi +0 -27
  82. data/rbi/spotted/resources/webhooks.rbi +0 -19
  83. data/sig/spotted/models/unwrap_webhook_event.rbs +0 -5
  84. data/sig/spotted/models/webhook_unwrap_params.rbs +0 -15
  85. data/sig/spotted/resources/webhooks.rbs +0 -9
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0327511d3f7632182098667902cd5cd228d2470f95bbaec5eb50708cbe1eabc7
4
- data.tar.gz: c8e8664a697319f6c2142156c48e2edcf805a65f32d0b780bd7352bebb82fbf0
3
+ metadata.gz: 723ec8e22c6c14d0cb4bda97e14ad0e5c6536ccafb0cdfb186ed087069524158
4
+ data.tar.gz: 8c66a7363419c3f3638e70c8623582e5d38383041e7a11bd9ff0c587b5753948
5
5
  SHA512:
6
- metadata.gz: 194ca906ae851592c5c7490dbdde4e6b1b58a960f548666effee77d0c755ba20d48aa0c66473d9abddc775515d2d8120d49acb3c6d3f830e1a0506679eb0cc31
7
- data.tar.gz: 9960a452be806304c04a51635fc443a750f20d6a8976a01aedb50272cf57053d74dac68e59f976d148c3de9aeccc017ff2275e8bcb32778b72823517e64c664f
6
+ metadata.gz: 55a9e547fc79b6b28c3a9d668104c4c2b0683e683f110890d3b76190954538d5ac81238703446ef0f810d53a930596dd51f3a4978173b107de77e2ce6f1d00ad
7
+ data.tar.gz: 90c914e72f57c59be8c66ea5fc11173a9c9fcb317f4a97c5ce184d53419dd3ffcb3827e3028eabd0d2e25b66a1be7a9d839f7863b2ee660a246b3bc5f4148ddd
data/CHANGELOG.md CHANGED
@@ -1,5 +1,31 @@
1
1
  # Changelog
2
2
 
3
+ ## 0.6.0 (2025-11-07)
4
+
5
+ Full Changelog: [v0.5.0...v0.6.0](https://github.com/cjavdev/spotted/compare/v0.5.0...v0.6.0)
6
+
7
+ ### Features
8
+
9
+ * **api:** manual updates ([3d95bc3](https://github.com/cjavdev/spotted/commit/3d95bc327b7762e7926e39bf6949ddc0de4b0908))
10
+
11
+
12
+ ### Bug Fixes
13
+
14
+ * better thread safety via early initializing SSL store during HTTP client creation ([eb7a596](https://github.com/cjavdev/spotted/commit/eb7a596117993c2466b45a9c0ce20e70ba9f994a))
15
+
16
+ ## 0.5.0 (2025-11-05)
17
+
18
+ Full Changelog: [v0.4.0...v0.5.0](https://github.com/cjavdev/spotted/compare/v0.4.0...v0.5.0)
19
+
20
+ ### Features
21
+
22
+ * **api:** manual updates ([5eb8f35](https://github.com/cjavdev/spotted/commit/5eb8f353b335e9f2e862a919b51b9a45b84dfa0a))
23
+
24
+
25
+ ### Chores
26
+
27
+ * **internal:** version bump ([81d42c8](https://github.com/cjavdev/spotted/commit/81d42c8c6636dcc91d52a10a94647252b79959a7))
28
+
3
29
  ## 0.4.0 (2025-11-04)
4
30
 
5
31
  Full Changelog: [v0.3.0...v0.4.0](https://github.com/cjavdev/spotted/compare/v0.3.0...v0.4.0)
data/README.md CHANGED
@@ -17,7 +17,7 @@ To use this gem, install via Bundler by adding the following to your application
17
17
  <!-- x-release-please-start-version -->
18
18
 
19
19
  ```ruby
20
- gem "spotted", "~> 0.4.0"
20
+ gem "spotted", "~> 0.6.0"
21
21
  ```
22
22
 
23
23
  <!-- x-release-please-end -->
@@ -66,9 +66,6 @@ module Spotted
66
66
  # @return [Spotted::Resources::Recommendations]
67
67
  attr_reader :recommendations
68
68
 
69
- # @return [Spotted::Resources::Webhooks]
70
- attr_reader :webhooks
71
-
72
69
  # @return [Spotted::Resources::Markets]
73
70
  attr_reader :markets
74
71
 
@@ -166,7 +163,6 @@ module Spotted
166
163
  @audio_features = Spotted::Resources::AudioFeatures.new(client: self)
167
164
  @audio_analysis = Spotted::Resources::AudioAnalysis.new(client: self)
168
165
  @recommendations = Spotted::Resources::Recommendations.new(client: self)
169
- @webhooks = Spotted::Resources::Webhooks.new(client: self)
170
166
  @markets = Spotted::Resources::Markets.new(client: self)
171
167
  end
172
168
  end
@@ -16,10 +16,11 @@ module Spotted
16
16
  class << self
17
17
  # @api private
18
18
  #
19
+ # @param cert_store [OpenSSL::X509::Store]
19
20
  # @param url [URI::Generic]
20
21
  #
21
22
  # @return [Net::HTTP]
22
- def connect(url)
23
+ def connect(cert_store:, url:)
23
24
  port =
24
25
  case [url.port, url.scheme]
25
26
  in [Integer, _]
@@ -33,6 +34,8 @@ module Spotted
33
34
  Net::HTTP.new(url.host, port).tap do
34
35
  _1.use_ssl = %w[https wss].include?(url.scheme)
35
36
  _1.max_retries = 0
37
+
38
+ (_1.cert_store = cert_store) if _1.use_ssl?
36
39
  end
37
40
  end
38
41
 
@@ -102,7 +105,7 @@ module Spotted
102
105
  pool =
103
106
  @mutex.synchronize do
104
107
  @pools[origin] ||= ConnectionPool.new(size: @size) do
105
- self.class.connect(url)
108
+ self.class.connect(cert_store: @cert_store, url: url)
106
109
  end
107
110
  end
108
111
 
@@ -192,6 +195,7 @@ module Spotted
192
195
  def initialize(size: self.class::DEFAULT_MAX_CONNECTIONS)
193
196
  @mutex = Mutex.new
194
197
  @size = size
198
+ @cert_store = OpenSSL::X509::Store.new.tap(&:set_default_paths)
195
199
  @pools = {}
196
200
  end
197
201
 
@@ -2,8 +2,8 @@
2
2
 
3
3
  module Spotted
4
4
  module Models
5
- # @see Spotted::Resources::Albums#list
6
- class AlbumListParams < Spotted::Internal::Type::BaseModel
5
+ # @see Spotted::Resources::Albums#bulk_retrieve
6
+ class AlbumBulkRetrieveParams < Spotted::Internal::Type::BaseModel
7
7
  extend Spotted::Internal::Type::RequestParameters::Converter
8
8
  include Spotted::Internal::Type::RequestParameters
9
9
 
@@ -31,7 +31,7 @@ module Spotted
31
31
 
32
32
  # @!method initialize(ids:, market: nil, request_options: {})
33
33
  # Some parameter documentations has been truncated, see
34
- # {Spotted::Models::AlbumListParams} for more details.
34
+ # {Spotted::Models::AlbumBulkRetrieveParams} for more details.
35
35
  #
36
36
  # @param ids [String] A comma-separated list of the [Spotify IDs](/documentation/web-api/concepts/spot
37
37
  #
@@ -2,15 +2,16 @@
2
2
 
3
3
  module Spotted
4
4
  module Models
5
- # @see Spotted::Resources::Albums#list
6
- class AlbumListResponse < Spotted::Internal::Type::BaseModel
5
+ # @see Spotted::Resources::Albums#bulk_retrieve
6
+ class AlbumBulkRetrieveResponse < Spotted::Internal::Type::BaseModel
7
7
  # @!attribute albums
8
8
  #
9
- # @return [Array<Spotted::Models::AlbumListResponse::Album>]
10
- required :albums, -> { Spotted::Internal::Type::ArrayOf[Spotted::Models::AlbumListResponse::Album] }
9
+ # @return [Array<Spotted::Models::AlbumBulkRetrieveResponse::Album>]
10
+ required :albums,
11
+ -> { Spotted::Internal::Type::ArrayOf[Spotted::Models::AlbumBulkRetrieveResponse::Album] }
11
12
 
12
13
  # @!method initialize(albums:)
13
- # @param albums [Array<Spotted::Models::AlbumListResponse::Album>]
14
+ # @param albums [Array<Spotted::Models::AlbumBulkRetrieveResponse::Album>]
14
15
 
15
16
  class Album < Spotted::Internal::Type::BaseModel
16
17
  # @!attribute id
@@ -23,8 +24,8 @@ module Spotted
23
24
  # @!attribute album_type
24
25
  # The type of the album.
25
26
  #
26
- # @return [Symbol, Spotted::Models::AlbumListResponse::Album::AlbumType]
27
- required :album_type, enum: -> { Spotted::Models::AlbumListResponse::Album::AlbumType }
27
+ # @return [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::AlbumType]
28
+ required :album_type, enum: -> { Spotted::Models::AlbumBulkRetrieveResponse::Album::AlbumType }
28
29
 
29
30
  # @!attribute available_markets
30
31
  # The markets in which the album is available:
@@ -69,9 +70,9 @@ module Spotted
69
70
  # @!attribute release_date_precision
70
71
  # The precision with which `release_date` value is known.
71
72
  #
72
- # @return [Symbol, Spotted::Models::AlbumListResponse::Album::ReleaseDatePrecision]
73
+ # @return [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::ReleaseDatePrecision]
73
74
  required :release_date_precision,
74
- enum: -> { Spotted::Models::AlbumListResponse::Album::ReleaseDatePrecision }
75
+ enum: -> { Spotted::Models::AlbumBulkRetrieveResponse::Album::ReleaseDatePrecision }
75
76
 
76
77
  # @!attribute total_tracks
77
78
  # The number of tracks in the album.
@@ -82,8 +83,8 @@ module Spotted
82
83
  # @!attribute type
83
84
  # The object type.
84
85
  #
85
- # @return [Symbol, Spotted::Models::AlbumListResponse::Album::Type]
86
- required :type, enum: -> { Spotted::Models::AlbumListResponse::Album::Type }
86
+ # @return [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::Type]
87
+ required :type, enum: -> { Spotted::Models::AlbumBulkRetrieveResponse::Album::Type }
87
88
 
88
89
  # @!attribute uri
89
90
  # The [Spotify URI](/documentation/web-api/concepts/spotify-uris-ids) for the
@@ -141,16 +142,16 @@ module Spotted
141
142
  # @!attribute tracks
142
143
  # The tracks of the album.
143
144
  #
144
- # @return [Spotted::Models::AlbumListResponse::Album::Tracks, nil]
145
- optional :tracks, -> { Spotted::Models::AlbumListResponse::Album::Tracks }
145
+ # @return [Spotted::Models::AlbumBulkRetrieveResponse::Album::Tracks, nil]
146
+ optional :tracks, -> { Spotted::Models::AlbumBulkRetrieveResponse::Album::Tracks }
146
147
 
147
148
  # @!method initialize(id:, album_type:, available_markets:, external_urls:, href:, images:, name:, release_date:, release_date_precision:, total_tracks:, type:, uri:, artists: nil, copyrights: nil, external_ids: nil, genres: nil, label: nil, popularity: nil, restrictions: nil, tracks: nil)
148
149
  # Some parameter documentations has been truncated, see
149
- # {Spotted::Models::AlbumListResponse::Album} for more details.
150
+ # {Spotted::Models::AlbumBulkRetrieveResponse::Album} for more details.
150
151
  #
151
152
  # @param id [String] The [Spotify ID](/documentation/web-api/concepts/spotify-uris-ids) for the album
152
153
  #
153
- # @param album_type [Symbol, Spotted::Models::AlbumListResponse::Album::AlbumType] The type of the album.
154
+ # @param album_type [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::AlbumType] The type of the album.
154
155
  #
155
156
  # @param available_markets [Array<String>] The markets in which the album is available: [ISO 3166-1 alpha-2 country codes](
156
157
  #
@@ -164,11 +165,11 @@ module Spotted
164
165
  #
165
166
  # @param release_date [String] The date the album was first released.
166
167
  #
167
- # @param release_date_precision [Symbol, Spotted::Models::AlbumListResponse::Album::ReleaseDatePrecision] The precision with which `release_date` value is known.
168
+ # @param release_date_precision [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::ReleaseDatePrecision] The precision with which `release_date` value is known.
168
169
  #
169
170
  # @param total_tracks [Integer] The number of tracks in the album.
170
171
  #
171
- # @param type [Symbol, Spotted::Models::AlbumListResponse::Album::Type] The object type.
172
+ # @param type [Symbol, Spotted::Models::AlbumBulkRetrieveResponse::Album::Type] The object type.
172
173
  #
173
174
  # @param uri [String] The [Spotify URI](/documentation/web-api/concepts/spotify-uris-ids) for the albu
174
175
  #
@@ -186,11 +187,11 @@ module Spotted
186
187
  #
187
188
  # @param restrictions [Spotted::Models::AlbumRestrictionObject] Included in the response when a content restriction is applied.
188
189
  #
189
- # @param tracks [Spotted::Models::AlbumListResponse::Album::Tracks] The tracks of the album.
190
+ # @param tracks [Spotted::Models::AlbumBulkRetrieveResponse::Album::Tracks] The tracks of the album.
190
191
 
191
192
  # The type of the album.
192
193
  #
193
- # @see Spotted::Models::AlbumListResponse::Album#album_type
194
+ # @see Spotted::Models::AlbumBulkRetrieveResponse::Album#album_type
194
195
  module AlbumType
195
196
  extend Spotted::Internal::Type::Enum
196
197
 
@@ -204,7 +205,7 @@ module Spotted
204
205
 
205
206
  # The precision with which `release_date` value is known.
206
207
  #
207
- # @see Spotted::Models::AlbumListResponse::Album#release_date_precision
208
+ # @see Spotted::Models::AlbumBulkRetrieveResponse::Album#release_date_precision
208
209
  module ReleaseDatePrecision
209
210
  extend Spotted::Internal::Type::Enum
210
211
 
@@ -218,7 +219,7 @@ module Spotted
218
219
 
219
220
  # The object type.
220
221
  #
221
- # @see Spotted::Models::AlbumListResponse::Album#type
222
+ # @see Spotted::Models::AlbumBulkRetrieveResponse::Album#type
222
223
  module Type
223
224
  extend Spotted::Internal::Type::Enum
224
225
 
@@ -228,7 +229,7 @@ module Spotted
228
229
  # @return [Array<Symbol>]
229
230
  end
230
231
 
231
- # @see Spotted::Models::AlbumListResponse::Album#tracks
232
+ # @see Spotted::Models::AlbumBulkRetrieveResponse::Album#tracks
232
233
  class Tracks < Spotted::Internal::Type::BaseModel
233
234
  # @!attribute href
234
235
  # A link to the Web API endpoint returning the full result of the request
@@ -273,7 +274,7 @@ module Spotted
273
274
 
274
275
  # @!method initialize(href:, items:, limit:, next_:, offset:, previous:, total:)
275
276
  # Some parameter documentations has been truncated, see
276
- # {Spotted::Models::AlbumListResponse::Album::Tracks} for more details.
277
+ # {Spotted::Models::AlbumBulkRetrieveResponse::Album::Tracks} for more details.
277
278
  #
278
279
  # The tracks of the album.
279
280
  #
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). For example:
14
14
  # `["4iV5W9uYEdYUVa79Axb7Rh", "1301WleyT98MSxVHPZCA6M"]`<br/>A maximum of 50 items
@@ -16,13 +16,13 @@ module Spotted
16
16
  # the query string, any IDs listed here in the body will be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::AlbumRemoveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). For example:
14
14
  # `["4iV5W9uYEdYUVa79Axb7Rh", "1301WleyT98MSxVHPZCA6M"]`<br/>A maximum of 50 items
@@ -16,13 +16,13 @@ module Spotted
16
16
  # the query string, any IDs listed here in the body will be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::AlbumSaveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). <br/>A maximum
14
14
  # of 50 items can be specified in one request. _**Note**: if the `ids` parameter
@@ -16,13 +16,13 @@ module Spotted
16
16
  # ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::EpisodeRemoveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). <br/>A maximum
14
14
  # of 50 items can be specified in one request. _**Note**: if the `ids` parameter
@@ -16,13 +16,13 @@ module Spotted
16
16
  # ignored._
17
17
  #
18
18
  # @return [Array<String>]
19
- required :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ required :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids:, request_options: {})
21
+ # @!method initialize(ids:, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::EpisodeSaveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the artist or user
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). For example:
14
14
  # `{ids:["74ASZWbe4lXaubB36ztrGX", "08td7MxkoHQkXnWAYD8d6Q"]}`. A maximum of 50
@@ -16,34 +16,15 @@ module Spotted
16
16
  # the query string, any IDs listed here in the body will be ignored._
17
17
  #
18
18
  # @return [Array<String>]
19
- required :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ required :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!attribute type
22
- # The ID type.
23
- #
24
- # @return [Symbol, Spotted::Models::Me::FollowingFollowParams::Type]
25
- required :type, enum: -> { Spotted::Me::FollowingFollowParams::Type }
26
-
27
- # @!method initialize(body_ids:, type:, request_options: {})
21
+ # @!method initialize(ids:, request_options: {})
28
22
  # Some parameter documentations has been truncated, see
29
23
  # {Spotted::Models::Me::FollowingFollowParams} for more details.
30
24
  #
31
- # @param body_ids [Array<String>] A JSON array of the artist or user [Spotify IDs](/documentation/web-api/concepts
32
- #
33
- # @param type [Symbol, Spotted::Models::Me::FollowingFollowParams::Type] The ID type.
25
+ # @param ids [Array<String>] A JSON array of the artist or user [Spotify IDs](/documentation/web-api/concepts
34
26
  #
35
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
36
-
37
- # The ID type.
38
- module Type
39
- extend Spotted::Internal::Type::Enum
40
-
41
- ARTIST = :artist
42
- USER = :user
43
-
44
- # @!method self.values
45
- # @return [Array<Symbol>]
46
- end
47
28
  end
48
29
  end
49
30
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the artist or user
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). For example:
14
14
  # `{ids:["74ASZWbe4lXaubB36ztrGX", "08td7MxkoHQkXnWAYD8d6Q"]}`. A maximum of 50
@@ -16,34 +16,15 @@ module Spotted
16
16
  # the query string, any IDs listed here in the body will be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!attribute type
22
- # The ID type: either `artist` or `user`.
23
- #
24
- # @return [Symbol, Spotted::Models::Me::FollowingUnfollowParams::Type]
25
- required :type, enum: -> { Spotted::Me::FollowingUnfollowParams::Type }
26
-
27
- # @!method initialize(type:, body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
28
22
  # Some parameter documentations has been truncated, see
29
23
  # {Spotted::Models::Me::FollowingUnfollowParams} for more details.
30
24
  #
31
- # @param type [Symbol, Spotted::Models::Me::FollowingUnfollowParams::Type] The ID type: either `artist` or `user`.
32
- #
33
- # @param body_ids [Array<String>] A JSON array of the artist or user [Spotify IDs](/documentation/web-api/concepts
25
+ # @param ids [Array<String>] A JSON array of the artist or user [Spotify IDs](/documentation/web-api/concepts
34
26
  #
35
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
36
-
37
- # The ID type: either `artist` or `user`.
38
- module Type
39
- extend Spotted::Internal::Type::Enum
40
-
41
- ARTIST = :artist
42
- USER = :user
43
-
44
- # @!method self.values
45
- # @return [Array<Symbol>]
46
- end
47
28
  end
48
29
  end
49
30
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](https://developer.spotify.com/documentation/web-api/#spotify-uris-and-ids).
14
14
  # A maximum of 50 items can be specified in one request. _Note: if the `ids`
@@ -16,29 +16,13 @@ module Spotted
16
16
  # be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!attribute market
22
- # An
23
- # [ISO 3166-1 alpha-2 country code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).
24
- # If a country code is specified, only content that is available in that market
25
- # will be returned.<br/> If a valid user access token is specified in the request
26
- # header, the country associated with the user account will take priority over
27
- # this parameter.<br/> _**Note**: If neither market or user country are provided,
28
- # the content is considered unavailable for the client._<br/> Users can view the
29
- # country that is associated with their account in the
30
- # [account settings](https://www.spotify.com/account/overview/).
31
- #
32
- # @return [String, nil]
33
- optional :market, String
34
-
35
- # @!method initialize(body_ids: nil, market: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
36
22
  # Some parameter documentations has been truncated, see
37
23
  # {Spotted::Models::Me::ShowRemoveParams} for more details.
38
24
  #
39
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](https://developer.spotify.com/documentation/we
40
- #
41
- # @param market [String] An [ISO 3166-1 alpha-2 country code](https://en.wikipedia.org/wiki/ISO_3166-1_al
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](https://developer.spotify.com/documentation/we
42
26
  #
43
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
44
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](https://developer.spotify.com/documentation/web-api/#spotify-uris-and-ids).
14
14
  # A maximum of 50 items can be specified in one request. _Note: if the `ids`
@@ -16,13 +16,13 @@ module Spotted
16
16
  # be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::ShowSaveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](https://developer.spotify.com/documentation/we
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](https://developer.spotify.com/documentation/we
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_ids
11
+ # @!attribute ids
12
12
  # A JSON array of the
13
13
  # [Spotify IDs](/documentation/web-api/concepts/spotify-uris-ids). For example:
14
14
  # `["4iV5W9uYEdYUVa79Axb7Rh", "1301WleyT98MSxVHPZCA6M"]`<br/>A maximum of 50 items
@@ -16,13 +16,13 @@ module Spotted
16
16
  # the query string, any IDs listed here in the body will be ignored._
17
17
  #
18
18
  # @return [Array<String>, nil]
19
- optional :body_ids, Spotted::Internal::Type::ArrayOf[String], api_name: :ids
19
+ optional :ids, Spotted::Internal::Type::ArrayOf[String]
20
20
 
21
- # @!method initialize(body_ids: nil, request_options: {})
21
+ # @!method initialize(ids: nil, request_options: {})
22
22
  # Some parameter documentations has been truncated, see
23
23
  # {Spotted::Models::Me::TrackRemoveParams} for more details.
24
24
  #
25
- # @param body_ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
25
+ # @param ids [Array<String>] A JSON array of the [Spotify IDs](/documentation/web-api/concepts/spotify-uris-i
26
26
  #
27
27
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
28
28
  end
@@ -8,7 +8,7 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_position
11
+ # @!attribute position
12
12
  # The position to insert the items, a zero-based index. For example, to insert the
13
13
  # items in the first position: `position=0` ; to insert the items in the third
14
14
  # position: `position=2`. If omitted, the items will be appended to the playlist.
@@ -16,9 +16,9 @@ module Spotted
16
16
  # `{"uris": ["spotify:track:4iV5W9uYEdYUVa79Axb7Rh","spotify:track:1301WleyT98MSxVHPZCA6M"], "position": 3}`
17
17
  #
18
18
  # @return [Integer, nil]
19
- optional :body_position, Integer, api_name: :position
19
+ optional :position, Integer
20
20
 
21
- # @!attribute body_uris
21
+ # @!attribute uris
22
22
  # A JSON array of the
23
23
  # [Spotify URIs](/documentation/web-api/concepts/spotify-uris-ids) to add. For
24
24
  # example:
@@ -28,15 +28,15 @@ module Spotted
28
28
  # be ignored._
29
29
  #
30
30
  # @return [Array<String>, nil]
31
- optional :body_uris, Spotted::Internal::Type::ArrayOf[String], api_name: :uris
31
+ optional :uris, Spotted::Internal::Type::ArrayOf[String]
32
32
 
33
- # @!method initialize(body_position: nil, body_uris: nil, request_options: {})
33
+ # @!method initialize(position: nil, uris: nil, request_options: {})
34
34
  # Some parameter documentations has been truncated, see
35
35
  # {Spotted::Models::Playlists::TrackAddParams} for more details.
36
36
  #
37
- # @param body_position [Integer] The position to insert the items, a zero-based index. For example, to insert the
37
+ # @param position [Integer] The position to insert the items, a zero-based index. For example, to insert the
38
38
  #
39
- # @param body_uris [Array<String>] A JSON array of the [Spotify URIs](/documentation/web-api/concepts/spotify-uris-
39
+ # @param uris [Array<String>] A JSON array of the [Spotify URIs](/documentation/web-api/concepts/spotify-uris-
40
40
  #
41
41
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
42
42
  end
@@ -8,11 +8,6 @@ module Spotted
8
8
  extend Spotted::Internal::Type::RequestParameters::Converter
9
9
  include Spotted::Internal::Type::RequestParameters
10
10
 
11
- # @!attribute body_uris
12
- #
13
- # @return [Array<String>, nil]
14
- optional :body_uris, Spotted::Internal::Type::ArrayOf[String], api_name: :uris
15
-
16
11
  # @!attribute insert_before
17
12
  # The position where the items should be inserted.<br/>To reorder the items to the
18
13
  # end of the playlist, simply set _insert_before_ to the position after the last
@@ -46,12 +41,15 @@ module Spotted
46
41
  # @return [String, nil]
47
42
  optional :snapshot_id, String
48
43
 
49
- # @!method initialize(body_uris: nil, insert_before: nil, range_length: nil, range_start: nil, snapshot_id: nil, request_options: {})
44
+ # @!attribute uris
45
+ #
46
+ # @return [Array<String>, nil]
47
+ optional :uris, Spotted::Internal::Type::ArrayOf[String]
48
+
49
+ # @!method initialize(insert_before: nil, range_length: nil, range_start: nil, snapshot_id: nil, uris: nil, request_options: {})
50
50
  # Some parameter documentations has been truncated, see
51
51
  # {Spotted::Models::Playlists::TrackUpdateParams} for more details.
52
52
  #
53
- # @param body_uris [Array<String>]
54
- #
55
53
  # @param insert_before [Integer] The position where the items should be inserted.<br/>To reorder the items to the
56
54
  #
57
55
  # @param range_length [Integer] The amount of items to be reordered. Defaults to 1 if not set.<br/>The range of
@@ -60,6 +58,8 @@ module Spotted
60
58
  #
61
59
  # @param snapshot_id [String] The playlist's snapshot ID against which you want to make the changes.
62
60
  #
61
+ # @param uris [Array<String>]
62
+ #
63
63
  # @param request_options [Spotted::RequestOptions, Hash{Symbol=>Object}]
64
64
  end
65
65
  end