Spotify.NET/SpotifyAPI.Web/Models/Request/RecommendationsRequest.cs

119 lines
4.6 KiB
C#
Raw Permalink Normal View History

using System;
using System.Collections.Generic;
namespace SpotifyAPI.Web
{
public class RecommendationsRequest : RequestParams
{
public RecommendationsRequest()
{
Min = new Dictionary<string, string>();
Max = new Dictionary<string, string>();
Target = new Dictionary<string, string>();
SeedArtists = new List<string>();
SeedGenres = new List<string>();
SeedTracks = new List<string>();
}
2020-05-28 15:30:17 +01:00
/// <summary>
/// A comma separated list of Spotify IDs for seed artists.
/// Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
/// </summary>
/// <value></value>
[QueryParam("seed_artists")]
public IList<string> SeedArtists { get; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// A comma separated list of any genres in the set of available genre seeds.
/// Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
/// </summary>
/// <value></value>
[QueryParam("seed_genres")]
public IList<string> SeedGenres { get; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// A comma separated list of Spotify IDs for a seed track.
/// Up to 5 seed values may be provided in any combination of seed_artists, seed_tracks and seed_genres.
/// </summary>
/// <value></value>
[QueryParam("seed_tracks")]
public IList<string> SeedTracks { get; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// The target size of the list of recommended tracks.
/// For seeds with unusually small pools or when highly restrictive filtering is applied,
/// it may be impossible to generate the requested number of recommended tracks.
/// Debugging information for such cases is available in the response. Default: 20. Minimum: 1. Maximum: 100.
/// </summary>
/// <value></value>
[QueryParam("limit")]
public int? Limit { get; set; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// An ISO 3166-1 alpha-2 country code or the string from_token.
/// Provide this parameter if you want to apply Track Relinking.
/// Because min_*, max_* and target_* are applied to pools before relinking, the generated results
/// may not precisely match the filters applied. Original,
/// non-relinked tracks are available via the linked_from attribute of the relinked track response.
/// </summary>
/// <value></value>
[QueryParam("market")]
2020-05-25 17:00:38 +01:00
public string? Market { get; set; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// Multiple values. For each tunable track attribute, a hard floor on the selected track attributes value can be provided.
/// See tunable track attributes below for the list of available options.
/// For example, min_tempo=140 would restrict results to only those tracks with a tempo of greater than 140 beats per minute.
/// DO NOT INCLUDE min_ IN THE KEY
/// </summary>
/// <value></value>
public Dictionary<string, string> Min { get; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// Multiple values. For each tunable track attribute, a hard ceiling on the selected track attributes value can be provided.
/// See tunable track attributes below for the list of available options.
/// For example, max_instrumentalness=0.35 would filter out most tracks that are likely to be instrumental.
/// DO NOT INCLUDE max_ IN THE KEY
/// </summary>
/// <value></value>
public Dictionary<string, string> Max { get; }
2020-05-28 15:30:17 +01:00
/// <summary>
/// Multiple values. For each of the tunable track attributes (below) a target value may be provided.
/// Tracks with the attribute values nearest to the target values will be preferred.
/// For example, you might request target_energy=0.6 and target_danceability=0.8.
/// All target values will be weighed equally in ranking results.
/// DO NOT INCLUDE target_ IN THE KEY
/// </summary>
/// <value></value>
public Dictionary<string, string> Target { get; }
2020-05-02 21:48:21 +01:00
protected override void CustomEnsure()
{
if (SeedArtists.Count == 0 && SeedGenres.Count == 0 && SeedTracks.Count == 0)
{
throw new ArgumentException("At least one of the seeds has to be non-empty");
}
}
protected override void AddCustomQueryParams(Dictionary<string, string> queryParams)
{
Ensure.ArgumentNotNull(queryParams, nameof(queryParams));
foreach (KeyValuePair<string, string> pair in Min)
{
queryParams.Add($"min_{pair.Key}", pair.Value);
}
2020-05-28 15:30:17 +01:00
foreach (KeyValuePair<string, string> pair in Max)
{
queryParams.Add($"max_{pair.Key}", pair.Value);
}
2020-05-28 15:30:17 +01:00
foreach (KeyValuePair<string, string> pair in Target)
{
queryParams.Add($"target_{pair.Key}", pair.Value);
}
}
}
}
2020-05-25 17:00:38 +01:00