diff --git a/3rdparty/spotify/LICENSE.md b/3rdparty/spotify/LICENSE.md deleted file mode 100644 index 071536e..0000000 --- a/3rdparty/spotify/LICENSE.md +++ /dev/null @@ -1,21 +0,0 @@ -https://github.com/jwilsson/spotify-web-api-php - -Copyright (c) Jonathan Wilsson - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/3rdparty/spotify/Request.php b/3rdparty/spotify/Request.php deleted file mode 100644 index e4eb4e3..0000000 --- a/3rdparty/spotify/Request.php +++ /dev/null @@ -1,253 +0,0 @@ -lastResponse['body'] = json_decode($body, $this->returnType == self::RETURN_ASSOC); - - if ($status >= 200 && $status <= 299) { - return $this->lastResponse['body']; - } - - $body = json_decode($body); - $error = isset($body->error) ? $body->error : null; - - if (isset($error->message) && isset($error->status)) { - // API call error - throw new SpotifyWebAPIException($error->message, $error->status); - } elseif (isset($body->error_description)) { - // Auth call error - throw new SpotifyWebAPIAuthException($body->error_description, $status); - } else { - // Something went really wrong - throw new SpotifyWebAPIException('An unknown error occurred.', $status); - } - } - - /** - * Parse HTTP response headers. - * - * @param string $headers The raw, unparsed response headers. - * - * @return array Headers as key–value pairs. - */ - protected function parseHeaders($headers) - { - $headers = str_replace("\r\n", "\n", $headers); - $headers = explode("\n", $headers); - - array_shift($headers); - - $parsedHeaders = []; - foreach ($headers as $header) { - list($key, $value) = explode(':', $header, 2); - - $parsedHeaders[$key] = trim($value); - } - - return $parsedHeaders; - } - - /** - * Make a request to the "account" endpoint. - * - * @param string $method The HTTP method to use. - * @param string $uri The URI to request. - * @param array $parameters Optional. Query string parameters or HTTP body, depending on $method. - * @param array $headers Optional. HTTP headers. - * - * @throws SpotifyWebAPIException - * @throws SpotifyWebAPIAuthException - * - * @return array Response data. - * - array|object body The response body. Type is controlled by `Request::setReturnType()`. - * - string headers Response headers. - * - int status HTTP status code. - * - string url The requested URL. - */ - public function account($method, $uri, $parameters = [], $headers = []) - { - return $this->send($method, self::ACCOUNT_URL . $uri, $parameters, $headers); - } - - /** - * Make a request to the "api" endpoint. - * - * @param string $method The HTTP method to use. - * @param string $uri The URI to request. - * @param array $parameters Optional. Query string parameters or HTTP body, depending on $method. - * @param array $headers Optional. HTTP headers. - * - * @throws SpotifyWebAPIException - * @throws SpotifyWebAPIAuthException - * - * @return array Response data. - * - array|object body The response body. Type is controlled by `Request::setReturnType()`. - * - string headers Response headers. - * - int status HTTP status code. - * - string url The requested URL. - */ - public function api($method, $uri, $parameters = [], $headers = []) - { - return $this->send($method, self::API_URL . $uri, $parameters, $headers); - } - - /** - * Get the latest full response from the Spotify API. - * - * @return array Response data. - * - array|object body The response body. Type is controlled by `Request::setReturnType()`. - * - array headers Response headers. - * - int status HTTP status code. - * - string url The requested URL. - */ - public function getLastResponse() - { - return $this->lastResponse; - } - - /** - * Get a value indicating the response body type. - * - * @return string A value indicating if the response body is an object or associative array. - */ - public function getReturnType() - { - return $this->returnType; - } - - /** - * Make a request to Spotify. - * You'll probably want to use one of the convenience methods instead. - * - * @param string $method The HTTP method to use. - * @param string $url The URL to request. - * @param array $parameters Optional. Query string parameters or HTTP body, depending on $method. - * @param array $headers Optional. HTTP headers. - * - * @throws SpotifyWebAPIException - * @throws SpotifyWebAPIAuthException - * - * @return array Response data. - * - array|object body The response body. Type is controlled by `Request::setReturnType()`. - * - array headers Response headers. - * - int status HTTP status code. - * - string url The requested URL. - */ - public function send($method, $url, $parameters = [], $headers = []) - { - // Reset any old responses - $this->lastResponse = []; - - // Sometimes a stringified JSON object is passed - if (is_array($parameters) || is_object($parameters)) { - $parameters = http_build_query($parameters); - } - - $mergedHeaders = []; - foreach ($headers as $key => $val) { - $mergedHeaders[] = "$key: $val"; - } - - $options = [ - CURLOPT_CAINFO => __DIR__ . '/cacert.pem', - CURLOPT_ENCODING => '', - CURLOPT_HEADER => true, - CURLOPT_HTTPHEADER => $mergedHeaders, - CURLOPT_RETURNTRANSFER => true, - ]; - - $url = rtrim($url, '/'); - $method = strtoupper($method); - - switch ($method) { - case 'DELETE': // No break - case 'PUT': - $options[CURLOPT_CUSTOMREQUEST] = $method; - $options[CURLOPT_POSTFIELDS] = $parameters; - - break; - case 'POST': - $options[CURLOPT_POST] = true; - $options[CURLOPT_POSTFIELDS] = $parameters; - - break; - default: - $options[CURLOPT_CUSTOMREQUEST] = $method; - - if ($parameters) { - $url .= '/?' . $parameters; - } - - break; - } - - $options[CURLOPT_URL] = $url; - - $ch = curl_init(); - curl_setopt_array($ch, $options); - - $response = curl_exec($ch); - - if (curl_error($ch)) { - throw new SpotifyWebAPIException('cURL transport error: ' . curl_errno($ch) . ' ' . curl_error($ch)); - } - - list($headers, $body) = explode("\r\n\r\n", $response, 2); - - // Skip the first set of headers for proxied requests - if (preg_match('/^HTTP\/1\.\d 200 Connection established$/', $headers) === 1) { - list($headers, $body) = explode("\r\n\r\n", $body, 2); - } - - $status = (int) curl_getinfo($ch, CURLINFO_HTTP_CODE); - $headers = $this->parseHeaders($headers); - - $this->lastResponse = [ - 'headers' => $headers, - 'status' => $status, - 'url' => $url, - ]; - - // Run this here since we might throw - $body = $this->parseBody($body, $status); - - curl_close($ch); - - return $this->lastResponse; - } - - /** - * Set the return type for the response body. - * - * @param string $returnType One of the `Request::RETURN_*` constants. - * - * @return void - */ - public function setReturnType($returnType) - { - $this->returnType = $returnType; - } -} diff --git a/3rdparty/spotify/Session.php b/3rdparty/spotify/Session.php deleted file mode 100644 index 142a5b1..0000000 --- a/3rdparty/spotify/Session.php +++ /dev/null @@ -1,279 +0,0 @@ -setClientId($clientId); - $this->setClientSecret($clientSecret); - $this->setRedirectUri($redirectUri); - - $this->request = $request ?: new Request(); - } - - /** - * Get the authorization URL. - * - * @param array|object $options Optional. Options for the authorization URL. - * - array scope Optional. Scope(s) to request from the user. - * - boolean show_dialog Optional. Whether or not to force the user to always approve the app. Default is false. - * - string state Optional. A CSRF token. - * - * @return string The authorization URL. - */ - public function getAuthorizeUrl($options = []) - { - $options = (array) $options; - - $parameters = [ - 'client_id' => $this->getClientId(), - 'redirect_uri' => $this->getRedirectUri(), - 'response_type' => 'code', - 'scope' => isset($options['scope']) ? implode(' ', $options['scope']) : null, - 'show_dialog' => !empty($options['show_dialog']) ? 'true' : null, - 'state' => isset($options['state']) ? $options['state'] : null, - ]; - - return Request::ACCOUNT_URL . '/authorize/?' . http_build_query($parameters); - } - - /** - * Get the access token. - * - * @return string The access token. - */ - public function getAccessToken() - { - return $this->accessToken; - } - - /** - * Get the client ID. - * - * @return string The client ID. - */ - public function getClientId() - { - return $this->clientId; - } - - /** - * Get the client secret. - * - * @return string The client secret. - */ - public function getClientSecret() - { - return $this->clientSecret; - } - - /** - * Get the access token expiration time. - * - * @return int A Unix timestamp indicating the token expiration time. - */ - public function getTokenExpiration() - { - return $this->expirationTime; - } - - /** - * Get the client's redirect URI. - * - * @return string The redirect URI. - */ - public function getRedirectUri() - { - return $this->redirectUri; - } - - /** - * Get the refresh token. - * - * @return string The refresh token. - */ - public function getRefreshToken() - { - return $this->refreshToken; - } - - /** - * Get the scope for the current access token - * - * @return array The scope for the current access token - */ - public function getScope() - { - return explode(' ', $this->scope); - } - - /** - * Refresh an access token. - * - * @param string $refreshToken The refresh token to use. - * - * @return bool Whether the access token was successfully refreshed. - */ - public function refreshAccessToken($refreshToken) - { - $payload = base64_encode($this->getClientId() . ':' . $this->getClientSecret()); - - $parameters = [ - 'grant_type' => 'refresh_token', - 'refresh_token' => $refreshToken, - ]; - - $headers = [ - 'Authorization' => 'Basic ' . $payload, - ]; - - $response = $this->request->account('POST', '/api/token', $parameters, $headers); - $response = $response['body']; - - if (isset($response->access_token)) { - $this->accessToken = $response->access_token; - $this->expirationTime = time() + $response->expires_in; - $this->scope = isset($response->scope) ? $response->scope : $this->scope; - - if (isset($response->refresh_token)) { - $this->refreshToken = $response->refresh_token; - } elseif (empty($this->refreshToken)) { - $this->refreshToken = $refreshToken; - } - - return true; - } - - return false; - } - - /** - * Request an access token using the Client Credentials Flow. - * - * @return bool True when an access token was successfully granted, false otherwise. - */ - public function requestCredentialsToken() - { - $payload = base64_encode($this->getClientId() . ':' . $this->getClientSecret()); - - $parameters = [ - 'grant_type' => 'client_credentials', - ]; - - $headers = [ - 'Authorization' => 'Basic ' . $payload, - ]; - - $response = $this->request->account('POST', '/api/token', $parameters, $headers); - $response = $response['body']; - - if (isset($response->access_token)) { - $this->accessToken = $response->access_token; - $this->expirationTime = time() + $response->expires_in; - $this->scope = isset($response->scope) ? $response->scope : $this->scope; - - return true; - } - - return false; - } - - /** - * Request an access token given an authorization code. - * - * @param string $authorizationCode The authorization code from Spotify. - * - * @return bool True when the access token was successfully granted, false otherwise. - */ - public function requestAccessToken($authorizationCode) - { - $parameters = [ - 'client_id' => $this->getClientId(), - 'client_secret' => $this->getClientSecret(), - 'code' => $authorizationCode, - 'grant_type' => 'authorization_code', - 'redirect_uri' => $this->getRedirectUri(), - ]; - - $response = $this->request->account('POST', '/api/token', $parameters, []); - $response = $response['body']; - - if (isset($response->refresh_token) && isset($response->access_token)) { - $this->refreshToken = $response->refresh_token; - $this->accessToken = $response->access_token; - $this->expirationTime = time() + $response->expires_in; - $this->scope = isset($response->scope) ? $response->scope : $this->scope; - - return true; - } - - return false; - } - - /** - * Set the client ID. - * - * @param string $clientId The client ID. - * - * @return void - */ - public function setClientId($clientId) - { - $this->clientId = $clientId; - } - - /** - * Set the client secret. - * - * @param string $clientSecret The client secret. - * - * @return void - */ - public function setClientSecret($clientSecret) - { - $this->clientSecret = $clientSecret; - } - - /** - * Set the client's redirect URI. - * - * @param string $redirectUri The redirect URI. - * - * @return void - */ - public function setRedirectUri($redirectUri) - { - $this->redirectUri = $redirectUri; - } - - /** - * Set the session's refresh token. - * - * @param string $refreshToken The refresh token. - * - * @return void - */ - public function setRefreshToken($refreshToken) - { - $this->refreshToken = $refreshToken; - } -} diff --git a/3rdparty/spotify/SpotifyWebAPI.php b/3rdparty/spotify/SpotifyWebAPI.php deleted file mode 100644 index 8137ba1..0000000 --- a/3rdparty/spotify/SpotifyWebAPI.php +++ /dev/null @@ -1,1727 +0,0 @@ -request = $request ?: new Request(); - } - - /** - * Add authorization headers. - * - * @return array Authorization headers. - */ - protected function authHeaders() - { - $headers = []; - - if ($this->accessToken) { - $headers['Authorization'] = 'Bearer ' . $this->accessToken; - } - - return $headers; - } - - /** - * Convert Spotify object IDs to Spotify URIs. - * - * @param array|string $ids ID(s) to convert. - * @param string $type Spotify object type. - * - * @return array|string Spotify URI(s). - */ - protected function idToUri($ids, $type) - { - $type = 'spotify:' . $type . ':'; - - $ids = array_map(function ($id) use ($type) { - if (substr($id, 0, strlen($type)) != $type) { - $id = $type . $id; - } - - return $id; - }, (array) $ids); - - return (count($ids) == 1) ? $ids[0] : $ids; - } - - /** - * Convert Spotify URIs to Spotify object IDs - * - * @param array|string $uriIds URI(s) to convert. - * @param string $type Spotify object type. - * - * @return array|string Spotify ID(s). - */ - protected function uriToId($uriIds, $type) - { - $type = 'spotify:' . $type . ':'; - - $uriIds = array_map(function ($id) use ($type) { - return str_replace($type, '', $id); - }, (array) $uriIds); - - return (count($uriIds) == 1) ? $uriIds[0] : $uriIds; - } - - /** - * Add albums to the current user's Spotify library. - * https://developer.spotify.com/web-api/save-albums-user/ - * - * @param string|array $albums ID(s) or Spotify URI(s) of the album(s) to add. - * - * @return bool Whether the albums was successfully added. - */ - public function addMyAlbums($albums) - { - $albums = $this->uriToId($albums, 'album'); - $albums = json_encode((array) $albums); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/albums'; - - $this->lastResponse = $this->request->api('PUT', $uri, $albums, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Add tracks to the current user's Spotify library. - * https://developer.spotify.com/web-api/save-tracks-user/ - * - * @param string|array $tracks ID(s) or Spotify URI(s) of the track(s) to add. - * - * @return bool Whether the tracks was successfully added. - */ - public function addMyTracks($tracks) - { - $tracks = $this->uriToId($tracks, 'track'); - $tracks = json_encode((array) $tracks); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/tracks'; - - $this->lastResponse = $this->request->api('PUT', $uri, $tracks, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Add tracks to a user's playlist. - * https://developer.spotify.com/web-api/add-tracks-to-playlist/ - * - * @param string $userId ID of the user who owns the playlist. - * @param string $playlistId ID of the playlist to add tracks to. - * @param string|array $tracks ID(s) or Spotify URI(s) of the track(s) to add. - * @param array|object $options Optional. Options for the new tracks. - * - int position Optional. Zero-based track position in playlist. Tracks will be appened if omitted or false. - * - * @return bool Whether the tracks was successfully added. - */ - public function addUserPlaylistTracks($userId, $playlistId, $tracks, $options = []) - { - $options = http_build_query($options); - - $tracks = $this->idToUri($tracks, 'track'); - $tracks = json_encode((array) $tracks); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - // We need to manually append data to the URI since it's a POST request - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/tracks?' . $options; - - $this->lastResponse = $this->request->api('POST', $uri, $tracks, $headers); - - return $this->lastResponse['status'] == 201; - } - - /** - * Change the current user's playback device. - * https://developer.spotify.com/web-api/transfer-a-users-playback/ - * - * @param array|object $options Options for the playback transfer. - * - string|array device_ids Required. ID of the device to switch to. - * - bool play Optional. Whether to start playing on the new device - * - * @return bool Whether the playback device was successfully changed. - */ - public function changeMyDevice($options) - { - $options = (array) $options; - $options['device_ids'] = (array) $options['device_ids']; - $options = json_encode($options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/player'; - - $this->lastResponse = $this->request->api('PUT', $uri, $options, $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Change playback volume for the current user. - * https://developer.spotify.com/web-api/set-volume-for-users-playback/ - * - * @param array|object $options Optional. Options for the playback volume. - * - int volume_percent Required. The volume to set. - * - string device_id Optional. ID of the device to target. - * - * @return bool Whether the playback volume was successfully changed. - */ - public function changeVolume($options) - { - $options = http_build_query($options); - - $headers = $this->authHeaders(); - - // We need to manually append data to the URI since it's a PUT request - $uri = '/v1/me/player/volume?' . $options; - - $this->lastResponse = $this->request->api('PUT', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Create a new playlist for a user. - * https://developer.spotify.com/web-api/create-playlist/ - * - * @param string $userId ID or Spotify URI of the user to create the playlist for. - * @param array|object $options Options for the new playlist. - * - string name Required. Name of the playlist. - * - bool public Optional. Whether the playlist should be public or not. - * - * @return array|object The new playlist. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function createUserPlaylist($userId, $options) - { - $options = json_encode($options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $uri = '/v1/users/' . $userId . '/playlists'; - - $this->lastResponse = $this->request->api('POST', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Check to see if the current user is following one or more artists or other Spotify users. - * https://developer.spotify.com/web-api/check-current-user-follows/ - * - * @param string $type The type to check: either 'artist' or 'user'. - * @param string|array $ids ID(s) or Spotify URI(s) of the user(s) or artist(s) to check for. - * - * @return array Whether each user or artist is followed. - */ - public function currentUserFollows($type, $ids) - { - $ids = $this->uriToId($ids, $type); - $ids = implode(',', (array) $ids); - - $options = [ - 'ids' => $ids, - 'type' => $type, - ]; - - $headers = $this->authHeaders(); - - $uri = '/v1/me/following/contains'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Delete albums from current user's Spotify library. - * https://developer.spotify.com/web-api/remove-albums-user/ - * - * @param string|array $albums ID(s) or Spotify URI(s) of the album(s) to delete. - * - * @return bool Whether the albums was successfully deleted. - */ - public function deleteMyAlbums($albums) - { - $albums = $this->uriToId($albums, 'album'); - $albums = json_encode((array) $albums); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/albums'; - - $this->lastResponse = $this->request->api('DELETE', $uri, $albums, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Delete tracks from current user's Spotify library. - * https://developer.spotify.com/web-api/remove-tracks-user/ - * - * @param string|array $tracks ID(s) or Spotify URI(s) of the track(s) to delete. - * - * @return bool Whether the tracks was successfully deleted. - */ - public function deleteMyTracks($tracks) - { - $tracks = $this->uriToId($tracks, 'track'); - $tracks = json_encode((array) $tracks); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/tracks'; - - $this->lastResponse = $this->request->api('DELETE', $uri, $tracks, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Delete tracks from a playlist and retrieve a new snapshot ID. - * https://developer.spotify.com/web-api/remove-tracks-playlist/ - * - * @param string $userId ID or Spotify URI of the user who owns the playlist. - * @param string $playlistId ID or Spotify URI of the playlist to delete tracks from. - * @param array $tracks An array with the key "tracks" containing arrays or objects with tracks to delete. - * Or an array with the key "positions" containing integer positions of the tracks to delete. - * For legacy reasons, the "tracks" key can be omitted but its use is deprecated. - * If the "tracks" key is used, the following fields are also available: - * - string id Required. Track ID or Spotify URI. - * - int|array positions Optional. The track's position(s) in the playlist. - * @param string $snapshotId Required when `$tracks['positions']` is used, optional otherwise. - * The playlist's snapshot ID. - * - * @return string|bool A new snapshot ID or false if the tracks weren't successfully deleted. - */ - public function deleteUserPlaylistTracks($userId, $playlistId, $tracks, $snapshotId = '') - { - $options = []; - - if ($snapshotId) { - $options['snapshot_id'] = $snapshotId; - } - - if (isset($tracks['positions'])) { - $options['positions'] = $tracks['positions']; - } else { - $tracks = isset($tracks['tracks']) ? $tracks['tracks'] : $tracks; - - $options['tracks'] = array_map(function ($track) { - $track = (array) $track; - - if (isset($track['positions'])) { - $track['positions'] = (array) $track['positions']; - } - - $track['uri'] = $this->idToUri($track['id'], 'track'); - - unset($track['id']); - - return $track; - }, $tracks); - } - - $options = json_encode($options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/tracks'; - - $this->lastResponse = $this->request->api('DELETE', $uri, $options, $headers); - $body = $this->lastResponse['body']; - - if (isset($body->snapshot_id)) { - return $body->snapshot_id; - } - - return false; - } - - /** - * Add the current user as a follower of one or more artists or other Spotify users. - * https://developer.spotify.com/web-api/follow-artists-users/ - * - * @param string $type The type to check: either 'artist' or 'user'. - * @param string|array $ids ID(s) or Spotify URI(s) of the user(s) or artist(s) to follow. - * - * @return bool Whether the artist or user was successfully followed. - */ - public function followArtistsOrUsers($type, $ids) - { - $ids = $this->uriToId($ids, $type); - $ids = json_encode([ - 'ids' => (array) $ids, - ]); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - // We need to manually append data to the URI since it's a PUT request - $uri = '/v1/me/following?type=' . $type; - - $this->lastResponse = $this->request->api('PUT', $uri, $ids, $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Add the current user as a follower of a playlist. - * https://developer.spotify.com/web-api/follow-playlist/ - * - * @param string $userId ID or Spotify URI of the user who owns the playlist. - * @param string $playlistId ID or Spotify URI of the playlist to follow. - * @param array|object $options Optional. Options for the followed playlist. - * - bool public Optional. Whether the playlist should be followed publicly or not. - * - * @return bool Whether the playlist was successfully followed. - */ - public function followPlaylist($userId, $playlistId, $options = []) - { - $options = json_encode((object) $options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/followers'; - - $this->lastResponse = $this->request->api('PUT', $uri, $options, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Get a album. - * https://developer.spotify.com/web-api/get-album/ - * - * @param string $albumId ID or Spotify URI of the album. - * - * @return array|object The requested album. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getAlbum($albumId) - { - $headers = $this->authHeaders(); - - $albumId = $this->uriToId($albumId, 'album'); - $uri = '/v1/albums/' . $albumId; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get multiple albums. - * https://developer.spotify.com/web-api/get-several-albums/ - * - * @param array $albumIds IDs or Spotify URIs of the albums. - * @param array|object $options Optional. Options for the albums. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The requested albums. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getAlbums($albumIds, $options = []) - { - $albumIds = $this->uriToId($albumIds, 'album'); - - $options = (array) $options; - $options['ids'] = implode(',', (array) $albumIds); - - $headers = $this->authHeaders(); - - $uri = '/v1/albums/'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a album's tracks. - * https://developer.spotify.com/web-api/get-albums-tracks/ - * - * @param string $albumId ID or Spotify URI of the album. - * @param array|object $options Optional. Options for the tracks. - * - int limit Optional. Limit the number of tracks. - * - int offset Optional. Number of tracks to skip. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The requested album tracks. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getAlbumTracks($albumId, $options = []) - { - $headers = $this->authHeaders(); - - $albumId = $this->uriToId($albumId, 'album'); - $uri = '/v1/albums/' . $albumId . '/tracks'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get an artist. - * https://developer.spotify.com/web-api/get-artist/ - * - * @param string $artistId ID or Spotify URI of the artist. - * - * @return array|object The requested artist. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getArtist($artistId) - { - $headers = $this->authHeaders(); - - $artistId = $this->uriToId($artistId, 'artist'); - $uri = '/v1/artists/' . $artistId; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get multiple artists. - * https://developer.spotify.com/web-api/get-several-artists/ - * - * @param array $artistIds IDs or Spotify URIs of the artists. - * - * @return array|object The requested artists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getArtists($artistIds) - { - $artistIds = $this->uriToId($artistIds, 'artist'); - $artistIds = implode(',', (array) $artistIds); - - $options = [ - 'ids' => $artistIds, - ]; - - $headers = $this->authHeaders(); - - $uri = '/v1/artists/'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get an artist's related artists. - * https://developer.spotify.com/web-api/get-related-artists/ - * - * @param string $artistId ID or Spotify URI of the artist. - * - * @return array|object The artist's related artists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getArtistRelatedArtists($artistId) - { - $headers = $this->authHeaders(); - - $artistId = $this->uriToId($artistId, 'artist'); - $uri = '/v1/artists/' . $artistId . '/related-artists'; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get an artist's albums. - * https://developer.spotify.com/web-api/get-artists-albums/ - * - * @param string $artistId ID or Spotify URI of the artist. - * @param array|object $options Optional. Options for the albums. - * - string|array album_type Optional. Album type(s) to return. If omitted, all album types will be returned. - * - string market Optional. Limit the results to items that are playable in this market, for example SE. - * - int limit Optional. Limit the number of albums. - * - int offset Optional. Number of albums to skip. - * - * @return array|object The artist's albums. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getArtistAlbums($artistId, $options = []) - { - $options = (array) $options; - - if (isset($options['album_type'])) { - $options['album_type'] = implode(',', (array) $options['album_type']); - } - - $headers = $this->authHeaders(); - - $artistId = $this->uriToId($artistId, 'artist'); - $uri = '/v1/artists/' . $artistId . '/albums'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get an artist's top tracks in a country. - * https://developer.spotify.com/web-api/get-artists-top-tracks/ - * - * @param string $artistId ID or Spotify URI of the artist. - * @param array|object $options Options for the tracks. - * - string $country Required. An ISO 3166-1 alpha-2 country code specifying the country to get the top tracks for. - * - * @return array|object The artist's top tracks. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getArtistTopTracks($artistId, $options) - { - $headers = $this->authHeaders(); - - $artistId = $this->uriToId($artistId, 'artist'); - $uri = '/v1/artists/' . $artistId . '/top-tracks'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get track audio features. - * https://developer.spotify.com/web-api/get-several-audio-features/ - * - * @param array $trackIds IDs or Spotify URIs of the tracks. - * - * @return array|object The tracks' audio features. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getAudioFeatures($trackIds) - { - $trackIds = $this->uriToId($trackIds, 'track'); - $options = [ - 'ids' => implode(',', (array) $trackIds), - ]; - - $headers = $this->authHeaders(); - - $uri = '/v1/audio-features'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get audio analysis for track. - * https://developer.spotify.com/web-api/get-audio-analysis/ - * - * @param string $trackId ID or Spotify URI of the track. - * - * @return object The track's audio analysis. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getAudioAnalysis($trackId) - { - $headers = $this->authHeaders(); - - $trackId = $this->uriToId($trackId, 'track'); - $uri = '/v1/audio-analysis/' . $trackId; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a list of categories used to tag items in Spotify (on, for example, the Spotify player’s "Browse" tab). - * https://developer.spotify.com/web-api/get-list-categories/ - * - * @param array|object $options Optional. Options for the categories. - * - string locale Optional. Language to show categories in, for example sv_SE. - * - string country Optional. An ISO 3166-1 alpha-2 country code. Show categories from this country. - * - int limit Optional. Limit the number of categories. - * - int offset Optional. Number of categories to skip. - * - * @return array|object The list of categories. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getCategoriesList($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/browse/categories'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a single category used to tag items in Spotify (on, for example, the Spotify player’s "Browse" tab). - * https://developer.spotify.com/web-api/get-category/ - * - * @param string $categoryId The Spotify ID of the category. - * - * @param array|object $options Optional. Options for the category. - * - string locale Optional. Language to show category in, for example sv_SE. - * - string country Optional. An ISO 3166-1 alpha-2 country code. Show category from this country. - * - * @return array|object The category. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getCategory($categoryId, $options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/browse/categories/' . $categoryId; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a list of Spotify playlists tagged with a particular category. - * https://developer.spotify.com/web-api/get-categorys-playlists/ - * - * @param string $categoryId The Spotify ID of the category. - * - * @param array|object $options Optional. Options for the category's playlists. - * - string country Optional. An ISO 3166-1 alpha-2 country code. Show category playlists from this country. - * - int limit Optional. Limit the number of playlists. - * - int offset Optional. Number of playlists to skip. - * - * @return array|object The list of playlists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getCategoryPlaylists($categoryId, $options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/browse/categories/' . $categoryId . '/playlists'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get Spotify featured playlists. - * https://developer.spotify.com/web-api/get-list-featured-playlists/ - * - * @param array|object $options Optional. Options for the playlists. - * - string locale Optional. Language to show playlists in, for example sv_SE. - * - string country Optional. An ISO 3166-1 alpha-2 country code. Show playlists from this country. - * - string timestamp Optional. A ISO 8601 timestamp. Show playlists relevant to this date and time. - * - int limit Optional. Limit the number of playlists. - * - int offset Optional. Number of playlists to skip. - * - * @return array|object The featured playlists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getFeaturedPlaylists($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/browse/featured-playlists'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a list of possible seed genres. - * https://developer.spotify.com/web-api/get-recommendations/#available-genre-seeds - * - * @return array|object All possible seed genres. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getGenreSeeds() - { - $headers = $this->authHeaders(); - - $uri = '/v1/recommendations/available-genre-seeds'; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the latest full response from the Spotify API. - * - * @return array Response data. - * - array|object body The response body. Type is controlled by `SpotifyWebAPI::setReturnType()`. - * - array headers Response headers. - * - int status HTTP status code. - * - string url The requested URL. - */ - public function getLastResponse() - { - return $this->lastResponse; - } - - /** - * Get the current user’s currently playing track. - * https://developer.spotify.com/web-api/get-the-users-currently-playing-track/ - * - * @param array|object $options Optional. Options for the track. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The user's currently playing track. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyCurrentTrack($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/currently-playing'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user’s devices. - * https://developer.spotify.com/web-api/get-a-users-available-devices/ - * - * @return array|object The user's devices. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyDevices() - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/devices'; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user’s current playback information. - * https://developer.spotify.com/web-api/get-information-about-the-users-current-playback/ - * - * @param array|object $options Optional. Options for the info. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The user's playback information. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyCurrentPlaybackInfo($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - - /** - * Get the current user’s playlists. - * https://developer.spotify.com/web-api/get-a-list-of-current-users-playlists/ - * - * @param array|object $options Optional. Options for the playlists. - * - int limit Optional. Limit the number of playlists. - * - int offset Optional. Number of playlists to skip. - * - * @return array|object The user's playlists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyPlaylists($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/playlists'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user’s recently played tracks. - * https://developer.spotify.com/web-api/web-api-personalization-endpoints/get-recently-played/ - * - * @param array|object $options Optional. Options for the tracks. - * - int limit Optional. Number of tracks to return. - * - string after Optional. Unix timestamp in ms (13 digits). Returns all items after this position. - * - string before Optional. Unix timestamp in ms (13 digits). Returns all items before this position. - * - * @return array|object The most recently played tracks. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyRecentTracks($options = []) - { - $options = (array) $options; - - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/recently-played'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user’s saved albums. - * https://developer.spotify.com/web-api/get-users-saved-albums/ - * - * @param array|object $options Optional. Options for the albums. - * - int limit Optional. Number of albums to return. - * - int offset Optional. Number of albums to skip. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The user's saved albums. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMySavedAlbums($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/albums'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user’s saved tracks. - * https://developer.spotify.com/web-api/get-users-saved-tracks/ - * - * @param array|object $options Optional. Options for the tracks. - * - int limit Optional. Limit the number of tracks. - * - int offset Optional. Number of tracks to skip. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The user's saved tracks. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMySavedTracks($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/tracks'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the current user's top tracks or artists. - * https://developer.spotify.com/web-api/get-users-top-artists-and-tracks/ - * - * @param string $type The type of entity to fetch. - * @param array $options. Optional. Options for the results. - * - int limit Optional. Limit the number of tracks. - * - int offset Optional. Number of tracks to skip. - * - mixed time_range Optional. Over what time frame the data is calculated. See Spotify API docs for more info. - * - * @return array|object A list of the requested top entity. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getMyTop($type, $options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/top/' . $type; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get new releases. - * https://developer.spotify.com/web-api/get-list-new-releases/ - * - * @param array|object $options Optional. Options for the items. - * - string country Optional. An ISO 3166-1 alpha-2 country code. Show items relevant to this country. - * - int limit Optional. Limit the number of items. - * - int offset Optional. Number of items to skip. - * - * @return array|object The new releases. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getNewReleases($options = []) - { - $headers = $this->authHeaders(); - - $uri = '/v1/browse/new-releases'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get recommendations based on artists, tracks, or genres. - * https://developer.spotify.com/web-api/get-recommendations/ - * - * @param array|object $options Optional. Options for the recommendations. - * - int limit Optional. Limit the number of recommendations. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - mixed max_* Optional. Max value for one of the tunable track attributes. - * - mixed min_* Optional. Min value for one of the tunable track attributes. - * - array seed_artists Artist IDs to seed by. - * - array seed_genres Genres to seed by. Call SpotifyWebAPI::getGenreSeeds() for a complete list. - * - array seed_tracks Track IDs to seed by. - * - mixed target_* Optional. Target value for one of the tunable track attributes. - * - * @return array|object The requested recommendations. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getRecommendations($options = []) - { - $options = (array) $options; - - array_walk($options, function (&$value, $key) { - if (substr($key, 0, 5) == 'seed_') { - $value = implode(',', $value); - } - }); - - $headers = $this->authHeaders(); - - $uri = '/v1/recommendations'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a value indicating the response body type. - * - * @return string A value indicating if the response body is an object or associative array. - */ - public function getReturnType() - { - return $this->request->getReturnType(); - } - - /** - * Get the Request object in use. - * - * @return Request The Request object in use. - */ - public function getRequest() - { - return $this->request; - } - - /** - * Get a track. - * https://developer.spotify.com/web-api/get-track/ - * - * @param string $trackId ID or Spotify URI of the track. - * @param array|object $options Optional. Options for the track. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The requested track. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getTrack($trackId, $options = []) - { - $headers = $this->authHeaders(); - - $trackId = $this->uriToId($trackId, 'track'); - $uri = '/v1/tracks/' . $trackId; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get multiple tracks. - * https://developer.spotify.com/web-api/get-several-tracks/ - * - * @param array $trackIds IDs or Spotify URIs of the tracks. - * @param array|object $options Optional. Options for the albums. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The requested tracks. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getTracks($trackIds, $options = []) - { - $trackIds = $this->uriToId($trackIds, 'track'); - $options['ids'] = implode(',', (array) $trackIds); - - $headers = $this->authHeaders(); - - $uri = '/v1/tracks/'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a user. - * https://developer.spotify.com/web-api/get-users-profile/ - * - * @param string $userId ID or Spotify URI of the user. - * - * @return array|object The requested user. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getUser($userId) - { - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $uri = '/v1/users/' . $userId; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the artists followed by the current user. - * https://developer.spotify.com/web-api/get-followed-artists/ - * - * @param array|object $options Optional. Options for the artists. - * - int limit Optional. Limit the number of artists returned. - * - string after Optional. The last artist ID retrieved from the previous request. - * - * @return array|object A list of artists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getUserFollowedArtists($options = []) - { - $options = (array) $options; - - if (!isset($options['type'])) { - $options['type'] = 'artist'; // Undocumented until more values are supported. - } - - $headers = $this->authHeaders(); - - $uri = '/v1/me/following'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a user's specific playlist. - * https://developer.spotify.com/web-api/get-playlist/ - * - * @param string $userId ID or Spotify URI of the user. - * @param string $playlistId ID or Spotify URI of the playlist. - * @param array|object $options Optional. Options for the playlist. - * - string|array fields Optional. A list of fields to return. See Spotify docs for more info. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The user's playlist. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getUserPlaylist($userId, $playlistId, $options = []) - { - $options = (array) $options; - - if (isset($options['fields'])) { - $options['fields'] = implode(',', (array) $options['fields']); - } - - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get a user's playlists. - * https://developer.spotify.com/web-api/get-list-users-playlists/ - * - * @param string $userId ID or Spotify URI of the user. - * @param array|object $options Optional. Options for the tracks. - * - int limit Optional. Limit the number of tracks. - * - int offset Optional. Number of tracks to skip. - * - * @return array|object The user's playlists. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getUserPlaylists($userId, $options = []) - { - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $uri = '/v1/users/' . $userId . '/playlists'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the tracks in a user's playlist. - * https://developer.spotify.com/web-api/get-playlists-tracks/ - * - * @param string $userId ID or Spotify URI of the user. - * @param string $playlistId ID or Spotify URI of the playlist. - * @param array|object $options Optional. Options for the tracks. - * - string|array fields Optional. A list of fields to return. See Spotify docs for more info. - * - int limit Optional. Limit the number of tracks. - * - int offset Optional. Number of tracks to skip. - * - string market Optional. An ISO 3166-1 alpha-2 country code, provide this if you wish to apply Track Relinking. - * - * @return array|object The tracks in the playlist. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function getUserPlaylistTracks($userId, $playlistId, $options = []) - { - $options = (array) $options; - - if (isset($options['fields'])) { - $options['fields'] = implode(',', (array) $options['fields']); - } - - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/tracks'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Get the currently authenticated user. - * https://developer.spotify.com/web-api/get-current-users-profile/ - * - * @return array|object The currently authenticated user. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function me() - { - $headers = $this->authHeaders(); - - $uri = '/v1/me'; - - $this->lastResponse = $this->request->api('GET', $uri, [], $headers); - - return $this->lastResponse['body']; - } - - /** - * Check if albums are saved in the current user's Spotify library. - * https://developer.spotify.com/web-api/check-users-saved-albums/ - * - * @param string|array $albums ID(s) or Spotify URI(s) of the album(s) to check for. - * - * @return array Whether each album is saved. - */ - public function myAlbumsContains($albums) - { - $albums = $this->uriToId($albums, 'album'); - $albums = implode(',', (array) $albums); - - $options = [ - 'ids' => $albums, - ]; - - $headers = $this->authHeaders(); - - $uri = '/v1/me/albums/contains'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Check if tracks are saved in the current user's Spotify library. - * https://developer.spotify.com/web-api/check-users-saved-tracks/ - * - * @param string|array $tracks ID(s) or Spotify URI(s) of the track(s) to check for. - * - * @return array Whether each track is saved. - */ - public function myTracksContains($tracks) - { - $tracks = $this->uriToId($tracks, 'track'); - $tracks = implode(',', (array) $tracks); - - $options = [ - 'ids' => $tracks, - ]; - - $headers = $this->authHeaders(); - - $uri = '/v1/me/tracks/contains'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Play the next track in the current users's queue. - * https://developer.spotify.com/web-api/skip-users-playback-to-next-track/ - * - * @param string $deviceId Optional. ID of the device to target. - * - * @return bool Whether the track was successfully skipped. - */ - public function next($deviceId = '') - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/next'; - - // We need to manually append data to the URI since it's a POST request - if ($deviceId) { - $uri = $uri . '?device_id=' . $deviceId; - } - - $this->lastResponse = $this->request->api('POST', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Pause playback for the current user. - * https://developer.spotify.com/web-api/pause-a-users-playback/ - * - * @param string $deviceId Optional. ID of the device to pause on. - * - * @return bool Whether the playback was successfully paused. - */ - public function pause($deviceId = '') - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/pause'; - - // We need to manually append data to the URI since it's a PUT request - if ($deviceId) { - $uri = $uri . '?device_id=' . $deviceId; - } - - $this->lastResponse = $this->request->api('PUT', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Start playback for the current user. - * https://developer.spotify.com/web-api/start-a-users-playback/ - * - * @param string $deviceId Optional. ID of the device to play on. - * @param array|object $options Optional. Options for the playback. - * - string context_uri Optional. Spotify URI of the context to play, for example an album. - * - array uris Optional. Spotify track URIs to play. - * - object offset Optional. Indicates from where in the context playback should start. - * - * @return bool Whether the playback was successfully started. - */ - public function play($deviceId = '', $options = []) - { - $options = json_encode((object) $options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $uri = '/v1/me/player/play'; - - // We need to manually append data to the URI since it's a PUT request - if ($deviceId) { - $uri = $uri . '?device_id=' . $deviceId; - } - - $this->lastResponse = $this->request->api('PUT', $uri, $options, $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Play the previous track in the current users's queue. - * https://developer.spotify.com/web-api/skip-users-playback-to-previous-track/ - * - * @param string $deviceId Optional. ID of the device to target. - * - * @return bool Whether the track was successfully skipped. - */ - public function previous($deviceId = '') - { - $headers = $this->authHeaders(); - - $uri = '/v1/me/player/previous'; - - // We need to manually append data to the URI since it's a POST request - if ($deviceId) { - $uri = $uri . '?device_id=' . $deviceId; - } - - $this->lastResponse = $this->request->api('POST', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Reorder the tracks in a user's playlist. - * https://developer.spotify.com/web-api/reorder-playlists-tracks/ - * - * @param string $userId ID or Spotify URI of the user. - * @param string $playlistId ID or Spotify URI of the playlist. - * @param array|object $options Options for the new tracks. - * - int range_start Required. Position of the first track to be reordered. - * - int range_length Optional. The amount of tracks to be reordered. - * - int insert_before Required. Position where the tracks should be inserted. - * - string snapshot_id Optional. The playlist's snapshot ID. - * - * @return string|bool A new snapshot ID or false if the tracks weren't successfully reordered. - */ - public function reorderUserPlaylistTracks($userId, $playlistId, $options) - { - $options = json_encode($options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/tracks'; - - $this->lastResponse = $this->request->api('PUT', $uri, $options, $headers); - $body = $this->lastResponse['body']; - - if (isset($body->snapshot_id)) { - return $body->snapshot_id; - } - - return false; - } - - /** - * Set repeat mode for the current user’s playback. - * https://developer.spotify.com/web-api/set-repeat-mode-on-users-playback/ - * - * @param array|object $options Optional. Options for the playback repeat mode. - * - string state Required. The repeat mode. See Spotify docs for possible values. - * - string device_id Optional. ID of the device to target. - * - * @return bool Whether the playback repeat mode was successfully changed. - */ - public function repeat($options) - { - $options = http_build_query($options); - - $headers = $this->authHeaders(); - - // We need to manually append data to the URI since it's a PUT request - $uri = '/v1/me/player/repeat?' . $options; - - $this->lastResponse = $this->request->api('PUT', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Replace all tracks in a user's playlist with new ones. - * https://developer.spotify.com/web-api/replace-playlists-tracks/ - * - * @param string $userId ID or Spotify URI of the user. - * @param string $playlistId ID or Spotify URI of the playlist. - * @param string|array $tracks ID(s) or Spotify URI(s) of the track(s) to add. - * - * @return bool Whether the tracks was successfully replaced. - */ - public function replaceUserPlaylistTracks($userId, $playlistId, $tracks) - { - $tracks = $this->idToUri($tracks, 'track'); - $tracks = json_encode([ - 'uris' => (array) $tracks, - ]); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/tracks'; - - $this->lastResponse = $this->request->api('PUT', $uri, $tracks, $headers); - - return $this->lastResponse['status'] == 201; - } - - /** - * Search for an item. - * https://developer.spotify.com/web-api/search-item/ - * - * @param string $query The term to search for. - * @param string|array $type The type of item to search for. - * @param array|object $options Optional. Options for the search. - * - string market Optional. Limit the results to items that are playable in this market, for example SE. - * - int limit Optional. Limit the number of items. - * - int offset Optional. Number of items to skip. - * - * @return array|object The search results. Type is controlled by `SpotifyWebAPI::setReturnType()`. - */ - public function search($query, $type, $options = []) - { - $type = implode(',', (array) $type); - $options = array_merge((array) $options, [ - 'q' => $query, - 'type' => $type, - ]); - - $headers = $this->authHeaders(); - - $uri = '/v1/search'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } - - /** - * Change playback position for the current user. - * https://developer.spotify.com/web-api/seek-to-position-in-currently-playing-track/ - * - * @param array|object $options Optional. Options for the playback seeking. - * - string position_ms Required. The position in milliseconds to seek to. - * - string device_id Optional. ID of the device to target. - * - * @return bool Whether the playback position was successfully changed. - */ - public function seek($options) - { - $options = http_build_query($options); - - $headers = $this->authHeaders(); - - // We need to manually append data to the URI since it's a PUT request - $uri = '/v1/me/player/seek?' . $options; - - $this->lastResponse = $this->request->api('PUT', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Set the access token to use. - * - * @param string $accessToken The access token. - * - * @return void - */ - public function setAccessToken($accessToken) - { - $this->accessToken = $accessToken; - } - - /** - * Set the return type for the response body. - * - * @param string $returnType One of the `SpotifyWebAPI::RETURN_*` constants. - * - * @return void - */ - public function setReturnType($returnType) - { - $this->request->setReturnType($returnType); - } - - /** - * Set shuffle mode for the current user’s playback. - * https://developer.spotify.com/web-api/toggle-shuffle-for-users-playback/ - * - * @param array|object $options Optional. Options for the playback shuffle mode. - * - bool state Required. The shuffle mode. See Spotify docs for possible values. - * - string device_id Optional. ID of the device to target. - * - * @return bool Whether the playback shuffle mode was successfully changed. - */ - public function shuffle($options) - { - $options = (array) $options; - $options['state'] = $options['state'] ? 'true' : 'false'; - $options = http_build_query($options); - - $headers = $this->authHeaders(); - - // We need to manually append data to the URI since it's a PUT request - $uri = '/v1/me/player/shuffle?' . $options; - - $this->lastResponse = $this->request->api('PUT', $uri, [], $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Remove the current user as a follower of one or more artists or other Spotify users. - * https://developer.spotify.com/web-api/unfollow-artists-users/ - * - * @param string $type The type to check: either 'artist' or 'user'. - * @param string|array $ids ID(s) or Spotify URI(s) of the user(s) or artist(s) to unfollow. - * - * @return bool Whether the artist(s) or user(s) were successfully unfollowed. - */ - public function unfollowArtistsOrUsers($type, $ids) - { - $ids = $this->uriToId($ids, $type); - $ids = json_encode([ - 'ids' => (array) $ids, - ]); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - // We need to manually append data to the URI since it's a DELETE request - $uri = '/v1/me/following?type=' . $type; - - $this->lastResponse = $this->request->api('DELETE', $uri, $ids, $headers); - - return $this->lastResponse['status'] == 204; - } - - /** - * Remove the current user as a follower of a playlist. - * https://developer.spotify.com/web-api/unfollow-playlist/ - * - * @param string $userId ID or Spotify URI of the user who owns the playlist. - * @param string $playlistId ID or Spotify URI of the playlist to unfollow - * - * @return bool Whether the playlist was successfully unfollowed. - */ - public function unfollowPlaylist($userId, $playlistId) - { - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/followers'; - - $this->lastResponse = $this->request->api('DELETE', $uri, [], $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Update the details of a user's playlist. - * https://developer.spotify.com/web-api/change-playlist-details/ - * - * @param string $userId ID or Spotify URI of the user who owns the playlist. - * @param string $playlistId ID or Spotify URI of the playlist to update. - * @param array|object $options Options for the playlist. - * - collaborative bool Optional. Whether the playlist should be collaborative or not. - * - description string Optional. Description of the playlist. - * - name string Optional. Name of the playlist. - * - public bool Optional. Whether the playlist should be public or not. - * - * @return bool Whether the playlist was successfully updated. - */ - public function updateUserPlaylist($userId, $playlistId, $options) - { - $options = json_encode($options); - - $headers = $this->authHeaders(); - $headers['Content-Type'] = 'application/json'; - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId; - - $this->lastResponse = $this->request->api('PUT', $uri, $options, $headers); - - return $this->lastResponse['status'] == 200; - } - - /** - * Update the image of a user's playlist. - * https://developer.spotify.com/web-api/upload-a-custom-playlist-cover-image/ - * - * @param string $userId ID or Spotify URI of the user who owns the playlist. - * @param string $playlistId ID or Spotify URI of the playlist to update. - * @param string $imageData. Base64 encoded JPEG image data, maximum 256 KB in size. - * - * @return bool Whether the playlist was successfully updated. - */ - public function updateUserPlaylistImage($userId, $playlistId, $imageData) - { - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/images'; - - $this->lastResponse = $this->request->api('PUT', $uri, $imageData, $headers); - - return $this->lastResponse['status'] == 202; - } - - /** - * Check if a user is following a playlist. - * https://developer.spotify.com/web-api/check-user-following-playlist/ - * - * @param string $userId User ID or Spotify URI of the playlist owner. - * @param string $playlistId ID or Spotify URI of the playlist. - * @param array|object $options Options for the check. - * - ids string|array Required. ID(s) or Spotify URI(s) of the user(s) to check for. - * - * @return array Whether each user is following the playlist. - */ - public function userFollowsPlaylist($userId, $playlistId, $options) - { - $options = (array) $options; - - if (isset($options['ids'])) { - $options['ids'] = $this->uriToId($options['ids'], 'user'); - $options['ids'] = implode(',', (array) $options['ids']); - } - - $headers = $this->authHeaders(); - - $userId = $this->uriToId($userId, 'user'); - $playlistId = $this->uriToId($playlistId, 'playlist'); - - $uri = '/v1/users/' . $userId . '/playlists/' . $playlistId . '/followers/contains'; - - $this->lastResponse = $this->request->api('GET', $uri, $options, $headers); - - return $this->lastResponse['body']; - } -} diff --git a/3rdparty/spotify/SpotifyWebAPIAuthException.php b/3rdparty/spotify/SpotifyWebAPIAuthException.php deleted file mode 100644 index 305c4fd..0000000 --- a/3rdparty/spotify/SpotifyWebAPIAuthException.php +++ /dev/null @@ -1,8 +0,0 @@ -Login to Spotify" - htmlLoginButton = auth_url - retData = htmlLoginButton - #print (retData) - #basicWebServer() - - print (retData) - - -class SpotifyHTTPServer(http.server.SimpleHTTPRequestHandler): - - def do_GET(self): - fullURL = self.path - getSpotifyToken(responseuri=fullURL) - self.send_response(200, 'OK') - self.send_header('Content-type', 'text/html') - self.end_headers() - self.wfile.write("