#wake-on-lan #wol #packets #magic #broadcasting #sending #mac

wakey

Wake-on-LAN library for creating and sending magic WOL packets

7 releases

0.3.0 Jan 6, 2023
0.2.2 Jun 26, 2022
0.1.2 Aug 20, 2019
0.1.1 Feb 4, 2019

#2 in #broadcasting

Download history 14/week @ 2024-06-17 41/week @ 2024-06-24 3/week @ 2024-07-01 31/week @ 2024-07-08 11/week @ 2024-07-15 40/week @ 2024-07-22 63/week @ 2024-07-29 34/week @ 2024-08-05 31/week @ 2024-08-12 14/week @ 2024-08-19 45/week @ 2024-08-26 40/week @ 2024-09-02 14/week @ 2024-09-09 33/week @ 2024-09-16 59/week @ 2024-09-23 50/week @ 2024-09-30

156 downloads per month

MIT license

10KB
181 lines

Wakey

Rust Crates.io docs.rs

Library for managing Wake-on-LAN packets. It supports:

  • creating magic packets,
  • broadcasting them via UDP.

Usage

From string representation of MAC address and using defaults when broadcasting:

let wol = wakey::WolPacket::from_string(&mac_adress, sep)?;
if wol.send_magic().is_ok() {
    println!("Sent the magic packet.");
} else {
    println!("Failed to send the magic packet.");
}

Packets can also be constructed with raw bytes and sent from / to custom addresses:

use std::net::SocketAddr;

let wol = wakey::WolPacket::from_bytes(&[0x00, 0x01, 0x02, 0x03, 0x04, 0x05])?;
let src = SocketAddr::from(([0,0,0,0], 0));
let dst = SocketAddr::from(([255,255,255,255], 9));

wol.send_magic_to(src, dst)?;

Included binary

cargo run --bin wakey-wake 00:11:22:33:44:55

lib.rs:

Library for managing Wake-on-LAN packets.

Example

let wol = wakey::WolPacket::from_string("01:02:03:04:05:06", ':').unwrap();
if wol.send_magic().is_ok() {
    println!("Sent the magic packet!");
} else {
    println!("Failed to send the magic packet!");
}

Dependencies

~90KB