Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use Oauth2 login with spotify #731

Merged
merged 35 commits into from
Nov 19, 2024
Merged
Changes from 1 commit
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
d64659f
s/Requestiong/Requesting/
nmschulte Jul 7, 2023
191c54e
fix: playlists not loading
QPixel Jan 4, 2024
0c1b928
Added translator
walthersmith Oct 19, 2023
24dd00a
Fix debug typo
Diegovsky Jan 17, 2024
2ca5d9c
Update README.md to include repology status
Diegovsky Nov 2, 2023
54c1186
Improve cover button display in library
panurg Aug 24, 2023
c6530a1
Bump version
Diegovsky Feb 1, 2024
d3049fb
fix: appstream-missing-developer-name lint error
Diegovsky Feb 1, 2024
017ae6c
Add new release, fix flatpak linter errors
Diegovsky Mar 11, 2024
f71cdf3
Update appstream to be compliant
Diegovsky Apr 9, 2024
6497e48
Made a start on OAuth
stevenleadbeater Oct 27, 2024
2422253
set `SpotifyItemType` on the `SpotifyId` used to play tracks as `Spot…
stevenleadbeater Oct 27, 2024
919ddfd
Lift and shift OAuth2 flow from librespot so we can open the authoris…
stevenleadbeater Oct 27, 2024
ccbac9b
format and bump version inline with librespot
stevenleadbeater Oct 27, 2024
f68b919
format and bump version inline with librespot
stevenleadbeater Oct 27, 2024
ef33ec9
fix flatpak
stevenleadbeater Oct 27, 2024
b2d77f6
fix clippy warnings
stevenleadbeater Oct 28, 2024
b2291e0
fix fmt warnings
stevenleadbeater Oct 28, 2024
96b06d0
remove password login method (more cleanup possible), add login html …
xou816 Nov 15, 2024
f1e83c0
Made a start on OAuth
stevenleadbeater Oct 27, 2024
7f9ee05
set `SpotifyItemType` on the `SpotifyId` used to play tracks as `Spot…
stevenleadbeater Oct 27, 2024
c963807
rebase
stevenleadbeater Nov 16, 2024
373fef2
Lift and shift OAuth2 flow from librespot so we can open the authoris…
stevenleadbeater Oct 27, 2024
a57d353
format and bump version inline with librespot
stevenleadbeater Oct 27, 2024
478a3f1
format and bump version inline with librespot
stevenleadbeater Oct 27, 2024
8cbdfc4
fix flatpak
stevenleadbeater Oct 27, 2024
0906f00
fix clippy warnings
stevenleadbeater Oct 28, 2024
951a7f2
fix fmt warnings
stevenleadbeater Oct 28, 2024
1b19ae4
remove password login method (more cleanup possible), add login html …
xou816 Nov 15, 2024
8331f85
Merge remote-tracking branch 'origin/development' into development
stevenleadbeater Nov 16, 2024
53215ad
fix fmt warnings
stevenleadbeater Nov 16, 2024
341631d
upgrade to librespot 0.6.0
stevenleadbeater Nov 16, 2024
faa00f7
check CSRF token
stevenleadbeater Nov 16, 2024
cfc9721
fix fmt warnings
stevenleadbeater Nov 16, 2024
4c9921f
update cargo sources for librespot 0.6.0
stevenleadbeater Nov 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
set SpotifyItemType on the SpotifyId used to play tracks as `Spot…
…ifyId::from_base62` is setting this to unkown which causes playback to fail with ` Unable to load audio item: Error { kind: Unavailable, error: NonPlayable } / unable to load track <SpotifyId("spotify:unknown:1iI5J72TQxYdQkKnkRwWCn")>`
  • Loading branch information
stevenleadbeater committed Nov 16, 2024

Verified

This commit was signed with the committer’s verified signature. The key has expired.
stevenleadbeater Steven Leadbeater
commit 7f9ee05f29dd77d0b6c89a12e8556c2a2c47950d
32 changes: 21 additions & 11 deletions src/app/components/player_notifier.rs
Original file line number Diff line number Diff line change
@@ -2,7 +2,7 @@ use std::ops::Deref;
use std::rc::Rc;

use futures::channel::mpsc::UnboundedSender;
use librespot::core::spotify_id::SpotifyId;
use librespot::core::spotify_id::{SpotifyId, SpotifyItemType};

use crate::app::components::EventListener;
use crate::app::state::{
@@ -78,7 +78,7 @@ impl PlayerNotifier {
Some(result)
}

fn device(&self) -> impl Deref<Target = Device> + '_ {
fn device(&self) -> impl Deref<Target=Device> + '_ {
self.app_model.map_state(|s| s.playback.current_device())
}

@@ -113,10 +113,10 @@ impl PlayerNotifier {
PlaybackEvent::TrackChanged(_) | PlaybackEvent::SourceChanged => {
match currently_playing {
Some(CurrentlyPlaying::WithSource {
source,
offset,
song,
}) => Some(ConnectCommand::PlayerLoadInContext {
source,
offset,
song,
}) => Some(ConnectCommand::PlayerLoadInContext {
source,
offset,
song,
@@ -154,22 +154,32 @@ impl PlayerNotifier {
PlaybackEvent::PlaybackStopped => Some(Command::PlayerStop),
PlaybackEvent::VolumeSet(volume) => Some(Command::PlayerSetVolume(*volume)),
PlaybackEvent::TrackChanged(id) => {
info!("track changed: {}", id);
SpotifyId::from_base62(id)
.ok()
.map(|track| Command::PlayerLoad {
track,
resume: true,
.map(|mut track| {
track.item_type = SpotifyItemType::Track;
Command::PlayerLoad {
track,
resume: true,
}
})
}
PlaybackEvent::SourceChanged => {
let resume = self.is_playing();
self.currently_playing()
.and_then(|c| SpotifyId::from_base62(c.song_id()).ok())
.map(|track| Command::PlayerLoad { track, resume })
.map(|mut track| {
track.item_type = SpotifyItemType::Track;
Command::PlayerLoad { track, resume }
})
}
PlaybackEvent::TrackSeeked(position) => Some(Command::PlayerSeek(*position)),
PlaybackEvent::Preload(id) => {
SpotifyId::from_base62(id).ok().map(Command::PlayerPreload)
SpotifyId::from_base62(id).ok().map(|mut track| {
track.item_type = SpotifyItemType::Track;
track
}).map(Command::PlayerPreload)
}
_ => None,
};