Skip to content

A library to receive information about Spotify songs.

License

Notifications You must be signed in to change notification settings

Luuk-Dev/Spotify-Info

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

84 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Spotify Info

A library to receive information about Spotify songs and playlists with and without using the API.

Table of contents:

Validate url's

To validate a Spotify url, you can use different functions, depending on the type of url you would like to validate. The available functions are:

  • validateSpotifyURL: Checks whether the url is Spotify URL or not
  • validateTrackURL: Checks whether the url is from a song on Spotify or not
  • validateArtistURL: Checks whether the url is from an artist on Spotify or not
  • validateAlbumURL: Checks whether the url is from an album on Spotify or not
  • validatePlaylistURL: Checks whether the url is from a playlist on Spotify or not

If the url is valid, the function will return true, if not, the function will return false.

const spotifyInfo = require('spotify-info');

console.log(spotifyInfo.validateSpotifyURL('https://open.spotify.com/playlist/5pI2mpzVD945Ni9aEB1veE')); // Returns true

console.log(spotifyInfo.validateTrackURL('https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT')) // Returns true

console.log(spotifyInfo.validateArtistURL('https://open.spotify.com/artist/0gxyHStUsqpMadRV0Di1Qt')) // Returns true

console.log(spotifyInfo.validateAlbumURL('https://open.spotify.com/album/5Z9iiGl2FcIfa3BMiv6OIw')) // Returns true

console.log(spotifyInfo.validatePlaylistURL('https://open.spotify.com/playlist/5pI2mpzVD945Ni9aEB1veE')) // Returns true

Get information with the Spotify API

The Spotify Info package allows you since the release of version 1.0.8 to use the Spotify API to receive information about songs, playlists, albums and artists. The Spotify API provides more information, is faster and has less risks of unable to functionate than the scrape functions. To make use of the you need a client id and client secret. These credentials can be received on the Spotify developer dashboard page by creating a new application and then by clicking the Settings button.

Using your credentials

The Spotify Info package needs the credentials of your application to be able to make requests to the Spotify API. These credentials can be set by using the setApiCredentials function. The first argument is the Client ID of your application and the second argument is the Client Secret of your application. The api credentials will be saved global so you don't have to define them in every file. The credentials can also be set by using the environmental variables SPOTIFY_CLIENT_ID and SPOTIFY_CLIENT_SECRET. These credentials must be set to be able to make use of the API functions. If you don't want to use credentials, you can make use of the scrape functions. This is an example of how to set your credentials:

const spotifyInfo = require('spotify-info');

spotifyInfo.setApiCredentials('my-client-id', 'my-client-secret');

Get song information

You can get information about a song by making use of the getTrack function. The function has two arguments. The first argument is the url or id of the song. The url may be an embed url, song url or an api url. The second argument is the options argument which is optional. The options in the options argument are:

  • market: The country code of the country where you want to get the available information about the track from. By default the one will be used which is linked to your account.
const spotifyInfo = require('spotify-info');

spotifyInfo.getTrack('https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT').then(res => console.log(res.name)).catch(console.log);

The getTrack function returns a Promise, once this is fullfilled, it will return the ApiTrack class. The ApiTrack class has the following properties:

Property Description
name The name of the song.
id The id of the song on Spotify.
uri The uri of the song on Spotify.
url The url of the song on Spotify.
discNumber The disc number of the song on Spotify (mostly 1).
trackNumber The track number of the song on Spotify.
embedUrl The embed url of the song on Spotify.
artists An array of the artists (base artist object).
album An object of the album the song is in (base album object).
explicit Whether the song is explicit or not.
popularity A number between 0-100 with 100 being the most popular (nullable).
duration The duration of the song in miliseconds.
previewUrl A url of a preview of the song (nullable).
locations An array of country codes of the countries where the song is available on Spotify.

Get playlist information

You can get information about a playlist by making use of the getPlaylist function. The function has two arguments. The first argument is the url or id of the playlist. The url may be an embed url, playlist url or an api url. The second argument is the options argument which is optional. The options in the options argument are:

  • market: The country code of the country where you want to get the available information about the playlist from. By default the one will be used which is linked to your account.
const spotifyInfo = require('spotify-info');

