/wifi-rs

📡 Easily interface and manage wireless networks.

Primary LanguageRust

WiFi-rs

A rust crate to interface and manage Wi-Fi networks.

This is a command-line counterpart of managing networks instead of via a GUI.

Features

  • Connect to a WiFi (Windows, Linux, MacOS).
  • Disconnect from a WiFi network (Windows, Linux, MacOS).
  • Create hotspot (Windows, Linux).

Currently supported network types

Note that only open, WEP and WPA-PSK networks are supported at the moment.

It is also supposed that IP configuration is obtained via DHCP.

Supported Operating Systems

  • Windows
  • Linux
  • MacOS

Example

use wifi_rs::{prelude::*, WiFi};

fn main() -> Result<(), WifiConnectionError> {
    let config = Some(Config {
        interface: Some("wlo1"),
    });

    let mut wifi = WiFi::new(config);

    match wifi.connect("AndroidAPSD22", "belm4235") {
        Ok(result) => println!(
            "{}",
            if result == true {
                "Connection Successful."
            } else {
                "Invalid password."
            }
        ),
        Err(err) => println!("The following error occurred: {:?}", err),
    }

    Ok(())
}

Todos

Windows

  • Support for Windows.
  • Bundle windows profile sample as literals.
  • Add hotspot functionality.
  • Use tempfile crate on windows to generate windows profile temporary file.
  • Fix the implementation for is_wifi_enabled for windows.
  • Add implementation for WifiInterface trait.
  • Add get network type feature.

Linux

  • Support for linux.
  • Add disconnect feature.
  • Add hotspot functionality.
  • Add get network type feature.

MacOS

  • Add support for MacOS.
  • Add hotspot functionality.
  • Add get network type feature.

General

  • Return detailed error messages.
  • Write documentation.
  • Update wifi-CLI with recent updates.

Contribution

Any feature you feel is missing, why not send in a Pull Request, and let's help make this project better. Or if there are any bugs, kindly create an issue, so we could work together towards fixing it.

Support

Love this project, please show some love by starring the project 😃.