diff options
author | FxQnLr <39925636+FxQnLr@users.noreply.github.com> | 2024-04-11 15:48:20 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-04-11 15:48:20 +0200 |
commit | b615f6e34e084d520dcc301058b5926074188500 (patch) | |
tree | cd19ad3355949b682485f720339a856b9de3396a /src/wol.rs | |
parent | 6b05d1a437a49db98056de7b029923e8aedf1a5a (diff) | |
parent | 1777c5c91c7b37ad458b62930f20fc518ca76777 (diff) | |
download | webol-b615f6e34e084d520dcc301058b5926074188500.tar webol-b615f6e34e084d520dcc301058b5926074188500.tar.gz webol-b615f6e34e084d520dcc301058b5926074188500.zip |
Merge pull request #34 from FxQnLr/nostartv0.4.0
Fix devices not starting
Diffstat (limited to 'src/wol.rs')
-rw-r--r-- | src/wol.rs | 23 |
1 files changed, 23 insertions, 0 deletions
@@ -1,7 +1,29 @@ | |||
1 | use std::net::{ToSocketAddrs, UdpSocket}; | 1 | use std::net::{ToSocketAddrs, UdpSocket}; |
2 | 2 | ||
3 | use tracing::trace; | ||
4 | |||
3 | use crate::error::Error; | 5 | use crate::error::Error; |
4 | 6 | ||
7 | /// Creates the magic packet from a mac address | ||
8 | /// | ||
9 | /// # Panics | ||
10 | /// | ||
11 | /// Panics if `mac_addr` is an invalid mac | ||
12 | pub fn create_buffer(mac_addr: &str) -> Result<Vec<u8>, Error> { | ||
13 | let mut mac = Vec::new(); | ||
14 | let sp = mac_addr.split(':'); | ||
15 | for f in sp { | ||
16 | mac.push(u8::from_str_radix(f, 16)?); | ||
17 | } | ||
18 | let mut buf = vec![255; 6]; | ||
19 | for _ in 0..16 { | ||
20 | for i in &mac { | ||
21 | buf.push(*i); | ||
22 | } | ||
23 | } | ||
24 | Ok(buf) | ||
25 | } | ||
26 | |||
5 | /// Sends a buffer on UDP broadcast | 27 | /// Sends a buffer on UDP broadcast |
6 | pub fn send_packet<A: ToSocketAddrs>( | 28 | pub fn send_packet<A: ToSocketAddrs>( |
7 | bind_addr: A, | 29 | bind_addr: A, |
@@ -10,5 +32,6 @@ pub fn send_packet<A: ToSocketAddrs>( | |||
10 | ) -> Result<usize, Error> { | 32 | ) -> Result<usize, Error> { |
11 | let socket = UdpSocket::bind(bind_addr)?; | 33 | let socket = UdpSocket::bind(bind_addr)?; |
12 | socket.set_broadcast(true)?; | 34 | socket.set_broadcast(true)?; |
35 | trace!(?buffer ,"start with"); | ||
13 | Ok(socket.send_to(buffer, broadcast_addr)?) | 36 | Ok(socket.send_to(buffer, broadcast_addr)?) |
14 | } | 37 | } |