logsnag
is a simple and efficient Rust library for interacting with the Logsnag API. It supports asynchronous requests and allows easy publication of logs and insights.
Note: this crate is currently being actively developed. It may change a lot until v1.0. Keep this in mind if you're using it for production apps.
First, add logsnag
to your Cargo.toml
:
toml
[dependencies]
logsnag = "0.4.0"
Then, import it in your file(s).
rust
use logsnag::Logsnag;
Here is a basic example of how to use the Logsnag
client. It uses a builder to add on to the initial event/insight for the optional parameters. Note that for tags, you can add one at a time with with_tag()
:
```rust use logsnag::Logsnag;
async fn main() {
let logsnag_key = env::var("LOGSNAG_API_KEY").expect("No Logsnag API Key (LOGSNAG_API_KEY) found in environment variables.");
let logsnag_project = env::var("LOGSNAG_PROJECT").expect("No Logsnag Project (LOGSNAG_PROJECT) found in environment variables.");
let logsnag = Logsnag::new(
&logsnag_key, //or pass "your-api-key-here"
&logsnag_project //or pass "your-logsnag-project-here"
);
let publish_result = logsnag.event("channel","event")
.with_notify(true)
.with_description("description")
.with_icon("❤️")
.with_tag("firsttag", "value")
.with_tag("secondtag", "secondvalue")
.publish()
.await;
let insight_result = logsnag.insight("Status", "online")
.with_icon("💀")
.publish()
.await;
} ```
See the API Documentation for more details.
Please feel free to submit issues, fork the repository and send pull requests!
Any questions, you can find me (rhh4x0r) on the Official Logsnag Discord Server or submit an issue.