Skip to content

Commit

Permalink
Update zeroconf fields and publish active user
Browse files Browse the repository at this point in the history
  • Loading branch information
roderickvd committed Oct 1, 2022
1 parent f10b8f6 commit bae304f
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 16 deletions.
13 changes: 7 additions & 6 deletions discovery/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,13 +77,14 @@ impl From<DiscoveryError> for Error {
}

impl Builder {
/// Starts a new builder using the provided device id.
pub fn new(device_id: impl Into<String>) -> Self {
/// Starts a new builder using the provided device and client IDs.
pub fn new<T: Into<String>>(device_id: T, client_id: T) -> Self {
Self {
server_config: server::Config {
name: "Librespot".into(),
device_type: DeviceType::default(),
device_id: device_id.into(),
client_id: client_id.into(),
},
port: 0,
}
Expand Down Expand Up @@ -141,13 +142,13 @@ impl Builder {

impl Discovery {
/// Starts a [`Builder`] with the provided device id.
pub fn builder(device_id: impl Into<String>) -> Builder {
Builder::new(device_id)
pub fn builder<T: Into<String>>(device_id: T, client_id: T) -> Builder {
Builder::new(device_id, client_id)
}

/// Create a new instance with the specified device id and default paramaters.
pub fn new(device_id: impl Into<String>) -> Result<Self, Error> {
Self::builder(device_id).launch()
pub fn new<T: Into<String>>(device_id: T, client_id: T) -> Result<Self, Error> {
Self::builder(device_id, client_id).launch()
}
}

Expand Down
42 changes: 33 additions & 9 deletions discovery/src/server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,12 @@ pub struct Config {
pub name: Cow<'static, str>,
pub device_type: DeviceType,
pub device_id: String,
pub client_id: String,
}

struct RequestHandler {
config: Config,
username: Option<String>,
keys: DhLocalKeys,
tx: mpsc::UnboundedSender<Credentials>,
}
Expand All @@ -50,6 +52,7 @@ impl RequestHandler {

let discovery = Self {
config,
username: None,
keys: DhLocalKeys::random(&mut rand::thread_rng()),
tx,
};
Expand All @@ -60,24 +63,45 @@ impl RequestHandler {
fn handle_get_info(&self) -> Response<hyper::Body> {
let public_key = base64::encode(&self.keys.public_key());
let device_type: &str = self.config.device_type.into();
let mut active_user = String::new();
if let Some(username) = &self.username {
active_user = username.to_string();
}

// See: https://developer.spotify.com/documentation/commercial-hardware/implementation/guides/zeroconf/
let body = json!({
"status": 101,
"statusString": "ERROR-OK",
"statusString": "OK",
"spotifyError": 0,
"version": crate::core::version::SEMVER,
// departing from the Spotify documentation, Google Cast uses "5.0.0"
"version": "2.9.0",
"deviceID": (self.config.device_id),
"deviceType": (device_type),
"remoteName": (self.config.name),
"activeUser": "",
// valid value seen in the wild: "empty"
"publicKey": (public_key),
"deviceType": (device_type),
"libraryVersion": crate::core::version::SEMVER,
"accountReq": "PREMIUM",
"brandDisplayName": "librespot",
"modelDisplayName": "librespot",
"resolverVersion": "0",
"libraryVersion": crate::core::version::SEMVER,
"resolverVersion": "1",
"groupStatus": "NONE",
"voiceSupport": "NO",
// valid value documented & seen in the wild: "accesstoken"
// Using it will cause clients to fail to connect.
"tokenType": "default",
"clientID": (self.config.client_id),
"productID": 0,
// Other known scope: client-authorization-universal
// Comma-separated.
"scope": "streaming",
"availability": "",
"supported_drm_media_formats": [],
// TODO: bitmask but what are the flags?
"supported_capabilities": 1,
// undocumented but should still work
"accountReq": "PREMIUM",
"activeUser": active_user,
// others seen-in-the-wild:
// - "deviceAPI_isGroup": False
})
.to_string();

Expand Down Expand Up @@ -162,7 +186,7 @@ impl RequestHandler {
let result = json!({
"status": 101,
"spotifyError": 0,
"statusString": "ERROR-OK"
"statusString": "OK",
});

let body = result.to_string();
Expand Down
3 changes: 2 additions & 1 deletion src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1635,7 +1635,8 @@ async fn main() {

if setup.enable_discovery {
let device_id = setup.session_config.device_id.clone();
match librespot::discovery::Discovery::builder(device_id)
let client_id = setup.session_config.client_id.clone();
match librespot::discovery::Discovery::builder(device_id, client_id)
.name(setup.connect_config.name.clone())
.device_type(setup.connect_config.device_type)
.port(setup.zeroconf_port)
Expand Down

0 comments on commit bae304f

Please sign in to comment.