spotifyInfo.getPlaylist('https://open.spotify.com/playlist/5pI2mpzVD945Ni9aEB1veE').then(res => console.log(res.name)).catch(console.log);

The getPlaylist function returns a Promise, once this is fullfilled, it will return the ApiPlaylist class. The ApiPlaylist class has the following properties:

Property Description
name The name of the playlist.
id The id of the playlist on Spotify.
uri The uri of the playlist on Spotify.
url The url of the playlist on Spotify.
images An array of images of the cover of the playlist (base image object).
owner An object of the owner of the playlist (base image object).
embedUrl The embed url of the playlist on Spotify.
artists An array of the artists (base artist object).
collaborative Whether the owner of the playlist allows others to modify the playlist or not.
public Whether the playlist is public or not.
description The descripition of the playlist (null for non-modified and non-verified playlists).
followers The amount of followers of the playlist.
previewUrl A url of a preview of the song (nullable).
locations An array of country codes of the countries where the song is available on Spotify.
tracks An object with information about the tracks of the playlist (base tracks information).

Get album information

You can get information about an album by making use of the getAlbum function. The function has two arguments. The first argument is the url or id of the album. The url may be an embed url, album url or an api url. The second argument is the options argument which is optional. The options in the options argument are:

  • market: The country code of the country where you want to get the available information about the album from. By default the one will be used which is linked to your account.
const spotifyInfo = require('spotify-info');

spotifyInfo.getAlbum('https://open.spotify.com/album/5Z9iiGl2FcIfa3BMiv6OIw').then(res => console.log(res.name)).catch(console.log);

The getAlbum function returns a Promise, once this is fullfilled, it will return the ApiAlbum class. The ApiAlbum class has the following properties:

Property Description
name The name of the album.
id The id of the album on Spotify.
uri The uri of the album on Spotify.
url The url of the album on Spotify.
locations An array of country codes of the countries where the album is available on Spotify.
images An array of images of the cover of the album (base image object).
embedUrl The embed url of the album on Spotify.
artists An array of the artists who participated in the album (base artist object).
type The type of the album (album, single or compilation).
totalTracks The total amount of songs in the album.
release The date when the album got released.
copyrights An array of the copyrights that count for the album.
genres An array of genres the album belongs to.
label The label associated to the album (nullable).
tracks An array of the songs in the album (base track object).
popularity A number between 0-100 with 100 being the most popular (nullable).

Get artist information

You can get information about an artist by making use of the getArtist function. The function has one argument. The argument is the url or id of the artist. The url may be an embed url, artist url or an api url.

const spotifyInfo = require('spotify-info');

spotifyInfo.getArtist('https://open.spotify.com/artist/0gxyHStUsqpMadRV0Di1Qt').then(res => console.log(res.name)).catch(console.log);

The getArtist function returns a Promise, once this is fullfilled, it will return the ApiArtist class. The ApiArtist class has the following properties:

Property Description
name The name of the artist.
id The id of the artist on Spotify.
uri The uri of the artist on Spotify.
url The url of the artist on Spotify.
images An array of images of the cover of the album (base image object).
embedUrl The embed url of the artist on Spotify.
followers The amount of followers the artist has.
copyrights An array of the copyrights that count for the album.
genres An array of genres the album belongs to.
popularity A number between 0-100 with 100 being the most popular (nullable).

Get user information

You can get information about a user by making use of the getUser function. The function has one argument. The argument is the url or id of the user. The url may be a spotify user url or a user api url.

const spotifyInfo = require('spotify-info');

spotifyInfo.getArtist('https://open.spotify.com/user/spotify').then(res => console.log(res.name)).catch(console.log);

The getUser function returns a Promise, once this is fullfilled, it will return the ApiUser class. The ApiUser class has the following properties:

Property Description
username The username of the user.
id The id of the user on Spotify.
uri The uri of the artist on Spotify.
url The url of the user on Spotify.
images An array of images of the profile image of the user (base image object).
followers The amount of followers the user has.

Search

You can also search for songs, playlists, albums and artists by using the search function. The function has two arguments. The first argument is the query or api url where you want to search the song, playlist, album or artist with. The second argument is the options argument which is required in this case. The options in the options argument are:

  • type: An array of the type you're looking for (can be track, playlist, album or artist, by default all of them are enabled).
  • offset: The index of the first result to return.
  • limit: The maximum number of results to return in each item type (range 0-50).
  • market: The country code of the country where you want to get the available information about the type you're looking for from. By default the one will be used which is linked to your account.
