All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.wrapper.spotify.requests.data.playlists.AddTracksToPlaylistRequest Maven / Gradle / Ivy

package com.wrapper.spotify.requests.data.playlists;

import com.google.gson.JsonArray;
import com.wrapper.spotify.exceptions.SpotifyWebApiException;
import com.wrapper.spotify.model_objects.special.SnapshotResult;
import com.wrapper.spotify.requests.data.AbstractDataRequest;
import org.apache.http.entity.ContentType;

import java.io.IOException;

/**
 * Add one or more tracks to a user’s playlist.
 * 

* Use this endpoint to add Spotify tracks to a user’s playlist, sending their Spotify URI. * Note that local tracks can’t be added. */ public class AddTracksToPlaylistRequest extends AbstractDataRequest { /** * The private {@link AddTracksToPlaylistRequest} constructor. * * @param builder A {@link AddTracksToPlaylistRequest.Builder}. */ private AddTracksToPlaylistRequest(final Builder builder) { super(builder); } /** * Add tracks to playlist. * * @return A playlist snapshot ID. The snapshot ID can be used to identify your playlist version in future requests. * @throws IOException In case of networking issues. * @throws SpotifyWebApiException The Web API returned an error further specified in this exception's root cause. * @see * Spotify: Version Control and Snapshots */ @SuppressWarnings("unchecked") public SnapshotResult execute() throws IOException, SpotifyWebApiException { return new SnapshotResult.JsonUtil().createModelObject(postJson()); } /** * Builder class for building an {@link AddTracksToPlaylistRequest}. */ public static final class Builder extends AbstractDataRequest.Builder { /** * Create a new {@link AddTracksToPlaylistRequest.Builder}. *

* Adding tracks to the current user's public playlists requires authorization of the {@code playlist-modify-public} * scope; adding tracks to the current user's private playlist (including collaborative playlists) requires the * {@code playlist-modify-private} scope. * * @param accessToken Required. A valid access token from the Spotify Accounts service. * @see Spotify: Using Scopes */ public Builder(final String accessToken) { super(accessToken); } /** * The user ID setter. * * @deprecated Playlist IDs are unique for themselves. This parameter is thus no longer used. * (https://developer.spotify.com/community/news/2018/06/12/changes-to-playlist-uris/) * @param user_id The user's Spotify user ID. * @return An {@link AddTracksToPlaylistRequest.Builder}. * @see Spotify: URIs & IDs */ @Deprecated public Builder user_id(final String user_id) { assert (user_id != null); assert (!user_id.equals("")); return setPathParameter("user_id", user_id); } /** * The playlist ID setter. * * @param playlist_id The Spotify ID for the playlist. * @return An {@link AddTracksToPlaylistRequest.Builder}. * @see Spotify: URIs & IDs */ public Builder playlist_id(final String playlist_id) { assert (playlist_id != null); assert (!playlist_id.equals("")); return setPathParameter("playlist_id", playlist_id); } /** * The track URIs setter. *

* Note: It is likely that passing a large number of track URIs as a query parameter will exceed the maximum * length of the request URI. When adding a large number of tracks it is recommended to pass them * with {@link #uris(JsonArray)}. * * @param uris Optional. A comma-separated list of Spotify track URIs to add. Maximum: 100 track URIs. * @return An {@link AddTracksToPlaylistRequest.Builder}. * @see Spotify: URIs & IDs */ public Builder uris(final String uris) { assert (uris != null); assert (!uris.equals("")); assert (uris.split(",").length <= 100); return setQueryParameter("uris", uris); } /** * The position setter. * * @param position Optional. The position to insert the tracks, a zero-based index. If omitted, the * tracks will be appended to the playlist. Tracks are added in the order they are * listed in the query string or request body. * @return An {@link AddTracksToPlaylistRequest.Builder}. */ public Builder position(final Integer position) { return position(position, false); } /** * The track URIs setter. *

* Note: If the URIs already have been set with {@link #uris(String)}, any URIs listed here will be ignored. * * @param uris Optional. A JSON array of the Spotify track URIs to add. maximum: 100 track URIs. * @return An {@link AddTracksToPlaylistRequest.Builder}. * @see Spotify: URIs & IDs */ public Builder uris(final JsonArray uris) { assert (uris != null); assert (!uris.isJsonNull()); assert (uris.size() <= 100); return setBodyParameter("uris", uris); } /** * The position setter. You can set it in the request query string or request body, depending on the * {@code use_body} parameter. * * @param position Optional. The position to insert the tracks, a zero-based index. If omitted, the * tracks will be appended to the playlist. Tracks are added in the order they are * listed in the query string or request body. * @param use_body Whether to include the position in the request query string or body. * @return An {@link AddTracksToPlaylistRequest.Builder}. */ public Builder position(final Integer position, final Boolean use_body) { assert (position >= 0); if (use_body) { return setBodyParameter("position", position); } else { return setQueryParameter("position", position); } } /** * The request build method. * * @return A custom {@link AddTracksToPlaylistRequest}. */ @Override public AddTracksToPlaylistRequest build() { setContentType(ContentType.APPLICATION_JSON); setPath("/v1/playlists/{playlist_id}/tracks"); return new AddTracksToPlaylistRequest(this); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy