Fix #173 (a track cannot be played with librespot)

Some tracks might have several `allowed` fields, librespot assumes that all fields must match, otherwise track cannot be played.
This change collects all `allowed` and `forbidden` lists, then does the final check on whole lists at once.
This commit is contained in:
Evgeny S 2017-06-01 13:04:22 +03:00 committed by GitHub
parent 6f24e3b731
commit 4a17a15a82

View file

@ -16,13 +16,19 @@ fn countrylist_contains(list: &str, country: &str) -> bool {
fn parse_restrictions<'s, I>(restrictions: I, country: &str, catalogue: &str) -> bool
where I: IntoIterator<Item = &'s protocol::metadata::Restriction>
{
restrictions.into_iter()
.filter(|r| r.get_catalogue_str().contains(&catalogue.to_owned()))
.all(|r| {
!countrylist_contains(r.get_countries_forbidden(), country) &&
(!r.has_countries_allowed() ||
countrylist_contains(r.get_countries_allowed(), country))
})
let mut forbidden = "".to_string();
let mut allowed = "".to_string();
let rs = restrictions.into_iter().filter(|r|
r.get_catalogue_str().contains(&catalogue.to_owned())
);
for r in rs {
forbidden.push_str(r.get_countries_forbidden());
allowed.push_str(r.get_countries_allowed());
}
(forbidden == "" || !countrylist_contains(forbidden.as_str(), country)) &&
(allowed == "" || countrylist_contains(allowed.as_str(), country))
}
pub trait MetadataTrait : Send + 'static {