const spotifyInfo = require('spotify-info');

spotifyInfo.search('Never Gonna Give You Up', {
    type: ['artist'],
    offset: 0,
    limit: 1,
    market: 'US'
}).then(res => console.log(res.name)).catch(console.log);

The search function returns a Promise, once this is fullfilled, it will return the SearchResult class. The SearchResult class has the following properties:

Property Description
tracks The tracks that have been found with the query. (base search result object).
playlists The playlists that have been found with the query. (base search result object).
albums The albums that have been found with the query. (base search result object).
artists The artists that have been found with the query. (base search result object).

Base artist object

The base artist object has the following properties:

Property Description
name The name of the artist.
id The id of the artist on Spotify.
uri The uri of the artist on Spotify.
url The url of the artist on Spotify.

Base owner object

The base owner object has the following properties:

Property Description
name The name of the owner.
id The id of the owner on Spotify.
uri The uri of the owner on Spotify.
url The url of the owner on Spotify.

Base album object

The base album object has the following properties:

Property Description
name The name of the album.
id The id of the album on Spotify.
uri The uri of the album on Spotify.
url The url of the album on Spotify.
artists An array of artists (base artist object) who participated in the album.
images An array of images of the cover (base image object) of the album.
locations An array of country codes of the countries where the album is available on Spotify.
totalTracks A number of the total amount of songs in the album.
type The type of album (album, single or compilation).
release The date when the album got released.

Base image object

The base image object has the following properties:

Property Description
height The height of the image (nullable).
width The width of the image (nullable).
url The url of the image.

Base tracks information

Property Description
tracks An array with the tracks of the playlist (base track object).
offset The offset used to find the tracks of the playlist.
limit The limit set to find the tracks of the playlist and the amount of tracks which have been returned.
total The total amount of tracks available for the playlist.
nextPage A function which returns a Promise and resolves a new ApiPlaylist class with a new page of tracks.
previousPage A function which returns a Promise and resolves a new ApiPlaylist class with the previous page of tracks (nullable).

Base track object

The base track object has the following properties:

Property Description
name The name of the song.
id The id of the song on Spotify.
uri The uri of the song on Spotify.
url The url of the song on Spotify.
embedUrl The url of the embed of the song.
artists An array of artists (base artist object) who participated in the song.
addedTimestamp A timestamp of the time when the song got added to the playlist. (Only for playlist)
locations An array of country codes of the countries where the song is available on Spotify.
previewUrl A url of a preview of the song (nullable).
explicit Whether the song is explicit or not.
duration The duration of the song in miliseconds.
discNumber The disc number of the song on Spotify (mostly 1).
trackNumber The track number of the song on Spotify.
album The album the song is in (base album object)

Base search result object

The base search result object has the following properties:

