Crates.io | luxafor |
lib.rs | luxafor |
version | 0.3.0 |
source | src |
created_at | 2020-08-17 23:29:38.924264 |
updated_at | 2024-07-22 16:50:37.007396 |
description | Library, and CLI, for Luxafor lights via either USB or webhooks. |
homepage | |
repository | https://github.com/johnstonskj/rust-luxafor |
max_upload_size | |
id | 277720 |
size | 100,396 |
Library, and CLI, for Luxafor lights via either USB or webhooks.
The main entry point for clients is the trait Device
that has implementations for USB connected devices such as the
flag as well as webhooks for both the flag and
bluetooth lights.
Each connection has its own discovery or connection methods but will provide a Device
implementation
for the manipulation of the light state.
The following example shows a function that sets the light to a solid red color. It demonstrates the use of a USB connected device.
use luxafor::usb_hid::USBDeviceDiscovery;
use luxafor::{Device, SolidColor};
use luxafor::error::Result;
fn set_do_not_disturb() -> Result<()> {
let discovery = USBDeviceDiscovery::new()?;
let device = discovery.device()?;
println!("USB device: '{}'", device.id());
device.set_solid_color(SolidColor::Red, false)
}
The following shows the same function but using the webhook connection.
use luxafor::webhook::new_device_for;
use luxafor::{Device, SolidColor};
use luxafor::error::Result;
fn set_do_not_disturb(device_id: &str) -> Result<()> {
let device = new_device_for(device_id)?;
println!("Webhook device: '{}'", device.id());
device.set_solid_color(SolidColor::Red, false)
}
The following shows the command line tool setting the color to red.
❯ lux -d 2a0f2c73b72 solid red
The following shows the command line tool setting the color to a blinking green. This example uses the environment
variable LUX_DEVICE
to save repeating the device identifier on each call.
❯ export LUX_DEVICE=2a0f2c73b72
❯ lux blink green
The following shows the command line tool turning the light off.
❯ lux -vvv -d 2a0f2c73b72 off
INFO luxafor > Setting the color of device '2a0f2c73b72e' to 000000
INFO luxafor > call successful
lux
, it is not on by default for library clients.usb_hid
module.Wave
enumDevice
.
TargetedDevice
trait and USB implementation.DeviceIdentifier
trait, and Device
now returns a String.Device
trait