https://github.com/yggverse/ggemini
Glib-oriented client for Gemini protocol
https://github.com/yggverse/ggemini
async client gemini gemini-protocol gio glib gtk socket titan tls
Last synced: 6 months ago
JSON representation
Glib-oriented client for Gemini protocol
- Host: GitHub
- URL: https://github.com/yggverse/ggemini
- Owner: YGGverse
- License: mit
- Created: 2024-10-18T18:24:15.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2025-03-27T22:33:36.000Z (7 months ago)
- Last Synced: 2025-05-01T15:18:39.760Z (6 months ago)
- Topics: async, client, gemini, gemini-protocol, gio, glib, gtk, socket, titan, tls
- Language: Rust
- Homepage: https://crates.io/crates/ggemini
- Size: 291 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ggemini

[](https://docs.rs/ggemini)
[](https://crates.io/crates/ggemini)
Glib/Gio-oriented network API for [Gemini protocol](https://geminiprotocol.net/)
> [!IMPORTANT]
> Project in development!
>
GGemini (or G-Gemini) library written as the client extension for [Yoda](https://github.com/YGGverse/Yoda), it also could be useful for other GTK-based applications dependent of [glib](https://crates.io/crates/glib) / [gio](https://crates.io/crates/gio) (`2.66+`) backend.
## Requirements
Debian
sudo apt install libglib2.0-dev
Fedora
sudo dnf install glib2-devel
## Install
```
cargo add ggemini
```
## Usage
* [Documentation](https://docs.rs/ggemini/latest/ggemini/)
### Example
``` rust
use gio::*;
use glib::*;
use ggemini::client::{
connection::{request::{Mode, Request}, Response},
Client,
};
fn main() -> ExitCode {
Client::new().request_async(
Request::Gemini { // or `Request::Titan`
uri: Uri::parse("gemini://geminiprotocol.net/", UriFlags::NONE).unwrap(),
mode: Mode::HeaderOnly // handle content separately (based on MIME)
},
Priority::DEFAULT,
Cancellable::new(),
None, // optional `GTlsCertificate`
|result| match result {
Ok((response, _connection)) => match response {
Response::Success(success) => match success.mime().unwrap().as_str() {
"text/gemini" => todo!(),
_ => todo!(),
},
_ => todo!(),
},
Err(_) => todo!(),
},
);
ExitCode::SUCCESS
}
```
## Other crates
* [ggemtext](https://github.com/YGGverse/ggemtext) - Glib-oriented Gemtext API