SeekTune is an implementation of Shazam's song recognition algorithm based on insights from these resources. It integrates Spotify and YouTube APIs to find and download songs.
- Golang: Install Golang
- FFmpeg: Install FFmpeg
- NPM: To run the client (frontend).
📦 Clone the repository:
git clone https://github.com/cgzirim/seek-tune.git
cd seek-tune
Prerequisites: Docker and Docker Compose
- Build and run the application:
Visit the app at http://localhost:8080
docker-compose up --build
- To stop the application:
docker-compose down
To access Spotify metadata, the project now uses the official Spotify Web API. This requires creating a developer application and retrieving a client ID and client secret.
Follow the official getting started guide to:
- Create a Spotify developer app.
- Copy your Client ID and Client Secret.
Instead of using a credentials.json file, the application now reads these values from environment variables.
Create a .env file in the server directory with the following content:
SPOTIFY_CLIENT_ID=your-client-id
SPOTIFY_CLIENT_SECRET=your-client-secret
Make sure this .env file is loaded into your environment before running the server. The application will automatically read this file to fetch and cache access tokens. If the token is expired or missing, a new one will be requested.
Install dependencies for the backend
cd server
go get ./...
Install dependencies for the client
cd client
npm install
# Assuming you're in the client directory:
npm start
In a separate terminal window:
cd server
go run *.go serve [-proto <http|https> (default: http)] [-port <port number> (default: 5000)]
Note: A link from Spotify's mobile app won't work. You can copy the link from either the desktop or web app.
go run *.go download <https://open.spotify.com/.../...>
go run *.go save [-f|--force] <path_to_song_file_or_dir_of_songs>
The -f
or --force
flag allows saving the song even if a YouTube ID is not found. Note that the frontend will not display matches without a YouTube ID.
Note: if *.go
does not work try to use ./...
instead.
go run *.go find <path-to-wav-file>
go run *.go erase
Download a song
$ go run *.go download https://open.spotify.com/track/4pqwGuGu34g8KtfN8LDGZm?si=b3180b3d61084018
Getting track info...
Now, downloading track...
Fingerprints saved in MongoDB successfully
'Voilà' by 'André Rieu' was downloaded
Total tracks downloaded: 1
Find matches of a song
$ go run *.go find songs/Voilà\ -\ André\ Rieu.wav
Top 20 matches:
- Voilà by André Rieu, score: 5390686.00
- I Am a Child of God by One Voice Children's Choir, score: 2539.00
- I Have A Dream by ABBA, score: 2428.00
- SOS by ABBA, score: 2327.00
- Sweet Dreams (Are Made of This) - Remastered by Eurythmics, score: 2213.00
- The Winner Takes It All by ABBA, score: 2094.00
- Sleigh Ride by One Voice Children's Choir, score: 2091.00
- Believe by Cher, score: 2089.00
- Knowing Me, Knowing You by ABBA, score: 1958.00
- Gimme! Gimme! Gimme! (A Man After Midnight) by ABBA, score: 1941.00
- Take A Chance On Me by ABBA, score: 1932.00
- Don't Stop Me Now - Remastered 2011 by Queen, score: 1892.00
- I Do, I Do, I Do, I Do, I Do by ABBA, score: 1853.00
- Everywhere - 2017 Remaster by Fleetwood Mac, score: 1779.00
- You Will Be Found by One Voice Children's Choir, score: 1664.00
- J'Imagine by One Voice Children's Choir, score: 1658.00
- When You Believe by One Voice Children's Choir, score: 1629.00
- When Love Was Born by One Voice Children's Choir, score: 1484.00
- Don't Stop Believin' (2022 Remaster) by Journey, score: 1465.00
- Lay All Your Love On Me by ABBA, score: 1436.00
Search took: 856.386557ms
Final prediction: Voilà by André Rieu , score: 5390686.00
This application uses SQLite as the default database, but you can switch to MongoDB if preferred.
-
Configure MongoDB Connection:
To connect to your MongoDB instance, set the following environment variables:DB_TYPE
: Set this to "mongo" to indicate using MongoDB.DB_USER
: The username for your MongoDB database.DB_PASS
: The password for your MongoDB database.DB_NAME
: The name of the MongoDB database you want to use.DB_HOST
: The hostname or IP address of your MongoDB server.DB_PORT
: The port number on which your MongoDB server is listening.
Note: The database connection URI is constructed using the environment variables.
If theDB_USER
orDB_PASS
environment variables are not set, it defaults to connecting tomongodb://localhost:27017
.
- How does Shazam work - Coding Geek (main resource)
- Song recognition using audio fingerprinting
- How does Shazam work - Toptal
- Creating Shazam in Java
- Chigozirim Igweamaka
This project is licensed under the MIT License - see the LICENSE file for details.