Add request device information and implement base of RPCResult
This commit is contained in:
parent
945c8386ad
commit
5bfe2bde5a
@ -117,6 +117,7 @@ impl std::fmt::Display for ErrorState {
|
|||||||
pub enum RPCCommand {
|
pub enum RPCCommand {
|
||||||
SendWifiSettings = 0x01,
|
SendWifiSettings = 0x01,
|
||||||
RequestCurrentState = 0x02,
|
RequestCurrentState = 0x02,
|
||||||
|
RequestDeviceInformation = 0x03,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn calculate_checksum(data: &[u8]) -> u8 {
|
pub fn calculate_checksum(data: &[u8]) -> u8 {
|
||||||
@ -216,6 +217,8 @@ pub enum ImprovPacket {
|
|||||||
CurrentStateResponse(CurrentStateResponse),
|
CurrentStateResponse(CurrentStateResponse),
|
||||||
ErrorState(ErrorStatePacket),
|
ErrorState(ErrorStatePacket),
|
||||||
RequestCurrentStateCommand(RequestCurrentStateCommand),
|
RequestCurrentStateCommand(RequestCurrentStateCommand),
|
||||||
|
RequestDeviceInformation(RequestDeviceInformationPacket),
|
||||||
|
RPCResult(RPCResultPacket),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ImprovPacket {
|
impl ImprovPacket {
|
||||||
@ -224,8 +227,8 @@ impl ImprovPacket {
|
|||||||
PacketType::CurrentState => Ok(ImprovPacket::CurrentStateResponse(CurrentStateResponse::try_from_raw_packet(raw_packet)?)),
|
PacketType::CurrentState => Ok(ImprovPacket::CurrentStateResponse(CurrentStateResponse::try_from_raw_packet(raw_packet)?)),
|
||||||
PacketType::ErrorState => Ok(ImprovPacket::ErrorState(ErrorStatePacket::try_from_raw_packet(raw_packet)?)),
|
PacketType::ErrorState => Ok(ImprovPacket::ErrorState(ErrorStatePacket::try_from_raw_packet(raw_packet)?)),
|
||||||
//PacketType::RPCCommand => _,
|
//PacketType::RPCCommand => _,
|
||||||
//PacketType::RPCResult => _,
|
PacketType::RPCResult => Ok(ImprovPacket::RPCResult(RPCResultPacket::try_from_raw_packet(raw_packet)?)),
|
||||||
_ => Err("Conversion into packet type {} not implemented"),
|
_ => Err("Conversion into packet type not implemented"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -297,3 +300,43 @@ impl ImprovDataToPacket for RequestCurrentStateCommand {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct RequestDeviceInformationPacket {
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ImprovDataPacketType for RequestDeviceInformationPacket {
|
||||||
|
const packet_type: PacketType = PacketType::RPCCommand;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ImprovDataToPacket for RequestDeviceInformationPacket {
|
||||||
|
fn to_bytes(self: &Self) -> Vec<u8> {
|
||||||
|
let mut out = Vec::new();
|
||||||
|
out.push(RPCCommand::RequestDeviceInformation as u8);
|
||||||
|
out.push(0x00); // rpc command payload length
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct RPCResultPacket {
|
||||||
|
results: Vec<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ImprovDataPacketType for RPCResultPacket {
|
||||||
|
const packet_type: PacketType = PacketType::RPCResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ImprovDataFromPacket for RPCResultPacket {
|
||||||
|
type Error = &'static str;
|
||||||
|
|
||||||
|
fn try_from_raw_packet(raw_packet: &RawPacket) -> Result<Self, Self::Error>{
|
||||||
|
if raw_packet.r#type != Self::packet_type {
|
||||||
|
return Err("Packet is not RPCResult");
|
||||||
|
}
|
||||||
|
|
||||||
|
let results: Vec<String> = Vec::new();
|
||||||
|
|
||||||
|
return Ok(Self {
|
||||||
|
results: results,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
24
src/main.rs
24
src/main.rs
@ -19,6 +19,7 @@ use improv_setup::improv::{
|
|||||||
RawPacket,
|
RawPacket,
|
||||||
ImprovPacket,
|
ImprovPacket,
|
||||||
RequestCurrentStateCommand,
|
RequestCurrentStateCommand,
|
||||||
|
RequestDeviceInformationPacket,
|
||||||
};
|
};
|
||||||
use log::{
|
use log::{
|
||||||
debug,
|
debug,
|
||||||
@ -39,6 +40,8 @@ enum DeviceCommands {
|
|||||||
/// Password for the SSID
|
/// Password for the SSID
|
||||||
password: String,
|
password: String,
|
||||||
},
|
},
|
||||||
|
/// Request device info
|
||||||
|
Info,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for DeviceCommands {
|
impl Default for DeviceCommands {
|
||||||
@ -168,7 +171,26 @@ async fn main() -> Result<()>{
|
|||||||
},
|
},
|
||||||
DeviceCommands::SetWifi {ssid, password} => {
|
DeviceCommands::SetWifi {ssid, password} => {
|
||||||
println!("Not implemented");
|
println!("Not implemented");
|
||||||
}
|
},
|
||||||
|
DeviceCommands::Info => {
|
||||||
|
let request_device_information_packet = (RequestDeviceInformationPacket {}).to_raw_packet();
|
||||||
|
|
||||||
|
let mut serial_interface = tokio_serial::new(path, *baud_rate).open().unwrap();
|
||||||
|
serial_interface.write(&request_device_information_packet.to_bytes()).unwrap();
|
||||||
|
|
||||||
|
let mut buffer: Vec<u8> = Vec::new();
|
||||||
|
serial_interface.read_to_end(&mut buffer);
|
||||||
|
|
||||||
|
let improv_packet_offset = find_begin_of_improv_packet(&buffer).unwrap();
|
||||||
|
|
||||||
|
let improv_packet_end = improv_packet_offset + 10 + <u8 as Into<usize>>::into(buffer[improv_packet_offset+8]);
|
||||||
|
let raw_packet = RawPacket::try_from_bytes(&buffer[improv_packet_offset..improv_packet_end].to_vec()).unwrap();
|
||||||
|
|
||||||
|
|
||||||
|
if let ImprovPacket::RPCResult(rpc_result) = ImprovPacket::try_from_raw_packet(&raw_packet).unwrap() {
|
||||||
|
println!("Received RPCResult");
|
||||||
|
}
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user