This library is a wrapper for the Spotify Web API and is designed to work with the ESP32 microcontroller.
- Create a new application on the Spotify Developer Dashboard and copy the Client ID and Client Secret into your code. Leave the developer dashboard open as you will need to set the callback url later.
- Now you will have to use the login without a refresh token which can be implemented the following way:
#include <Arduino.h>
#include <WiFi.h>
#include "SpotifyEsp32.h"
const char* SSID = "your_ssid";
const char* PASSWORD = "your_password";
const char* CLIENT_ID = "your_client_id";
const char* CLIENT_SECRET = "your_client_secret";
//Create an instance of the Spotify class Optional: you can set the Port for the webserver the debug mode(This prints out data to the serial monitor) and number of retries
Spotify sp(CLIENT_ID, CLIENT_SECRET);
void setup() {
Serial.begin(115200);
connect_to_wifi();//Connect to your wifi
sp.begin();//Start the webserver
while(!sp.is_auth()){//Wait for the user to authenticate
sp.handle_client();//Handle the client, this is necessary otherwise the webserver won't work
}
Serial.println("Authenticated");
}
void loop() {
//Add your code here
}
void connect_to_wifi(){
WiFi.begin(SSID, PASSWORD);
Serial.print("Connecting to WiFi...");
while (WiFi.status() != WL_CONNECTED) {
delay(1000);
Serial.print(".");
}
Serial.printf("\nConnected to WiFi\n");
}
-
Now you will have to set the callback url in the Spotify Developer Dashboard before you can log in the callback url is the url printed to the serial plus callback so e.g. if your url printed to the serial is:
https://192.1.1.128/
then the callback url will behttps://192.1.1.128/callback
-
If you want to set your tokens during runtime you can use the same code pass an empty char array to the constructor and set the tokens later in the webserver. By calling the "get_tokens" function you could then save these tokens with SPIFFS. And during next runtime pass them from the memory.
-
Now you can use the library.
- The normal functions return an response object. You can get the http code of type int with
response_obj.status_code
and the response message of type String withresponse_obj.reply
.
To print the response you can use theprint_response(response_obj)
function. - To search for methods you can use the Spotify Web API Reference, all of the methods shown there are implemented
- There are also some helper and some simplified functions.
// Get the current track name and return it as String
String current_track_name();
// Get the current track id and return it as String
String current_track_id();
// Get the current device id and return it as String
String current_device_id();
// Get the current artist names and return it as String
String current_artist_names();
// Get the current device id and return a pointer to the char, can be used as parameter for other functions
char* current_device_id(char* device_id);
// Get the current track id and return a pointer to the char, can be used as parameter for other functions
char* current_track_id(char* track_id);
// Get the current track name and return a pointer to the char, can be used as parameter for other functions
char* current_track_name(char* track_name);
// Get the current artist names and return a pointer to the char, can be used as parameter for other functions
char* current_artist_names(char* artist_names);
//Check if the device is playing and return true or false
bool is_playing();
//Check if volume of the current device is modifyable and return true or false
bool volume_modifyable();
//Convert a context id to a uri and return it as a char
char convert_id_to_uri(char* id, char* type);
//Convert a context id to a uri and return it as a pointer to the char
char* convert_id_to_uri(char* id, char* type, char* uri);
- You can also include the namespace:
using namespace Spotify_types;
. These are some types used in the library eg. TYPES, SIZES of uris/ids
If you want to get the tokens which you set during runtime to save them and reuse them you can call the get_user_tokens()
function, this function returns a user_tokens
object which contains: client_id
,client_secret
and the refresh_token
.
Due to the Wifi and HTTPS this library is quite big, so i recommend setting the partitions table of your esp to use more than the default 1.2MB of flash as most esp32's have 4MB of which the biggest part is set for SPIFFS which in most cases isn't used. Here are some tutorials about setting the partitions table of your esp:
- If you have any problems with the library you can use the debug mode to print out the data to the serial monitor. I recommend not setting the baud rate lower than 115200 as the data printed can be quite large which can lead to crash if the Serial communication is too slow.
- If you have any problems with the library you can also use the Spotify Web API Console to test the endpoints.
- If there are still issues you can open an issue on this repository.
- ESP32 WROOM
- Should also work on ESP2866 and other ESP32 models(Untested).