Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cijiugechu/utwt

Parsing utmp file
https://github.com/cijiugechu/utwt

linux login parser rust utmp wtmp

Last synced: 2 months ago
JSON representation

Parsing utmp file

Awesome Lists containing this project

README

        

# `utwt`

[![Crates.io](https://img.shields.io/crates/v/utwt.svg)](https://crates.io/crates/utwt)
[![Docs](https://docs.rs/utwt/badge.svg)](https://docs.rs/utwt)

A Rust crate for parsing `utmp` files like `/var/run/utmp` and `/var/log/wtmp`.

> Note: This project has been forked from [utmp-rs](https://github.com/upsuper/utmp-rs) since September of 2023, but a lot has changed.

## Usage

Simplest way is to use `parse_from_*` functions,
which returns a `Vec` on success:
```rust
let entries = utwt::parse_utmp()?;
// or specify a path explicitly
let entries = utwt::parse_from_path("/var/run/utmp")?;
//
```

If you don't need to collect them all,
`UtmpParser` can be used as an iterator:
```rust
use utwt::UtmpParser;
for entry in UtmpParser::from_path("/var/run/utmp")? {
let entry = entry?;
// ...
}
```

All the `parse_from_*` functions as well as `UtmpParser` parse `utmp` file
based on the native format for the target platform.
If cross-platform parsing is needed,
`Utmp32Parser` or `Utmp64Parser` can be used instead of `UtmpParser`.