leda

Crates.ioleda
lib.rsleda
version0.5.0
sourcesrc
created_at2022-10-11 15:07:35.784531
updated_at2023-01-17 03:08:51.547263
descriptionA gemini client backend
homepage
repository
max_upload_size
id685394
size52,244
maebee (maebee-cm)

documentation

README

Leda

A crate that implements the client logic for several small internet protocols. Currently only supports gemini but with plans to support other protocols in the future.

Get started

This is a minimal example to show what using this library is like. It will grab the gemini homepage and print it's contents both in the plain gemtext format and as html.

You can run this example by running cargo run --example readme.

use leda::gemini::{self, gemtext::Gemtext};
use std::time::Duration;

fn main() {
    let url = String::from("gemini://gemini.circumlunar.space/");

    let mut client = gemini::Client::with_timeout(Some(Duration::from_secs(5)))
        .expect("Failed to create gemini client");

    let response = client.request(url).expect("Failed to retrieve gemini page");

    // Check that the server responded successfully with a gemtext document
    let body = if let gemini::header::StatusCode::Success = response.header.status {
        if !response.header.meta.starts_with("text/gemini") {
            panic!("The server didn't respond with a gemtext document when we expected it to");
        }
        response.body.as_ref().unwrap()
    } else {
        // you can handle differents errors, redirects, and input requests as you see fit from
        // here on!
        panic!("Page requested didn't return a body!");
    };

    let body = std::str::from_utf8(&body).expect("Failed to parse body as utf8");
    assert!(Gemtext::new(body).is_ok());
    println!("raw body: \n{}\n", body);
}
Commit count: 0

cargo fmt