Property Description
limit The limit that has been set for the results.
width The offset that has been set for the results.
total The total amount of results.
previousPage A function which returns a Promise that shows the previous page of results (only available when results isn't the first page, nullable).
nextPage A function which returns a Promise that shows the next page of results (only available when results isn't the last page, nullable).
items An array with the results (result depends on the parent*)

* Based on the parent object name:

  • Result items of songs will be the ApiTrack class
  • Result items of playlists will be the SearchPlaylist class
  • Result items of albums will be the SearchAlbum class
  • Result items of artists will be the ApiArtist class

SearchPlaylist class

The SearchPlaylist class has the following properties:

Property Description
name The name of the playlist.
collaborative Whether the owner of the playlist allows others to modify the playlist or not.
url The url of the playlist on Spotify.
uri The uri of the playlist on Spotify.
embedUrl The embed url of the playlist on Spotify.
id The id of the playlist on Spotify.
images An array of images of the cover (base image object) of the playlist.
owner An object of the owner of the playlist (base image object).
public Whether the playlist is public or not.
description The descripition of the playlist (null for non-modified and non-verified playlists).
getTracks A function which returns a Promise which gives an array of the songs in the playlist (base track object).

SearchAlbum class

The SearchAlbum class has the following properties:

Property Description
name The name of the album.
id The id of the album on Spotify.
uri The uri of the album on Spotify.
url The url of the album on Spotify.
locations An array of country codes of the countries where the album is available on Spotify.
images An array of images of the cover of the album (base image object).
embedUrl The embed url of the album on Spotify.
artists An array of the artists who participated in the album (base artist object).
type The type of the album (album, single or compilation).
totalTracks The total amount of songs in the album.
release The date when the album got released.
copyrights An array of the copyrights that count for the album.
genres An array of genres the album belongs to.
label The label associated to the album (nullable).
getTracks A function which returns a Promise which gives an array of the songs in the album (base track object).

Get information without the Spotify API

The Spotify Info package allows you to get information about songs, playlists and albums without making use of the Spotify API. It is recommended though to make use of the API as when Spotify changes their pages, it is possible that the scrape functions might not work anymore. In addition, the scrape functions have to make requests to multiple pages to receive all the information, which makes the Spotify API faster than the scrape functions.

Get song information

To get a song it's information, you can scrape the Spotify page by using the scrapeTrack function. The function has one argument which is the url of the song.

const spotifyInfo = require('spotify-info');

spotifyInfo.scrapeTrack('https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT').then(song => console.log(song.name)).catch(console.log);

The scrapeTrack function returns a Promise, once this is fullfilled, it will return the ScrapedTrack class. The ScrapedTrack class has the following properties:

Property Description
name The name of the song.
id The id of the song on Spotify.
artist The artist of the song.
artistUrl The url of the artist of the song on Spotify.
artistId The id of the artist of the song on Spotify.
description The description of the song on Spotify.
publishDate The date when the song got published on Spotify.
locations An array of country codes of the countries where the song is available on Spotify.
url The url of the song on Spotify.
embedUrl The embed url of the song on Spotify.

Get playlist information

To get a playlist it's information, you can scrape the Spotify page by using the scrapePlaylist function. The function has one argument which is the url of the playlist.

const spotifyInfo = require('spotify-info');

spotifyInfo.scrapePlaylist('https://open.spotify.com/playlist/5pI2mpzVD945Ni9aEB1veE').then(song => console.log(song.name)).catch(console.log);

The scrapePlaylist function returns a Promise, once this is fullfilled, it will return the ScrapedPlaylist class. The ScrapedPlaylist class has the following properties:

Property Description
name The name of the playlist on Spotify.
id The id of the playlist on Spotify.
creator The username of the creator of the playlist on Spotify.
creatorId The id of the creator of the playlist on Spotify.
creatorUrl The url of the creator of the playlist on Spotify.
thumbnail The image which is used as the thumbnail for the playlist on Spotify.
locations An array of country codes of the countries where the playlist is available on Spotify.
description The description of the playlist on Spotify.
url The url of the playlist on Spotify.
embedUrl The embed url of the playlist on Spotify.
tracks An array of the tracks in the playlist, the tracks make use of the ScrapedPlaylistTrack class.

Get album information

To get an album it's information, you can scrape the Spotify page by using the scrapeAlbum function. The function has one argument which is the url of the album.

const spotifyInfo = require('spotify-info');

spotifyInfo.scrapeAlbum('https://open.spotify.com/album/5Z9iiGl2FcIfa3BMiv6OIw').then(song => console.log(song.name)).catch(console.log);

The scrapeAlbum function returns a Promise, once this is fullfilled, it will return the scrapeAlbum class. The scrapeAlbum class has the following properties:

Property Description
name The name of the album.
id The id of the album on Spotify.
url The url of the album on Spotify.
artist The username of the artist of the album on Spotify.
artistId The id of the artist of the album on Spotify.
artistUrl The url of the artist of the album on Spotify.
thumbnail The image which is used as the thumbnail for the album on Spotify.
locations An array of country codes of the countries where the album is available on Spotify.
description The description of the album on Spotify.
embedUrl The embed url of the album on Spotify.
tracks An array of the tracks in the album, the tracks make use of the ScrapedPlaylistTrack class.

The ScrapedPlaylistTrack class

The ScrapedPlaylistTrack class is used for tracks in the ScrapedPlaylist class and for tracks in the ScrapedAlbum class. The properties of the ScrapedPlaylistTrack class are:

Property Description
name The name of the song.
artist The name of the artist of the song on Spotify.
duration The duration of the song in miliseconds.
durationString The duration of the song as a string.