audio_key.rs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. use byteorder::{BigEndian, ByteOrder, WriteBytesExt};
  2. use bytes::Bytes;
  3. use futures::sync::oneshot;
  4. use futures::{Async, Future, Poll};
  5. use std::collections::HashMap;
  6. use std::io::Write;
  7. use crate::spotify_id::{FileId, SpotifyId};
  8. use crate::util::SeqGenerator;
  9. #[derive(Debug, Hash, PartialEq, Eq, Copy, Clone)]
  10. pub struct AudioKey(pub [u8; 16]);
  11. #[derive(Debug, Hash, PartialEq, Eq, Copy, Clone)]
  12. pub struct AudioKeyError;
  13. component! {
  14. AudioKeyManager : AudioKeyManagerInner {
  15. sequence: SeqGenerator<u32> = SeqGenerator::new(0),
  16. pending: HashMap<u32, oneshot::Sender<Result<AudioKey, AudioKeyError>>> = HashMap::new(),
  17. }
  18. }
  19. impl AudioKeyManager {
  20. pub(crate) fn dispatch(&self, cmd: u8, mut data: Bytes) {
  21. let seq = BigEndian::read_u32(data.split_to(4).as_ref());
  22. let sender = self.lock(|inner| inner.pending.remove(&seq));
  23. if let Some(sender) = sender {
  24. match cmd {
  25. 0xd => {
  26. let mut key = [0u8; 16];
  27. key.copy_from_slice(data.as_ref());
  28. let _ = sender.send(Ok(AudioKey(key)));
  29. }
  30. 0xe => {
  31. warn!(
  32. "error audio key {:x} {:x}",
  33. data.as_ref()[0],
  34. data.as_ref()[1]
  35. );
  36. let _ = sender.send(Err(AudioKeyError));
  37. }
  38. _ => (),
  39. }
  40. }
  41. }
  42. pub fn request(&self, track: SpotifyId, file: FileId) -> AudioKeyFuture<AudioKey> {
  43. let (tx, rx) = oneshot::channel();
  44. let seq = self.lock(move |inner| {
  45. let seq = inner.sequence.get();
  46. inner.pending.insert(seq, tx);
  47. seq
  48. });
  49. self.send_key_request(seq, track, file);
  50. AudioKeyFuture(rx)
  51. }
  52. fn send_key_request(&self, seq: u32, track: SpotifyId, file: FileId) {
  53. let mut data: Vec<u8> = Vec::new();
  54. data.write(&file.0).unwrap();
  55. data.write(&track.to_raw()).unwrap();
  56. data.write_u32::<BigEndian>(seq).unwrap();
  57. data.write_u16::<BigEndian>(0x0000).unwrap();
  58. self.session().send_packet(0xc, data)
  59. }
  60. }
  61. pub struct AudioKeyFuture<T>(oneshot::Receiver<Result<T, AudioKeyError>>);
  62. impl<T> Future for AudioKeyFuture<T> {
  63. type Item = T;
  64. type Error = AudioKeyError;
  65. fn poll(&mut self) -> Poll<T, AudioKeyError> {
  66. match self.0.poll() {
  67. Ok(Async::Ready(Ok(value))) => Ok(Async::Ready(value)),
  68. Ok(Async::Ready(Err(err))) => Err(err),
  69. Ok(Async::NotReady) => Ok(Async::NotReady),
  70. Err(oneshot::Canceled) => Err(AudioKeyError),
  71. }
  72. }
  73. }