Welcome to SoundChat! Transform your emotions into music with this AI-based intelligent playlist generator. Whether you're feeling joyful, melancholic, or in need of motivation, SoundChat creates personalized playlists that match your mood. Let's dive into the world of music and emotions!
A deployed version of SoundChat is available at bit.ly/soundchatai. To use this application, you'll need to be added as a user on the Spotify Developer Dashboard. This is because I am currently using Spotify's development API, which has usage limits.
- Emotion-Based Playlists: Generate playlists based on your current mood.
- Support for Multiple Moods: From dancing vibes to workout tunes, find the perfect playlist for every occasion.
- AI-Powered Recommendations: Leverage OpenAI's GPT-4o to generate personalized playlist names.
- Spotify Integration: Connect your Spotify account and enjoy your custom playlists directly.
- User-Friendly Interface: Simple and intuitive design for a seamless experience.
Follow these steps to get SoundChat up and running on your local machine:
-
Clone the repository:
git clone https://github.com/hrialan/soundchat.git cd soundchat
-
Set up the virtual environment:
python3 -m venv venv source venv/bin/activate
-
Install dependencies:
pip install -r requirements.txt
-
Configure environment variables: Create a
.env
file in the root directory and add the following:FLASK_SESSION_DIR='./.flask_session/' SPOTIPY_CLIENT_ID="your_spotify_client_id" SPOTIPY_CLIENT_SECRET="your_spotify_client_secret" SPOTIPY_REDIRECT_URI='http://127.0.0.1:8080' OPENAI_API_KEY="your_openai_api_key" GOOGLE_CLOUD_PROJECT="your_google_cloud_project" FIRESTORE_DATABASE="your_firestore_database" ENCRYPTION_KEY="Fernet key used for encryption of sensitive data in Firestore"
-
Run the application:
python run.py
- Visit the homepage: Open your browser and go to
http://127.0.0.1:8080
. - Connect to Spotify: Click on the "Connect to Spotify" button to authorize SoundChat.
- Generate a Playlist: Enter your mood or activity in the textbox and click "Generate Playlist".
- Enjoy your music: Your personalized playlist will be created on your Spotify account.
- Spotify Client ID and Secret: Obtain these from the Spotify Developer Dashboard.
- OpenAI API Key: Get your API key from OpenAI.
- Google Cloud Project: Set up a project on Google Cloud.
-
Pre-commit Hooks: Ensure code quality by setting up pre-commit hooks:
pre-commit install
-
Run Tests: Execute tests to verify your changes:
pytest
-
Linting: Use
flake8
andblack
for linting and formatting:flake8 . black .
In the folder iac
you can find the Terraform scripts to deploy the application on Google Cloud Platform. The scripts create a Cloud Run service and a Firestore database.
Interested in contributing to SoundChat? Here's how you can help improve the project:
- Fork the repository.
- Create a new branch:
git checkout -b feature/your-feature-name
- Make your changes.
- Commit your changes:
git commit -m "Add your message"
- Push to the branch:
git push origin feature/your-feature-name
- Create a Pull Request.
This project is licensed under the MIT License. See the LICENSE file for details.
Thank you for checking out SoundChat! Enjoy creating and listening to your personalized playlists. If you have any questions or feedback, feel free to reach out. Happy listening! 🎧