This bundle provides a simple integration of jwilsson/spotify-web-api-php into Symfony 5.
Make sure Composer is installed globally, as explained in the installation chapter of the Composer documentation.
Open a command console, enter your project directory and execute:
$ composer require calliostro/spotify-web-api-bundle
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
$ composer require calliostro/spotify-web-api-bundle
Then, enable the bundle by adding it to the list of registered bundles
in the config/bundles.php
file of your project:
// config/bundles.php
return [
// ...
Calliostro\SpotifyWebApiBundle\CalliostroSpotifyWebApiBundle::class => ['all' => true],
];
First, you must register your application at https://developer.spotify.com/dashboard/applications to obtain the
client_id
and client_secret
.
If you want to access user-related endpoints, the user must grant access to your application. Spotify provides OAuth 2.0
for this purpose. You need to register the redirect_uri
in the Spotify dashboard. For the following example, you would
add https://127.0.0.1:8000/callback/
to the whitelist addresses.
For configuration, create a new config/packages/calliostro_spotify_web_api.yaml
file. Here is an example:
# config/packages/calliostro_spotify_web_api.yaml
calliostro_spotify_web_api:
# Your Client ID
client_id: '' # Required
# Your Client Secret
client_secret: '' # Required
# Options for SpotifyWebAPI client
# https://github.com/jwilsson/spotify-web-api-php/blob/main/docs/examples/setting-options.md
options:
auto_refresh: false
auto_retry: false
return_assoc: false
# Address to redirect to after authentication success OR failure
redirect_uri: '' # Example: 'https://127.0.0.1:8000/callback/'
# Service ID of the token provider that provides the user's access token
token_provider: calliostro_spotify_web_api.token_provider
This bundle provides a single service for communication with Spotify Web API, which you can autowire by using the
SpotifyWebAPI
and Session
type-hint:
This is the simpler option if no user-related endpoints are required.
// src/Controller/SomeController.php
use SpotifyWebAPI\SpotifyWebAPI;
// ...
class SomeController
{
public function index(SpotifyWebAPI $api)
{
$search = $api->search('Thriller', 'album');
var_dump($search);
// ...
}
}
If you want to access a Spotify user's profile or data, you must first redirect the user to Spotify's approval page. Then you can start the session.
// src/Controller/SomeController.php
namespace App\Controller;
use SpotifyWebAPI\Session;
use SpotifyWebAPI\SpotifyWebAPI;
use SpotifyWebAPI\SpotifyWebAPIAuthException;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
class SomeController extends AbstractController
{
private $api;
private $session;
public function __construct(SpotifyWebAPI $api, Session $session)
{
$this->api = $api;
$this->session = $session;
}
/**
* @Route("/callback")
*/
public function callbackFromSpotify(Request $request): Response
{
try {
$this->session->requestAccessToken($request->query->get('code'));
} catch (SpotifyWebAPIAuthException $e) {
return $this->redirectToRoute('some_redirect');
}
$this->api->setAccessToken($this->session->getAccessToken());
$me = $this->api->me();
return new Response(var_export($me, false), 200, ['Content-Type' => 'text/plain']);
}
/**
* @Route("/redirect", name="some_redirect")
*/
public function redirectToSpotify(): Response
{
$options = [
'scope' => [
'user-read-email',
],
];
return $this->redirect($this->session->getAuthorizeUrl($options));
}
}
Don't forget to set redirect_uri
in the configuration file and whitelist it on Spotify.
See jwilsson/spotify-web-api-php for documentation of the SpotifyWebAPI service.
See Spotify's Web API full API documentation.
Implemented a missing feature? You can request it. And creating a pull request is an even better way to get things done.