Spotify.NET/SpotifyAPI.Web/Clients/Interfaces/IPlayerClient.cs

209 lines
8.7 KiB
C#
Raw Permalink Normal View History

2020-05-07 17:03:20 +01:00
using System.Net;
using System.Threading.Tasks;
namespace SpotifyAPI.Web
{
/// <summary>
/// Player Endpoints.
/// These endpoints are in beta.
/// While we encourage you to build with them, a situation may arise
/// where we need to disable some or all of the functionality and/or change how
/// they work without prior notice. Please report any issues via our developer community forum.
/// </summary>
2020-05-07 17:03:20 +01:00
public interface IPlayerClient
{
/// <summary>
/// Skips to next track in the users queue.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-skip-users-playback-to-next-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SkipNext();
/// <summary>
/// Skips to next track in the users queue.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-skip-users-playback-to-next-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SkipNext(PlayerSkipNextRequest request);
/// <summary>
/// Set the repeat mode for the users playback. Options are repeat-track, repeat-context, and off.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-set-repeat-mode-on-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SetRepeat(PlayerSetRepeatRequest request);
/// <summary>
/// Transfer playback to a new device and determine if it should start playing.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-transfer-a-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> TransferPlayback(PlayerTransferPlaybackRequest request);
/// <summary>
/// Get the object currently being played on the users Spotify account.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-the-users-currently-playing-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<CurrentlyPlaying> GetCurrentlyPlaying(PlayerCurrentlyPlayingRequest request);
/// <summary>
/// Get information about the users current playback state, including track or episode, progress, and active device.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-information-about-the-users-current-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<CurrentlyPlayingContext> GetCurrentPlayback();
/// <summary>
/// Get information about the users current playback state, including track or episode, progress, and active device.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-information-about-the-users-current-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<CurrentlyPlayingContext> GetCurrentPlayback(PlayerCurrentPlaybackRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Seeks to the given position in the users currently playing track.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-seek-to-position-in-currently-playing-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SeekTo(PlayerSeekToRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Skips to previous track in the users queue.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-skip-users-playback-to-previous-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SkipPrevious();
2020-05-30 22:32:06 +01:00
/// <summary>
/// Skips to previous track in the users queue.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-skip-users-playback-to-previous-track
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SkipPrevious(PlayerSkipPreviousRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Start a new context or resume current playback on the users active device.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-start-a-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> ResumePlayback();
2020-05-30 22:32:06 +01:00
/// <summary>
/// Start a new context or resume current playback on the users active device.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-start-a-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> ResumePlayback(PlayerResumePlaybackRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Pause playback on the users account.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-pause-a-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> PausePlayback();
2020-05-30 22:32:06 +01:00
/// <summary>
/// Pause playback on the users account.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-pause-a-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> PausePlayback(PlayerPausePlaybackRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Set the volume for the users current playback device.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-set-volume-for-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SetVolume(PlayerVolumeRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Get tracks from the current users recently played tracks. Note: Currently doesnt support podcast episodes.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-recently-played
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<CursorPaging<PlayHistoryItem>> GetRecentlyPlayed();
2020-05-30 22:32:06 +01:00
/// <summary>
/// Get tracks from the current users recently played tracks. Note: Currently doesnt support podcast episodes.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-recently-played
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<CursorPaging<PlayHistoryItem>> GetRecentlyPlayed(PlayerRecentlyPlayedRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Get information about a users available devices.
/// </summary>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-get-a-users-available-devices
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<DeviceResponse> GetAvailableDevices();
2020-05-30 22:32:06 +01:00
/// <summary>
/// Toggle shuffle on or off for users playback.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-toggle-shuffle-for-users-playback
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> SetShuffle(PlayerShuffleRequest request);
2020-05-30 22:32:06 +01:00
/// <summary>
/// Add an item to the end of the users current playback queue.
/// </summary>
/// <param name="request">The request-model which contains required and optional parameters.</param>
/// <remarks>
/// https://developer.spotify.com/documentation/web-api/reference-beta/#endpoint-add-to-queue
/// </remarks>
/// <returns></returns>
2020-05-07 17:03:20 +01:00
Task<bool> AddToQueue(PlayerAddToQueueRequest request);
}
}