unifi_protect

Crates.iounifi_protect
lib.rsunifi_protect
version0.5.2
sourcesrc
created_at2023-07-23 14:28:18.1379
updated_at2024-02-16 21:45:32.736128
descriptionAn SDK for interacting with a unifi protect server
homepagehttps://github.com/xlfpx/unifi-protect-rust
repositoryhttps://github.com/xlfpx/unifi-protect-rust
max_upload_size
id923778
size154,568
Lars Frölich (xlfpx)

documentation

README

UniFi-Protect Rust Library

Crates.io Docs.rs Build Status

This library enables interacting with a unifi protect server (such as the one running on a ubiquiti cloud key gen2). It aims to eventually be a complete implementation of the unifi protect api in Rust, closely following the example of the javascript-based https://github.com/hjdhjd/unifi-protect/ It is also used in the unifi-protect-bulk-download tool for downloading footage from a unifi protect system.

To add the library to an existing cargo project: cargo add unifi-protect

Basic usage:

use unifi_protect::UnifiProtectServer;

// [ ...]
// within an async context:

// create a new instance using the base uri of the unifi protect server (same uri you would use to reach the system's web portal)
let mut server = UnifiProtectServer::new("BASE_URI"); // ( e.g. "https://192.168.1.28")
// login with username + password credentials (same credentials you would use to login to the system's web portal)
server
    .login("USERNAME", "PASSWORD")
    .await
    .expect("Failed to login");
server
    .fetch_cameras()
    .await
    .expect("Failed to fetch cameras");
println!("Found {} cameras", server.cameras.len());
Commit count: 22

cargo fmt