mirror of
https://github.com/Sarsoo/Spotify.NET.git
synced 2025-01-12 06:27:47 +00:00
Reworked async/await in WebAPI
This commit is contained in:
parent
dd2b39292a
commit
a67305cb14
@ -110,9 +110,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first result to return. Default: 0</param>
|
/// <param name="offset">The index of the first result to return. Default: 0</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code or the string from_token.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code or the string from_token.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SearchItem> SearchItemsAsync(string q, SearchType type, int limit = 20, int offset = 0, string market = "")
|
public Task<SearchItem> SearchItemsAsync(string q, SearchType type, int limit = 20, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SearchItem>(_builder.SearchItems(q, type, limit, offset, market));
|
return DownloadDataAsync<SearchItem>(_builder.SearchItems(q, type, limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Search
|
#endregion Search
|
||||||
@ -142,9 +142,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first track to return. Default: 0 (the first object).</param>
|
/// <param name="offset">The index of the first track to return. Default: 0 (the first object).</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<Paging<SimpleTrack>> GetAlbumTracksAsync(string id, int limit = 20, int offset = 0, string market = "")
|
public Task<Paging<SimpleTrack>> GetAlbumTracksAsync(string id, int limit = 20, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Paging<SimpleTrack>>(_builder.GetAlbumTracks(id, limit, offset, market));
|
return DownloadDataAsync<Paging<SimpleTrack>>(_builder.GetAlbumTracks(id, limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -164,9 +164,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">The Spotify ID for the album.</param>
|
/// <param name="id">The Spotify ID for the album.</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<FullAlbum> GetAlbumAsync(string id, string market = "")
|
public Task<FullAlbum> GetAlbumAsync(string id, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<FullAlbum>(_builder.GetAlbum(id, market));
|
return DownloadDataAsync<FullAlbum>(_builder.GetAlbum(id, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -186,9 +186,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of the Spotify IDs for the albums. Maximum: 20 IDs.</param>
|
/// <param name="ids">A list of the Spotify IDs for the albums. Maximum: 20 IDs.</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SeveralAlbums> GetSeveralAlbumsAsync(List<string> ids, string market = "")
|
public Task<SeveralAlbums> GetSeveralAlbumsAsync(List<string> ids, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralAlbums>(_builder.GetSeveralAlbums(ids, market));
|
return DownloadDataAsync<SeveralAlbums>(_builder.GetSeveralAlbums(ids, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Albums
|
#endregion Albums
|
||||||
@ -210,9 +210,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="id">The Spotify ID for the artist.</param>
|
/// <param name="id">The Spotify ID for the artist.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<FullArtist> GetArtistAsync(string id)
|
public Task<FullArtist> GetArtistAsync(string id)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<FullArtist>(_builder.GetArtist(id));
|
return DownloadDataAsync<FullArtist>(_builder.GetArtist(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -232,9 +232,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="id">The Spotify ID for the artist.</param>
|
/// <param name="id">The Spotify ID for the artist.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SeveralArtists> GetRelatedArtistsAsync(string id)
|
public Task<SeveralArtists> GetRelatedArtistsAsync(string id)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralArtists>(_builder.GetRelatedArtists(id));
|
return DownloadDataAsync<SeveralArtists>(_builder.GetRelatedArtists(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -254,9 +254,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">The Spotify ID for the artist.</param>
|
/// <param name="id">The Spotify ID for the artist.</param>
|
||||||
/// <param name="country">The country: an ISO 3166-1 alpha-2 country code.</param>
|
/// <param name="country">The country: an ISO 3166-1 alpha-2 country code.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SeveralTracks> GetArtistsTopTracksAsync(string id, string country)
|
public Task<SeveralTracks> GetArtistsTopTracksAsync(string id, string country)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralTracks>(_builder.GetArtistsTopTracks(id, country));
|
return DownloadDataAsync<SeveralTracks>(_builder.GetArtistsTopTracks(id, country));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -296,9 +296,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// geographical market
|
/// geographical market
|
||||||
/// </param>
|
/// </param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<Paging<SimpleAlbum>> GetArtistsAlbumsAsync(string id, AlbumType type = AlbumType.All, int limit = 20, int offset = 0, string market = "")
|
public Task<Paging<SimpleAlbum>> GetArtistsAlbumsAsync(string id, AlbumType type = AlbumType.All, int limit = 20, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Paging<SimpleAlbum>>(_builder.GetArtistsAlbums(id, type, limit, offset, market));
|
return DownloadDataAsync<Paging<SimpleAlbum>>(_builder.GetArtistsAlbums(id, type, limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -316,9 +316,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="ids">A list of the Spotify IDs for the artists. Maximum: 50 IDs.</param>
|
/// <param name="ids">A list of the Spotify IDs for the artists. Maximum: 50 IDs.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SeveralArtists> GetSeveralArtistsAsync(List<string> ids)
|
public Task<SeveralArtists> GetSeveralArtistsAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralArtists>(_builder.GetSeveralArtists(ids));
|
return DownloadDataAsync<SeveralArtists>(_builder.GetSeveralArtists(ids));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Artists
|
#endregion Artists
|
||||||
@ -356,11 +356,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="limit">The maximum number of items to return. Default: 20. Minimum: 1. Maximum: 50.</param>
|
/// <param name="limit">The maximum number of items to return. Default: 20. Minimum: 1. Maximum: 50.</param>
|
||||||
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<FeaturedPlaylists> GetFeaturedPlaylistsAsync(string locale = "", string country = "", DateTime timestamp = default(DateTime), int limit = 20, int offset = 0)
|
public Task<FeaturedPlaylists> GetFeaturedPlaylistsAsync(string locale = "", string country = "", DateTime timestamp = default(DateTime), int limit = 20, int offset = 0)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetFeaturedPlaylists");
|
throw new InvalidOperationException("Auth is required for GetFeaturedPlaylists");
|
||||||
return await DownloadDataAsync<FeaturedPlaylists>(_builder.GetFeaturedPlaylists(locale, country, timestamp, limit, offset));
|
return DownloadDataAsync<FeaturedPlaylists>(_builder.GetFeaturedPlaylists(locale, country, timestamp, limit, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -386,11 +386,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<NewAlbumReleases> GetNewAlbumReleasesAsync(string country = "", int limit = 20, int offset = 0)
|
public Task<NewAlbumReleases> GetNewAlbumReleasesAsync(string country = "", int limit = 20, int offset = 0)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetNewAlbumReleases");
|
throw new InvalidOperationException("Auth is required for GetNewAlbumReleases");
|
||||||
return await DownloadDataAsync<NewAlbumReleases>(_builder.GetNewAlbumReleases(country, limit, offset));
|
return DownloadDataAsync<NewAlbumReleases>(_builder.GetNewAlbumReleases(country, limit, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -430,11 +430,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first item to return. Default: 0 (the first object).</param>
|
/// <param name="offset">The index of the first item to return. Default: 0 (the first object).</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<CategoryList> GetCategoriesAsync(string country = "", string locale = "", int limit = 20, int offset = 0)
|
public Task<CategoryList> GetCategoriesAsync(string country = "", string locale = "", int limit = 20, int offset = 0)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetCategories");
|
throw new InvalidOperationException("Auth is required for GetCategories");
|
||||||
return await DownloadDataAsync<CategoryList>(_builder.GetCategories(country, locale, limit, offset));
|
return DownloadDataAsync<CategoryList>(_builder.GetCategories(country, locale, limit, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -470,9 +470,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </param>
|
/// </param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Category> GetCategoryAsync(string categoryId, string country = "", string locale = "")
|
public Task<Category> GetCategoryAsync(string categoryId, string country = "", string locale = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Category>(_builder.GetCategory(categoryId, country, locale));
|
return DownloadDataAsync<Category>(_builder.GetCategory(categoryId, country, locale));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -498,9 +498,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
/// <param name="offset">The index of the first item to return. Default: 0</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<CategoryPlaylist> GetCategoryPlaylistsAsync(string categoryId, string country = "", int limit = 20, int offset = 0)
|
public Task<CategoryPlaylist> GetCategoryPlaylistsAsync(string categoryId, string country = "", int limit = 20, int offset = 0)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<CategoryPlaylist>(_builder.GetCategoryPlaylists(categoryId, country, limit, offset));
|
return DownloadDataAsync<CategoryPlaylist>(_builder.GetCategoryPlaylists(categoryId, country, limit, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -553,10 +553,10 @@ namespace SpotifyAPI.Web
|
|||||||
/// Because min_*, max_* and target_* are applied to pools before relinking, the generated results may not precisely match the filters applied.</param>
|
/// Because min_*, max_* and target_* are applied to pools before relinking, the generated results may not precisely match the filters applied.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Recommendations> GetRecommendationsAsync(List<string> artistSeed = null, List<string> genreSeed = null, List<string> trackSeed = null,
|
public Task<Recommendations> GetRecommendationsAsync(List<string> artistSeed = null, List<string> genreSeed = null, List<string> trackSeed = null,
|
||||||
TuneableTrack target = null, TuneableTrack min = null, TuneableTrack max = null, int limit = 20, string market = "")
|
TuneableTrack target = null, TuneableTrack min = null, TuneableTrack max = null, int limit = 20, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Recommendations>(_builder.GetRecommendations(artistSeed, genreSeed, trackSeed, target, min, max, limit, market));
|
return DownloadDataAsync<Recommendations>(_builder.GetRecommendations(artistSeed, genreSeed, trackSeed, target, min, max, limit, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -574,9 +574,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<RecommendationSeedGenres> GetRecommendationSeedsGenresAsync()
|
public Task<RecommendationSeedGenres> GetRecommendationSeedsGenresAsync()
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<RecommendationSeedGenres>(_builder.GetRecommendationSeedsGenres());
|
return DownloadDataAsync<RecommendationSeedGenres>(_builder.GetRecommendationSeedsGenres());
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Browse
|
#endregion Browse
|
||||||
@ -606,11 +606,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="after">The last artist ID retrieved from the previous request.</param>
|
/// <param name="after">The last artist ID retrieved from the previous request.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<FollowedArtists> GetFollowedArtistsAsync(FollowType followType, int limit = 20, string after = "")
|
public Task<FollowedArtists> GetFollowedArtistsAsync(FollowType followType, int limit = 20, string after = "")
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetFollowedArtists");
|
throw new InvalidOperationException("Auth is required for GetFollowedArtists");
|
||||||
return await DownloadDataAsync<FollowedArtists>(_builder.GetFollowedArtists(limit, after));
|
return DownloadDataAsync<FollowedArtists>(_builder.GetFollowedArtists(limit, after));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -642,9 +642,8 @@ namespace SpotifyAPI.Web
|
|||||||
{
|
{
|
||||||
{"ids", new JArray(ids)}
|
{"ids", new JArray(ids)}
|
||||||
};
|
};
|
||||||
return await
|
return (await UploadDataAsync<ErrorResponse>(_builder.Follow(followType),
|
||||||
UploadDataAsync<ErrorResponse>(_builder.Follow(followType),
|
ob.ToString(Formatting.None), "PUT").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
ob.ToString(Formatting.None), "PUT") ?? new ErrorResponse();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -666,9 +665,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">Artists or the Users Spotify ID</param>
|
/// <param name="id">Artists or the Users Spotify ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> FollowAsync(FollowType followType, string id)
|
public Task<ErrorResponse> FollowAsync(FollowType followType, string id)
|
||||||
{
|
{
|
||||||
return await FollowAsync(followType, new List<string> { id });
|
return FollowAsync(followType, new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -700,7 +699,7 @@ namespace SpotifyAPI.Web
|
|||||||
{
|
{
|
||||||
{"ids", new JArray(ids)}
|
{"ids", new JArray(ids)}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.Unfollow(followType), ob.ToString(Formatting.None), "DELETE") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.Unfollow(followType), ob.ToString(Formatting.None), "DELETE").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -722,9 +721,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">Artists or the Users Spotify ID</param>
|
/// <param name="id">Artists or the Users Spotify ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> UnfollowAsync(FollowType followType, string id)
|
public Task<ErrorResponse> UnfollowAsync(FollowType followType, string id)
|
||||||
{
|
{
|
||||||
return await UnfollowAsync(followType, new List<string> { id });
|
return UnfollowAsync(followType, new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -752,13 +751,13 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of the artist or the user Spotify IDs to check</param>
|
/// <param name="ids">A list of the artist or the user Spotify IDs to check</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> IsFollowingAsync(FollowType followType, List<string> ids)
|
public Task<ListResponse<bool>> IsFollowingAsync(FollowType followType, List<string> ids)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for IsFollowing");
|
throw new InvalidOperationException("Auth is required for IsFollowing");
|
||||||
|
|
||||||
var url = _builder.IsFollowing(followType, ids);
|
var url = _builder.IsFollowing(followType, ids);
|
||||||
return await DownloadListAsync<bool>(url);
|
return DownloadListAsync<bool>(url);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -780,9 +779,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">Artists or the Users Spotify ID</param>
|
/// <param name="id">Artists or the Users Spotify ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> IsFollowingAsync(FollowType followType, string id)
|
public Task<ListResponse<bool>> IsFollowingAsync(FollowType followType, string id)
|
||||||
{
|
{
|
||||||
return await IsFollowingAsync(followType, new List<string> { id });
|
return IsFollowingAsync(followType, new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -822,13 +821,13 @@ namespace SpotifyAPI.Web
|
|||||||
/// </param>
|
/// </param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> FollowPlaylistAsync(string ownerId, string playlistId, bool showPublic = true)
|
public Task<ErrorResponse> FollowPlaylistAsync(string ownerId, string playlistId, bool showPublic = true)
|
||||||
{
|
{
|
||||||
JObject body = new JObject
|
JObject body = new JObject
|
||||||
{
|
{
|
||||||
{"public", showPublic}
|
{"public", showPublic}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.FollowPlaylist(ownerId, playlistId, showPublic), body.ToString(Formatting.None), "PUT");
|
return UploadDataAsync<ErrorResponse>(_builder.FollowPlaylist(ownerId, playlistId, showPublic), body.ToString(Formatting.None), "PUT");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -850,9 +849,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="playlistId">The Spotify ID of the playlist that is to be no longer followed.</param>
|
/// <param name="playlistId">The Spotify ID of the playlist that is to be no longer followed.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> UnfollowPlaylistAsync(string ownerId, string playlistId)
|
public Task<ErrorResponse> UnfollowPlaylistAsync(string ownerId, string playlistId)
|
||||||
{
|
{
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.UnfollowPlaylist(ownerId, playlistId), "", "DELETE");
|
return UploadDataAsync<ErrorResponse>(_builder.UnfollowPlaylist(ownerId, playlistId), "", "DELETE");
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -880,13 +879,13 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of Spotify User IDs</param>
|
/// <param name="ids">A list of Spotify User IDs</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> IsFollowingPlaylistAsync(string ownerId, string playlistId, List<string> ids)
|
public Task<ListResponse<bool>> IsFollowingPlaylistAsync(string ownerId, string playlistId, List<string> ids)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for IsFollowingPlaylist");
|
throw new InvalidOperationException("Auth is required for IsFollowingPlaylist");
|
||||||
|
|
||||||
var url = _builder.IsFollowingPlaylist(ownerId, playlistId, ids);
|
var url = _builder.IsFollowingPlaylist(ownerId, playlistId, ids);
|
||||||
return await DownloadListAsync<bool>(url);
|
return DownloadListAsync<bool>(url);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -910,9 +909,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">A Spotify User ID</param>
|
/// <param name="id">A Spotify User ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> IsFollowingPlaylistAsync(string ownerId, string playlistId, string id)
|
public Task<ListResponse<bool>> IsFollowingPlaylistAsync(string ownerId, string playlistId, string id)
|
||||||
{
|
{
|
||||||
return await IsFollowingPlaylistAsync(ownerId, playlistId, new List<string> { id });
|
return IsFollowingPlaylistAsync(ownerId, playlistId, new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Follow
|
#endregion Follow
|
||||||
@ -940,7 +939,7 @@ namespace SpotifyAPI.Web
|
|||||||
public async Task<ErrorResponse> SaveTracksAsync(List<string> ids)
|
public async Task<ErrorResponse> SaveTracksAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
JArray array = new JArray(ids);
|
JArray array = new JArray(ids);
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.SaveTracks(), array.ToString(Formatting.None), "PUT") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.SaveTracks(), array.ToString(Formatting.None), "PUT").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -960,9 +959,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">A Spotify ID</param>
|
/// <param name="id">A Spotify ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> SaveTrackAsync(string id)
|
public Task<ErrorResponse> SaveTrackAsync(string id)
|
||||||
{
|
{
|
||||||
return await SaveTracksAsync(new List<string> { id });
|
return SaveTracksAsync(new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -988,11 +987,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<SavedTrack>> GetSavedTracksAsync(int limit = 20, int offset = 0, string market = "")
|
public Task<Paging<SavedTrack>> GetSavedTracksAsync(int limit = 20, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetSavedTracks");
|
throw new InvalidOperationException("Auth is required for GetSavedTracks");
|
||||||
return await DownloadDataAsync<Paging<SavedTrack>>(_builder.GetSavedTracks(limit, offset, market));
|
return DownloadDataAsync<Paging<SavedTrack>>(_builder.GetSavedTracks(limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1016,7 +1015,7 @@ namespace SpotifyAPI.Web
|
|||||||
public async Task<ErrorResponse> RemoveSavedTracksAsync(List<string> ids)
|
public async Task<ErrorResponse> RemoveSavedTracksAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
JArray array = new JArray(ids);
|
JArray array = new JArray(ids);
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.RemoveSavedTracks(), array.ToString(Formatting.None), "DELETE") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.RemoveSavedTracks(), array.ToString(Formatting.None), "DELETE").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1040,12 +1039,12 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of the Spotify IDs.</param>
|
/// <param name="ids">A list of the Spotify IDs.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> CheckSavedTracksAsync(List<string> ids)
|
public Task<ListResponse<bool>> CheckSavedTracksAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for CheckSavedTracks");
|
throw new InvalidOperationException("Auth is required for CheckSavedTracks");
|
||||||
var url = _builder.CheckSavedTracks(ids);
|
var url = _builder.CheckSavedTracks(ids);
|
||||||
return await DownloadListAsync<bool>(url);
|
return DownloadListAsync<bool>(url);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1069,7 +1068,7 @@ namespace SpotifyAPI.Web
|
|||||||
public async Task<ErrorResponse> SaveAlbumsAsync(List<string> ids)
|
public async Task<ErrorResponse> SaveAlbumsAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
JArray array = new JArray(ids);
|
JArray array = new JArray(ids);
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.SaveAlbums(), array.ToString(Formatting.None), "PUT") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.SaveAlbums(), array.ToString(Formatting.None), "PUT").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1089,9 +1088,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">A Spotify ID</param>
|
/// <param name="id">A Spotify ID</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> SaveAlbumAsync(string id)
|
public Task<ErrorResponse> SaveAlbumAsync(string id)
|
||||||
{
|
{
|
||||||
return await SaveAlbumsAsync(new List<string> { id });
|
return SaveAlbumsAsync(new List<string> { id });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1117,11 +1116,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<SavedAlbum>> GetSavedAlbumsAsync(int limit = 20, int offset = 0, string market = "")
|
public Task<Paging<SavedAlbum>> GetSavedAlbumsAsync(int limit = 20, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetSavedAlbumsAsync");
|
throw new InvalidOperationException("Auth is required for GetSavedAlbumsAsync");
|
||||||
return await DownloadDataAsync<Paging<SavedAlbum>>(_builder.GetSavedAlbums(limit, offset, market));
|
return DownloadDataAsync<Paging<SavedAlbum>>(_builder.GetSavedAlbums(limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1145,7 +1144,7 @@ namespace SpotifyAPI.Web
|
|||||||
public async Task<ErrorResponse> RemoveSavedAlbumsAsync(List<string> ids)
|
public async Task<ErrorResponse> RemoveSavedAlbumsAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
JArray array = new JArray(ids);
|
JArray array = new JArray(ids);
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.RemoveSavedAlbums(), array.ToString(Formatting.None), "DELETE") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.RemoveSavedAlbums(), array.ToString(Formatting.None), "DELETE").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1169,12 +1168,12 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of the Spotify IDs.</param>
|
/// <param name="ids">A list of the Spotify IDs.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ListResponse<bool>> CheckSavedAlbumsAsync(List<string> ids)
|
public Task<ListResponse<bool>> CheckSavedAlbumsAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for CheckSavedAlbumsAsync");
|
throw new InvalidOperationException("Auth is required for CheckSavedAlbumsAsync");
|
||||||
var url = _builder.CheckSavedAlbums(ids);
|
var url = _builder.CheckSavedAlbums(ids);
|
||||||
return await DownloadListAsync<bool>(url);
|
return DownloadListAsync<bool>(url);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Library
|
#endregion Library
|
||||||
@ -1206,9 +1205,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offest">The index of the first entity to return. Default: 0 (i.e., the first track). Use with limit to get the next set of entities.</param>
|
/// <param name="offest">The index of the first entity to return. Default: 0 (i.e., the first track). Use with limit to get the next set of entities.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<FullTrack>> GetUsersTopTracksAsync(TimeRangeType timeRange = TimeRangeType.MediumTerm, int limit = 20, int offest = 0)
|
public Task<Paging<FullTrack>> GetUsersTopTracksAsync(TimeRangeType timeRange = TimeRangeType.MediumTerm, int limit = 20, int offest = 0)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Paging<FullTrack>>(_builder.GetUsersTopTracks(timeRange, limit, offest));
|
return DownloadDataAsync<Paging<FullTrack>>(_builder.GetUsersTopTracks(timeRange, limit, offest));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1236,9 +1235,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offest">The index of the first entity to return. Default: 0 (i.e., the first track). Use with limit to get the next set of entities.</param>
|
/// <param name="offest">The index of the first entity to return. Default: 0 (i.e., the first track). Use with limit to get the next set of entities.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<FullArtist>> GetUsersTopArtistsAsync(TimeRangeType timeRange = TimeRangeType.MediumTerm, int limit = 20, int offest = 0)
|
public Task<Paging<FullArtist>> GetUsersTopArtistsAsync(TimeRangeType timeRange = TimeRangeType.MediumTerm, int limit = 20, int offest = 0)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<Paging<FullArtist>>(_builder.GetUsersTopArtists(timeRange, limit, offest));
|
return DownloadDataAsync<Paging<FullArtist>>(_builder.GetUsersTopArtists(timeRange, limit, offest));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
@ -1268,11 +1267,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="offset">The index of the first playlist to return. Default: 0 (the first object)</param>
|
/// <param name="offset">The index of the first playlist to return. Default: 0 (the first object)</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<SimplePlaylist>> GetUserPlaylistsAsync(string userId, int limit = 20, int offset = 0)
|
public Task<Paging<SimplePlaylist>> GetUserPlaylistsAsync(string userId, int limit = 20, int offset = 0)
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetUserPlaylists");
|
throw new InvalidOperationException("Auth is required for GetUserPlaylists");
|
||||||
return await DownloadDataAsync<Paging<SimplePlaylist>>(_builder.GetUserPlaylists(userId, limit, offset));
|
return DownloadDataAsync<Paging<SimplePlaylist>>(_builder.GetUserPlaylists(userId, limit, offset));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1306,11 +1305,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<FullPlaylist> GetPlaylistAsync(string userId, string playlistId, string fields = "", string market = "")
|
public Task<FullPlaylist> GetPlaylistAsync(string userId, string playlistId, string fields = "", string market = "")
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetPlaylist");
|
throw new InvalidOperationException("Auth is required for GetPlaylist");
|
||||||
return await DownloadDataAsync<FullPlaylist>(_builder.GetPlaylist(userId, playlistId, fields, market));
|
return DownloadDataAsync<FullPlaylist>(_builder.GetPlaylist(userId, playlistId, fields, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1348,11 +1347,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Paging<PlaylistTrack>> GetPlaylistTracksAsync(string userId, string playlistId, string fields = "", int limit = 100, int offset = 0, string market = "")
|
public Task<Paging<PlaylistTrack>> GetPlaylistTracksAsync(string userId, string playlistId, string fields = "", int limit = 100, int offset = 0, string market = "")
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetPlaylistTracks");
|
throw new InvalidOperationException("Auth is required for GetPlaylistTracks");
|
||||||
return await DownloadDataAsync<Paging<PlaylistTrack>>(_builder.GetPlaylistTracks(userId, playlistId, fields, limit, offset, market));
|
return DownloadDataAsync<Paging<PlaylistTrack>>(_builder.GetPlaylistTracks(userId, playlistId, fields, limit, offset, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1393,14 +1392,14 @@ namespace SpotifyAPI.Web
|
|||||||
/// </param>
|
/// </param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<FullPlaylist> CreatePlaylistAsync(string userId, string playlistName, bool isPublic = true)
|
public Task<FullPlaylist> CreatePlaylistAsync(string userId, string playlistName, bool isPublic = true)
|
||||||
{
|
{
|
||||||
JObject body = new JObject
|
JObject body = new JObject
|
||||||
{
|
{
|
||||||
{"name", playlistName},
|
{"name", playlistName},
|
||||||
{"public", isPublic}
|
{"public", isPublic}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<FullPlaylist>(_builder.CreatePlaylist(userId, playlistName, isPublic), body.ToString(Formatting.None));
|
return UploadDataAsync<FullPlaylist>(_builder.CreatePlaylist(userId, playlistName, isPublic), body.ToString(Formatting.None));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1438,7 +1437,7 @@ namespace SpotifyAPI.Web
|
|||||||
body.Add("name", newName);
|
body.Add("name", newName);
|
||||||
if (newPublic != null)
|
if (newPublic != null)
|
||||||
body.Add("public", newPublic);
|
body.Add("public", newPublic);
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.UpdatePlaylist(userId, playlistId), body.ToString(Formatting.None), "PUT") ?? new ErrorResponse();
|
return (await UploadDataAsync<ErrorResponse>(_builder.UpdatePlaylist(userId, playlistId), body.ToString(Formatting.None), "PUT").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1474,7 +1473,7 @@ namespace SpotifyAPI.Web
|
|||||||
{
|
{
|
||||||
{"uris", new JArray(uris.Take(100))}
|
{"uris", new JArray(uris.Take(100))}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.ReplacePlaylistTracks(userId, playlistId), body.ToString(Formatting.None), "PUT") ?? new ErrorResponse();
|
return await (UploadDataAsync<ErrorResponse>(_builder.ReplacePlaylistTracks(userId, playlistId), body.ToString(Formatting.None), "PUT").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1514,7 +1513,7 @@ namespace SpotifyAPI.Web
|
|||||||
{
|
{
|
||||||
{"tracks", JArray.FromObject(uris.Take(100))}
|
{"tracks", JArray.FromObject(uris.Take(100))}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.RemovePlaylistTracks(userId, playlistId, uris), body.ToString(Formatting.None), "DELETE") ?? new ErrorResponse();
|
return await (UploadDataAsync<ErrorResponse>(_builder.RemovePlaylistTracks(userId, playlistId, uris), body.ToString(Formatting.None), "DELETE").ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1538,9 +1537,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="uri">Spotify URI</param>
|
/// <param name="uri">Spotify URI</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> RemovePlaylistTrackAsync(string userId, string playlistId, DeleteTrackUri uri)
|
public Task<ErrorResponse> RemovePlaylistTrackAsync(string userId, string playlistId, DeleteTrackUri uri)
|
||||||
{
|
{
|
||||||
return await RemovePlaylistTracksAsync(userId, playlistId, new List<DeleteTrackUri> { uri });
|
return RemovePlaylistTracksAsync(userId, playlistId, new List<DeleteTrackUri> { uri });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1576,7 +1575,7 @@ namespace SpotifyAPI.Web
|
|||||||
{
|
{
|
||||||
{"uris", JArray.FromObject(uris.Take(100))}
|
{"uris", JArray.FromObject(uris.Take(100))}
|
||||||
};
|
};
|
||||||
return await UploadDataAsync<ErrorResponse>(_builder.AddPlaylistTracks(userId, playlistId, uris, position), body.ToString(Formatting.None)) ?? new ErrorResponse();
|
return await (UploadDataAsync<ErrorResponse>(_builder.AddPlaylistTracks(userId, playlistId, uris, position), body.ToString(Formatting.None)).ConfigureAwait(false)) ?? new ErrorResponse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1602,9 +1601,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="position">The position to insert the tracks, a zero-based index</param>
|
/// <param name="position">The position to insert the tracks, a zero-based index</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<ErrorResponse> AddPlaylistTrackAsync(string userId, string playlistId, string uri, int? position = null)
|
public Task<ErrorResponse> AddPlaylistTrackAsync(string userId, string playlistId, string uri, int? position = null)
|
||||||
{
|
{
|
||||||
return await AddPlaylistTracksAsync(userId, playlistId, new List<string> { uri }, position);
|
return AddPlaylistTracksAsync(userId, playlistId, new List<string> { uri }, position);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1642,7 +1641,7 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="snapshotId">The playlist's snapshot ID against which you want to make the changes.</param>
|
/// <param name="snapshotId">The playlist's snapshot ID against which you want to make the changes.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<Snapshot> ReorderPlaylistAsync(string userId, string playlistId, int rangeStart, int insertBefore, int rangeLength = 1, string snapshotId = "")
|
public Task<Snapshot> ReorderPlaylistAsync(string userId, string playlistId, int rangeStart, int insertBefore, int rangeLength = 1, string snapshotId = "")
|
||||||
{
|
{
|
||||||
JObject body = new JObject
|
JObject body = new JObject
|
||||||
{
|
{
|
||||||
@ -1653,7 +1652,7 @@ namespace SpotifyAPI.Web
|
|||||||
};
|
};
|
||||||
if (!string.IsNullOrEmpty(snapshotId))
|
if (!string.IsNullOrEmpty(snapshotId))
|
||||||
body.Add("snapshot_id", snapshotId);
|
body.Add("snapshot_id", snapshotId);
|
||||||
return await UploadDataAsync<Snapshot>(_builder.ReorderPlaylist(userId, playlistId), body.ToString(Formatting.None), "PUT");
|
return UploadDataAsync<Snapshot>(_builder.ReorderPlaylist(userId, playlistId), body.ToString(Formatting.None), "PUT");
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Playlists
|
#endregion Playlists
|
||||||
@ -1677,11 +1676,11 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<PrivateProfile> GetPrivateProfileAsync()
|
public Task<PrivateProfile> GetPrivateProfileAsync()
|
||||||
{
|
{
|
||||||
if (!UseAuth)
|
if (!UseAuth)
|
||||||
throw new InvalidOperationException("Auth is required for GetPrivateProfile");
|
throw new InvalidOperationException("Auth is required for GetPrivateProfile");
|
||||||
return await DownloadDataAsync<PrivateProfile>(_builder.GetPrivateProfile());
|
return DownloadDataAsync<PrivateProfile>(_builder.GetPrivateProfile());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1699,9 +1698,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="userId">The user's Spotify user ID.</param>
|
/// <param name="userId">The user's Spotify user ID.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<PublicProfile> GetPublicProfileAsync(string userId)
|
public Task<PublicProfile> GetPublicProfileAsync(string userId)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<PublicProfile>(_builder.GetPublicProfile(userId));
|
return DownloadDataAsync<PublicProfile>(_builder.GetPublicProfile(userId));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Profiles
|
#endregion Profiles
|
||||||
@ -1725,9 +1724,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of the Spotify IDs for the tracks. Maximum: 50 IDs.</param>
|
/// <param name="ids">A list of the Spotify IDs for the tracks. Maximum: 50 IDs.</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<SeveralTracks> GetSeveralTracksAsync(List<string> ids, string market = "")
|
public Task<SeveralTracks> GetSeveralTracksAsync(List<string> ids, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralTracks>(_builder.GetSeveralTracks(ids, market));
|
return DownloadDataAsync<SeveralTracks>(_builder.GetSeveralTracks(ids, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1747,9 +1746,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">The Spotify ID for the track.</param>
|
/// <param name="id">The Spotify ID for the track.</param>
|
||||||
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
/// <param name="market">An ISO 3166-1 alpha-2 country code. Provide this parameter if you want to apply Track Relinking.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task<FullTrack> GetTrackAsync(string id, string market = "")
|
public Task<FullTrack> GetTrackAsync(string id, string market = "")
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<FullTrack>(_builder.GetTrack(id, market));
|
return DownloadDataAsync<FullTrack>(_builder.GetTrack(id, market));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1769,9 +1768,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="id">The Spotify ID for the track.</param>
|
/// <param name="id">The Spotify ID for the track.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<AudioFeatures> GetAudioFeaturesAsync(string id)
|
public Task<AudioFeatures> GetAudioFeaturesAsync(string id)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<AudioFeatures>(_builder.GetAudioFeatures(id));
|
return DownloadDataAsync<AudioFeatures>(_builder.GetAudioFeatures(id));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -1791,9 +1790,9 @@ namespace SpotifyAPI.Web
|
|||||||
/// <param name="ids">A list of Spotify Track-IDs. Maximum: 100 IDs.</param>
|
/// <param name="ids">A list of Spotify Track-IDs. Maximum: 100 IDs.</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
/// <remarks>AUTH NEEDED</remarks>
|
/// <remarks>AUTH NEEDED</remarks>
|
||||||
public async Task<SeveralAudioFeatures> GetSeveralAudioFeaturesAsync(List<string> ids)
|
public Task<SeveralAudioFeatures> GetSeveralAudioFeaturesAsync(List<string> ids)
|
||||||
{
|
{
|
||||||
return await DownloadDataAsync<SeveralAudioFeatures>(_builder.GetSeveralAudioFeatures(ids));
|
return DownloadDataAsync<SeveralAudioFeatures>(_builder.GetSeveralAudioFeatures(ids));
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion Tracks
|
#endregion Tracks
|
||||||
@ -1812,16 +1811,16 @@ namespace SpotifyAPI.Web
|
|||||||
return GetNextPage<Paging<T>, T>(paging);
|
return GetNextPage<Paging<T>, T>(paging);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<TOut> GetNextPageAsync<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
public Task<TOut> GetNextPageAsync<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
||||||
{
|
{
|
||||||
if (!paging.HasNextPage())
|
if (!paging.HasNextPage())
|
||||||
throw new InvalidOperationException("This Paging-Object has no Next-Page");
|
throw new InvalidOperationException("This Paging-Object has no Next-Page");
|
||||||
return await DownloadDataAsync<TOut>(paging.Next);
|
return DownloadDataAsync<TOut>(paging.Next);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<Paging<T>> GetNextPageAsync<T>(Paging<T> paging)
|
public Task<Paging<T>> GetNextPageAsync<T>(Paging<T> paging)
|
||||||
{
|
{
|
||||||
return await GetNextPageAsync<Paging<T>, T>(paging);
|
return GetNextPageAsync<Paging<T>, T>(paging);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TOut GetPreviousPage<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
public TOut GetPreviousPage<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
||||||
@ -1836,16 +1835,16 @@ namespace SpotifyAPI.Web
|
|||||||
return GetPreviousPage<Paging<T>, T>(paging);
|
return GetPreviousPage<Paging<T>, T>(paging);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<TOut> GetPreviousPageAsync<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
public Task<TOut> GetPreviousPageAsync<TOut, TIn>(Paging<TIn> paging) where TOut : BasicModel
|
||||||
{
|
{
|
||||||
if (!paging.HasPreviousPage())
|
if (!paging.HasPreviousPage())
|
||||||
throw new InvalidOperationException("This Paging-Object has no Previous-Page");
|
throw new InvalidOperationException("This Paging-Object has no Previous-Page");
|
||||||
return await DownloadDataAsync<TOut>(paging.Previous);
|
return DownloadDataAsync<TOut>(paging.Previous);
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task<Paging<T>> GetPreviousPageAsync<T>(Paging<T> paging)
|
public Task<Paging<T>> GetPreviousPageAsync<T>(Paging<T> paging)
|
||||||
{
|
{
|
||||||
return await GetPreviousPageAsync<Paging<T>, T>(paging);
|
return GetPreviousPageAsync<Paging<T>, T>(paging);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ListResponse<T> DownloadList<T>(string url)
|
private ListResponse<T> DownloadList<T>(string url)
|
||||||
@ -1877,8 +1876,8 @@ namespace SpotifyAPI.Web
|
|||||||
ListResponse<T> data = null;
|
ListResponse<T> data = null;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (data != null) { await Task.Delay(RetryAfter); }
|
if (data != null) { await Task.Delay(RetryAfter).ConfigureAwait(false); }
|
||||||
Tuple<ResponseInfo, JToken> res = await DownloadDataAltAsync<JToken>(url);
|
Tuple<ResponseInfo, JToken> res = await DownloadDataAltAsync<JToken>(url).ConfigureAwait(false);
|
||||||
data = ExtractDataToListResponse<T>(res);
|
data = ExtractDataToListResponse<T>(res);
|
||||||
|
|
||||||
lastError = data.Error;
|
lastError = data.Error;
|
||||||
@ -1953,8 +1952,8 @@ namespace SpotifyAPI.Web
|
|||||||
WebClient.SetHeader("Authorization", TokenType + " " + AccessToken);
|
WebClient.SetHeader("Authorization", TokenType + " " + AccessToken);
|
||||||
WebClient.SetHeader("Content-Type", "application/json");
|
WebClient.SetHeader("Content-Type", "application/json");
|
||||||
|
|
||||||
if (response != null) { await Task.Delay(RetryAfter); }
|
if (response != null) { await Task.Delay(RetryAfter).ConfigureAwait(false); }
|
||||||
response = await WebClient.UploadJsonAsync<T>(url, uploadData, method);
|
response = await WebClient.UploadJsonAsync<T>(url, uploadData, method).ConfigureAwait(false);
|
||||||
|
|
||||||
response.Item2.AddResponseInfo(response.Item1);
|
response.Item2.AddResponseInfo(response.Item1);
|
||||||
lastError = response.Item2.Error;
|
lastError = response.Item2.Error;
|
||||||
@ -1996,8 +1995,8 @@ namespace SpotifyAPI.Web
|
|||||||
Tuple<ResponseInfo, T> response = null;
|
Tuple<ResponseInfo, T> response = null;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (response != null) { await Task.Delay(RetryAfter); }
|
if (response != null) { await Task.Delay(RetryAfter).ConfigureAwait(false); }
|
||||||
response = await DownloadDataAltAsync<T>(url);
|
response = await DownloadDataAltAsync<T>(url).ConfigureAwait(false);
|
||||||
|
|
||||||
response.Item2.AddResponseInfo(response.Item1);
|
response.Item2.AddResponseInfo(response.Item1);
|
||||||
lastError = response.Item2.Error;
|
lastError = response.Item2.Error;
|
||||||
|
Loading…
Reference in New Issue
Block a user