1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
use crate::api::prelude::*;
/// Get a playlist owned by a Spotify user.
#[derive(Debug, Clone)]
pub struct GetPlaylist {
/// The [Spotify ID](https://developer.spotify.com/documentation/web-api/concepts/spotify-uris-ids) of the playlist.
pub id: String,
/// An [ISO 3166-1 alpha-2 country code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).
/// If a country code is specified, only content that is available in that market will be returned.
/// If a valid user access token is specified in the request header, the country associated with the user account will take priority over this parameter.
///
/// # Notes
/// If neither market or user country are provided, the content is considered unavailable for the client.
/// Users can view the country that is associated with their account in the [account settings](https://www.spotify.com/account/overview/).
pub market: Option<Market>,
}
impl<T: Into<String>> From<T> for GetPlaylist {
fn from(id: T) -> Self {
Self {
id: id.into(),
market: None,
}
}
}
impl Endpoint for GetPlaylist {
fn method(&self) -> Method {
Method::GET
}
fn endpoint(&self) -> Cow<'static, str> {
format!("playlists/{}", self.id).into()
}
fn parameters(&self) -> QueryParams<'_> {
let mut params = QueryParams::default();
params.push_opt("market", self.market.as_ref());
params
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::{
api::{self, Query as _},
test::client::{ExpectedUrl, SingleTestClient},
};
#[test]
fn test_get_playlist_endpoint() {
let endpoint = ExpectedUrl::builder()
.endpoint("playlists/3cEYpjA9oz9GiPac4AsH4n")
.build();
let client = SingleTestClient::new_raw(endpoint, "");
let endpoint = GetPlaylist::from("3cEYpjA9oz9GiPac4AsH4n");
api::ignore(endpoint).query(&client).unwrap();
}
}