2015-07-23 20:42:34 +01:00
##GetUserPlaylists
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Get a list of the playlists owned or followed by a Spotify user.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|[limit]| The maximum number of playlists to return. Default: 20. Minimum: 1. Maximum: 50. | `20`
|[offset]| The index of the first playlist to return. Default: 0 (the first object) | `0`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a [SimplePlaylist ](https://developer.spotify.com/web-api/object-model/#playlist-object-simplified ) wrapped inside a [Paging Object ](https://developer.spotify.com/web-api/object-model/#paging-object )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
Paging< SimplePlaylist > userPlaylists = _spotify.GetUserPlaylists("1122095781");
userPlaylists.Items.ForEach(playlist => playlist.Owner.DisplayName) //Who is the owner of the playlist?
2015-07-23 20:42:34 +01:00
```
---
##GetPlaylist
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Get a playlist owned by a Spotify user.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|[fields]| Filters for the query: a comma-separated list of the fields to return. If omitted, all fields are returned. | `"description,uri"`
|[market]| An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking. | "DE"
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a [FullTrack ](https://developer.spotify.com/web-api/object-model/#track-object-full )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
FullPlaylist playlist = _spotify.GetPlaylist("1122095781", "1TtEejT1y4D1WmcOnLfha2");
playlist.Tracks.Items.ForEach(track => Console.WriteLine(track.Track.Name));
2015-07-23 20:42:34 +01:00
```
---
##GetPlaylistTracks
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Get full details of the tracks of a playlist owned by a Spotify user.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|[fields]| Filters for the query: a comma-separated list of the fields to return. If omitted, all fields are returned. | `"description,uri"`
|[limit]| The maximum number of tracks to return. Default: 100. Minimum: 1. Maximum: 100. | `100`
|[offset]| The index of the first object to return. Default: 0 (i.e., the first object) | `0`
|[market]| An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking. | `DE`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a [PlaylistTrack ](https://developer.spotify.com/web-api/object-model/#playlist-object-simplified ) wrapped inside a [Paging Object ](https://developer.spotify.com/web-api/object-model/#paging-object )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
Paging< PlaylistTrack > playlist = _spotify.GetPlaylistTracks("1122095781", "1TtEejT1y4D1WmcOnLfha2");
playlist.Items.ForEach(track => Console.WriteLine(track.Track.Name));
2015-07-23 20:42:34 +01:00
```
---
##CreatePlaylist
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Create a playlist for a Spotify user. (The playlist will be empty until you add tracks.)
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistName| The name for the new playlist, for example "Your Coolest Playlist". This name does not need to be unique. | `"This is my new Playlist"`
|[isPublic]| default true. If true the playlist will be public, if false it will be private. To be able to create private playlists, the user must have granted the playlist-modify-private scope. | `true`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a [FullPlaylist ](https://developer.spotify.com/web-api/object-model/#playlist-object-full )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
FullPlaylist playlist = _spotify.CreatePlaylist("1122095781", "This is my new Playlist");
if(!playlist.HasError())
Console.WriteLine("Playlist-URI: " + playlist.Uri);
2015-07-23 20:42:34 +01:00
```
---
##UpdatePlaylist
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Change a playlist’ s name and public/private state. (The user must, of course, own the playlist.)
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|[newName]| The new name for the playlist, for example "My New Playlist Title". | `"New Playlistname"`
|[newPublic]| If true the playlist will be public, if false it will be private. | EXAMPLE
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
ErrorResponse response = _spotify.UpdatePlaylist("1122095781", "1TtEejT1y4D1WmcOnLfha2", "New Name", true);
if(!response.HasError())
Console.WriteLine("success");
2015-07-23 20:42:34 +01:00
```
---
##ReplacePlaylistTracks
< span class = "label label-warning" > AUTH REQUIRED< / span >
2015-07-26 15:07:08 +01:00
> Replace all the tracks in a playlist, overwriting its existing tracks. This powerful request can be useful for replacing tracks, re-ordering existing tracks, or clearing the playlist.
2015-07-23 20:42:34 +01:00
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|uris| A list of Spotify track URIs to set. A maximum of 100 tracks can be set in one request. | `new List<string> { "1ri6UZpjPLmTCswIXZ6Uq1" }`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
ErrorResponse response = _spotify.ReplacePlaylistTracks("1122095781", "1TtEejT1y4D1WmcOnLfha2", new List< string > { "1ri6UZpjPLmTCswIXZ6Uq1" });
if(!response.HasError())
Console.WriteLine("success");
2015-07-23 20:42:34 +01:00
```
---
##RemovePlaylistTracks
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Remove one or more tracks from a user’ s playlist.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|uris| array of objects containing Spotify URI strings (and their position in the playlist). A maximum of 100 objects can be sent at once. | `(example below)`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
//Remove multiple tracks
ErrorResponse playlist = _spotify.RemovePlaylistTracks("1122095781", "1TtEejT1y4D1WmcOnLfha2", new List< DeleteTrackUri > ()
{
new DeleteTrackUri("1ri6UZpjPLmTCswIXZ6Uq1"),
new DeleteTrackUri("47xtGU3vht7mXLHqnbaau5")
});
//Remove multiple tracks at their specified positions
ErrorResponse playlist = _spotify.RemovePlaylistTracks("1122095781", "1TtEejT1y4D1WmcOnLfha2", new List< DeleteTrackUri > ()
{
new DeleteTrackUri("1ri6UZpjPLmTCswIXZ6Uq1", 2),
new DeleteTrackUri("47xtGU3vht7mXLHqnbaau5", 0, 50)
});
2015-07-23 20:42:34 +01:00
```
---
##RemovePlaylistTrack
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Remove one or more tracks from a user’ s playlist.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|uri| Spotify URI | `new DeleteTrackUri("1ri6UZpjPLmTCswIXZ6Uq1")`
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
//Remove all tracks with the specified URI
ErrorResponse response = _spotify.RemovePlaylistTrack("1122095781", "1TtEejT1y4D1WmcOnLfha2", new DeleteTrackUri("1ri6UZpjPLmTCswIXZ6Uq1"));
//Remove all tracks with the specified URI and the specified positions
ErrorResponse response = _spotify.RemovePlaylistTrack("1122095781", "1TtEejT1y4D1WmcOnLfha2", new DeleteTrackUri("1ri6UZpjPLmTCswIXZ6Uq1", 0, 10, 20));
2015-07-23 20:42:34 +01:00
```
---
##AddPlaylistTracks
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Add one or more tracks to a user’ s playlist.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|uris| A list of Spotify track URIs to add | `new List<string> { "1ri6UZpjPLmTCswIXZ6Uq1" }`
|[position]| The position to insert the tracks, a zero-based index | `10`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
ErrorResponse response = _spotify.AddPlaylistTracks("1122095781", "1TtEejT1y4D1WmcOnLfha2", new List< string > { "1ri6UZpjPLmTCswIXZ6Uq1" });
if(!response.HasError())
Console.WriteLine("Success");
2015-07-23 20:42:34 +01:00
```
---
##AddPlaylistTrack
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Add one or more tracks to a user’ s playlist.
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|uri| A Spotify Track URI | `"1ri6UZpjPLmTCswIXZ6Uq1"`
|position| The position to insert the tracks, a zero-based index | `10`
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **ErrorResponse** which just contains a possible error. (`response.HasError()` and `response.Error` )
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
ErrorResponse response = _spotify.AddPlaylistTrack("1122095781", "1TtEejT1y4D1WmcOnLfha2", "1ri6UZpjPLmTCswIXZ6Uq1");
if(!response.HasError())
Console.WriteLine("Success");
2015-07-23 20:42:34 +01:00
```
---
##ReorderPlaylist
< span class = "label label-warning" > AUTH REQUIRED< / span >
> Reorder a track or a group of tracks in a playlist.
2015-07-26 15:07:08 +01:00
> More Info: [Reorder-Playlist](https://developer.spotify.com/web-api/reorder-playlists-tracks/)
2015-07-23 20:42:34 +01:00
**Paramters**
|Name|Description|Example|
|--------------|-------------------------|-------------------------|
2015-07-26 15:07:08 +01:00
|userId| The user's Spotify user ID. | `"1122095781"`
|playlistId| The Spotify ID for the playlist. | `"1TtEejT1y4D1WmcOnLfha2"`
|rangeStart| The position of the first track to be reordered. | `2`
|insertBefore| The position where the tracks should be inserted. | `0`
|[rangeLength]| The amount of tracks to be reordered. Defaults to 1 if not set. | `2`
|[snapshotId]| The playlist's snapshot ID against which you want to make the changes. | ``
2015-07-23 20:42:34 +01:00
2015-07-26 15:07:08 +01:00
Returns a **Snapshot** -Object which contains the property `String SnapshotId`
2015-07-23 20:42:34 +01:00
**Usage**
```cs
2015-07-26 15:07:08 +01:00
Snapshot snapshot = _spotify.ReorderPlaylist("1122095781", "1TtEejT1y4D1WmcOnLfha2", 2, 0, 2);
Console.WriteLine("New SnapshotId: " + snapshot.SnapshotId);
2015-07-23 20:42:34 +01:00
```
---