2025-03-15 16:10:11 +08:00
|
|
|
|
use colored::Colorize;
|
|
|
|
|
|
use log::info;
|
|
|
|
|
|
|
2025-01-07 00:34:16 +08:00
|
|
|
|
use crate::messager;
|
|
|
|
|
|
use std::fmt::Debug;
|
|
|
|
|
|
use std::sync::mpsc;
|
|
|
|
|
|
pub struct Messager {
|
|
|
|
|
|
name: String,
|
|
|
|
|
|
sender: mpsc::Sender<messager::Message>,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub struct Message {
|
|
|
|
|
|
pub name: String,
|
|
|
|
|
|
pub signal: Signals,
|
|
|
|
|
|
}
|
2025-03-15 16:10:11 +08:00
|
|
|
|
impl Message {
|
|
|
|
|
|
// 定义一个公共方法 log,用于记录不同信号状态下的日志信息
|
|
|
|
|
|
pub fn log(&self) {
|
|
|
|
|
|
let loginfo = match &self.signal {
|
|
|
|
|
|
Signals::Start => "读取文件",
|
|
|
|
|
|
Signals::GetMetaInfo => "解密歌曲元信息",
|
|
|
|
|
|
Signals::GetCover => "解密封面图片数据",
|
|
|
|
|
|
Signals::Decrypt => "解密歌曲信息",
|
|
|
|
|
|
Signals::Save => "保存文件",
|
|
|
|
|
|
Signals::End => "成功!",
|
|
|
|
|
|
};
|
|
|
|
|
|
info!("[{}] {}", self.name.cyan(), loginfo)
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-01-07 00:34:16 +08:00
|
|
|
|
pub enum Signals {
|
|
|
|
|
|
Start,
|
2025-03-15 16:10:11 +08:00
|
|
|
|
GetMetaInfo,
|
|
|
|
|
|
GetCover,
|
2025-01-07 00:34:16 +08:00
|
|
|
|
Decrypt,
|
|
|
|
|
|
Save,
|
|
|
|
|
|
End,
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl Messager {
|
|
|
|
|
|
pub fn new(name: String, sender: mpsc::Sender<messager::Message>) -> Self {
|
|
|
|
|
|
Self { name, sender }
|
|
|
|
|
|
}
|
|
|
|
|
|
pub fn send(&self, s: Signals) -> Result<(), std::sync::mpsc::SendError<messager::Message>> {
|
|
|
|
|
|
self.sender.send(Message {
|
|
|
|
|
|
name: self.name.clone(),
|
|
|
|
|
|
signal: s,
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
impl Debug for Message {
|
|
|
|
|
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
|
|
|
|
|
let message = match &self.signal {
|
2025-03-15 16:10:11 +08:00
|
|
|
|
Signals::Start => "开始破解",
|
|
|
|
|
|
Signals::Decrypt => "开始解密",
|
|
|
|
|
|
Signals::Save => "保存文件",
|
|
|
|
|
|
Signals::End => "破解完成",
|
|
|
|
|
|
Signals::GetMetaInfo => "获取元数据",
|
|
|
|
|
|
Signals::GetCover => "获取封面",
|
2025-01-07 00:34:16 +08:00
|
|
|
|
};
|
|
|
|
|
|
write!(f, "[{}] {}", self.name, message)
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|