Search on instagram directly in the application is terrible.
I couldn't find the song I had sent a friend so I built this.
Note
Documentation auto-generated by ai-docs.
The provided code repository is a Python project that extracts Spotify links shared in an Instagram direct message thread and creates a Spotify playlist from those links. The project aims to automate the process of creating a shared playlist with a friend based on the music tracks shared in an Instagram conversation.
The codebase consists of three main Python files:
instagram.py
: Handles the extraction of Spotify links from an Instagram direct message thread.spotify.py
: Handles the creation of a Spotify playlist using the extracted Spotify links.run.py
: Serves as the main entry point of the application, orchestrating the execution of the Instagram and Spotify modules.
The project follows a modular architecture, separating the concerns of Instagram interaction and Spotify playlist creation into separate files. The run.py
file acts as the coordinator, calling the necessary functions from the other modules.
To set up the development environment for this project, follow these steps:
- Ensure you have Python 3.9 or higher installed on your system.
- Clone the project repository to your local machine.
- Open a terminal and navigate to the project directory.
- Install Poetry, the dependency management tool used in this project, by following the official installation guide: https://python-poetry.org/docs/#installation
- Run
poetry install
to install the project dependencies specified in thepyproject.toml
file. - Set up a
.env
file in the project root directory with the following Spotify API credentials:ReplaceSPOTIPY_CLIENT_ID=your_client_id SPOTIPY_CLIENT_SECRET=your_client_secret SPOTIPY_REDIRECT_URI=your_redirect_uri
your_client_id
,your_client_secret
, andyour_redirect_uri
with your actual Spotify API credentials. - You're now ready to run the project!
The code repository has the following structure:
auto-friend-playlist/
├── auto-friend-playlist/
│ ├── instagram.py
│ ├── spotify.py
│ └── run.py
├── pyproject.toml
└── README.md
auto-friend-playlist/
: The main package directory containing the Python source files.instagram.py
: Module responsible for extracting Spotify links from an Instagram direct message thread.spotify.py
: Module responsible for creating a Spotify playlist using the extracted Spotify links.run.py
: The main entry point of the application, coordinating the execution of the Instagram and Spotify modules.
pyproject.toml
: The Poetry configuration file specifying project dependencies and metadata.README.md
: The project's README file.
-
Instagram API Interaction:
- The
instagram.py
module uses theinstagrapi
library to interact with the Instagram API. - It handles logging in to Instagram, searching for a specific direct message thread, and extracting Spotify links from the messages.
- The module deals with pagination and rate limiting when fetching messages from the thread.
- Error handling is implemented to handle session expiration and other potential issues.
- The
-
Spotify API Integration:
- The
spotify.py
module uses thespotipy
library to interact with the Spotify API. - It handles authentication using the Spotify OAuth flow and retrieves the necessary access token.
- The module creates a new playlist on the user's Spotify account and adds the extracted tracks to the playlist.
- It handles extracting track IDs from the Spotify URLs and constructs the appropriate track URIs for playlist addition.
- The
-
Modular Architecture:
- The project follows a modular architecture, separating the concerns of Instagram interaction and Spotify playlist creation into separate files.
- The
run.py
file acts as the coordinator, orchestrating the execution of the Instagram and Spotify modules. - This modular design allows for better code organization, reusability, and maintainability.
To install and set up the project, follow these steps:
- Ensure you have Python 3.9 or higher installed on your system.
- Clone the project repository to your local machine.
- Open a terminal and navigate to the project directory.
- Install Poetry by running the following command:
curl -sSL https://raw.githubusercontent.com/python-poetry/poetry/master/get-poetry.py | python
- Run
poetry install
to install the project dependencies. - Set up a
.env
file in the project root directory with your Spotify API credentials (as mentioned in the Development Environment Setup section).
To start using the Instagram Spotify Playlist Creator, follow these steps:
- Open a terminal and navigate to the project directory.
- Run the following command to start the application:
poetry run python auto-friend-playlist/run.py
- Follow the prompts to enter your Instagram username, password, and your friend's Instagram username.
- The application will extract the Spotify links from the Instagram direct message thread and save them to a JSON file.
- Next, you will be prompted to enter a name for the Spotify playlist (or press Enter for the default name).
- The application will create a new playlist on your Spotify account and add the extracted tracks to it.
- Upon successful completion, the playlist URL will be displayed in the console.
That's it! You now have a Spotify playlist created from the music tracks shared in your Instagram conversation with your friend.
Feel free to explore the code and modify it to suit your specific needs. If you encounter any issues or have any questions, please refer to the project's README file or reach out to the project maintainers.
Happy playlist creation!