Amazing-Python-Scripts
Amazing-Python-Scripts copied to clipboard
Bump spotipy from 2.23.0 to 2.25.2 in /Spotify Playlist Automation
Bumps spotipy from 2.23.0 to 2.25.2.
Release notes
Sourced from spotipy's releases.
2.25.2: CVE-2025-66040
Security
- CVE-2025-66040 – HTML for OAuth flow now sanitized: prevents potential XSS attacks (by
@​yueyueL)- Upgrade if you run spotipy with the default OAuth flow (uses a local HTTP server as a callback method)
Added
- Adds
additional_typesparameter to retrieve currently playing episode- Add deprecation warnings to documentation
Fixed
- Fixed dead link in README.md
- Corrected Spotify/Spotipy typo in documentation
2.25.1: CVE-2025-27154
Security
- CVE-2025-27154 – Cache file permissions tightened: now
600(user read/write only) instead of644, preventing unauthorized local access to auth tokens (by@​alichtman)
- Upgrade if you run spotipy in a multi-user environment, manage multiple users' auth tokens, or need better protection against local unauthorized access; not required if you're the only user and your home directory is private.
Added
- Added examples for audiobooks, shows and episodes methods to examples directory
Fixed
- Fixed scripts in examples directory that didn't run correctly
- Updated documentation for
Client.current_user_top_artiststo indicate maximum number of artists limitChanged
- Updated get_cached_token and save_token_to_cache methods to utilize Python's Context Management Protocol
- Added except clause to get_cached_token method to handle json decode errors
- Added warnings and updated docs due to Spotify's deprecation of HTTP and "localhost" redirect URIs
- Use newer string formatters (https://pyformat.info)
- Marked
recommendation_genre_seedsas deprecated2.25: Deprecated methods & misc. updates
Added
- Added unit tests for queue functions
- Added detailed function docstrings to 'util.py', including descriptions and special sections that lists arguments, returns, and raises.
- Updated order of instructions for Python and pip package manager installation in TUTORIAL.md
- Updated TUTORIAL.md instructions to match current layout of Spotify Developer Dashboard
- Added test_artist_id, test_artist_url, and test_artists_mixed_ids to non_user_endpoints test.py
- Added rate/request limit to FAQ
- Added custom
urllib3.Retryclass for printing a warning when a rate/request limit is reached.- Added
personalized_playlist.py,track_recommendations.py, andaudio_features_analysis.pyto/examples.- Discord badge in README
... (truncated)
Changelog
Sourced from spotipy's changelog.
[2.25.2] - 2025-11-26
Added
- Adds
additional_typesparameter to retrieve currently playing episode- Add deprecation warnings to documentation
Fixed
- Fixed dead link in README.md
- Corrected Spotify/Spotipy typo in documentation
- Sanitize HTML error message output for OAuth flow: https://github.com/spotipy-dev/spotipy/security/advisories/GHSA-r77h-rpp9-w2xm
[2.25.1] - 2025-02-27
Added
- Added examples for audiobooks, shows and episodes methods to examples directory
Fixed
- Fixed scripts in examples directory that didn't run correctly
- Updated documentation for
Client.current_user_top_artiststo indicate maximum number of artists limit- Set auth cache file permissions to
600: https://github.com/spotipy-dev/spotipy/security/advisories/GHSA-pwhh-q4h6-w599- Fixed
__del__methods by preventing garbage collection forrequests.Session- Improved retry warning by using
loggerinstead ofloggingand making sure thatretry_headeris an intChanged
- Updated get_cached_token and save_token_to_cache methods to utilize Python's Context Management Protocol
- Added except clause to get_cached_token method to handle json decode errors
- Added warnings and updated docs due to Spotify's deprecation of HTTP and "localhost" redirect URIs
- Use newer string formatters (https://pyformat.info)
- Marked
recommendation_genre_seedsas deprecated[2.25.0] - 2025-03-01
Added
- Added unit tests for queue functions
- Added detailed function docstrings to 'util.py', including descriptions and special sections that lists arguments, returns, and raises.
- Updated order of instructions for Python and pip package manager installation in TUTORIAL.md
- Updated TUTORIAL.md instructions to match current layout of Spotify Developer Dashboard
- Added test_artist_id, test_artist_url, and test_artists_mixed_ids to non_user_endpoints test.py
- Added rate/request limit to FAQ
- Added custom
urllib3.Retryclass for printing a warning when a rate/request limit is reached.- Added
personalized_playlist.py,track_recommendations.py, andaudio_features_analysis.pyto/examples.- Discord badge in README
- Added
SpotifyBaseExceptionand moved all exceptions toexceptions.py- Marked the following methods as deprecated:
... (truncated)
Commits
b5be7fbadd advisory link48dab6ebump version to 2.25.2880b92dMerge commit from forka91d9feCorrect Spotify/Spotipy typo (#1209)5a8b55fDeprecations in doc (#1202)9dfb717Revert "Run integration tests from fork" (#1201)6bc91ecFix README "examples" link. (#1195) (#1196)1a8d9daadd additional_types to current_user_playing_track() (#1193)5b018cfFix main branch name7430599Pin gha workflows to ubuntu-22.04- Additional commits viewable in compare view
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
@dependabot rebasewill rebase this PR@dependabot recreatewill recreate this PR, overwriting any edits that have been made to it@dependabot mergewill merge this PR after your CI passes on it@dependabot squash and mergewill squash and merge this PR after your CI passes on it@dependabot cancel mergewill cancel a previously requested merge and block automerging@dependabot reopenwill reopen this PR if it is closed@dependabot closewill close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually@dependabot show <dependency name> ignore conditionswill show all of the ignore conditions of the specified dependency@dependabot ignore this major versionwill close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this minor versionwill close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this dependencywill close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) You can disable automated security fix PRs for this repo from the Security Alerts page.