1
0
mirror of https://github.com/YGGverse/Yoda.git synced 2025-01-26 19:14:13 +00:00
Yoda/README.md

221 lines
7.2 KiB
Markdown
Raw Normal View History

2024-09-18 20:39:03 +03:00
# Yoda - Browser for [Gemini protocol](https://geminiprotocol.net)
2024-10-11 22:45:00 +03:00
GTK 4 / Libadwaita client written in Rust
2024-09-18 20:39:03 +03:00
> [!IMPORTANT]
> Project in development!
2024-09-18 20:51:18 +03:00
>
2024-10-11 05:21:55 +03:00
![image](https://github.com/user-attachments/assets/cfbbc3fb-61d2-4afd-a21f-8e36ee329941)
2024-10-30 20:55:32 +02:00
## Features
2024-10-30 20:56:48 +02:00
### Interface
* [x] Multi-tab
* [x] Hotkeys
* [ ] Bookmarks
* [ ] Build-in multimedia support
2024-10-30 21:11:15 +02:00
* [x] [Images](#images)
* [ ] [Audio](#audio)
* [ ] [Video](#video)
2024-10-31 15:50:37 +02:00
* [ ] Certificates
2024-10-30 20:56:48 +02:00
* [ ] Downloads
* [ ] History
2024-10-30 21:03:02 +02:00
* [ ] Proxy
* [ ] Session
2024-10-30 21:18:43 +02:00
* [ ] Window
* [x] Size
* [x] Tabs
2024-10-30 21:21:38 +02:00
* [x] Pin
2024-10-30 21:18:43 +02:00
* [x] Page
* [ ] Content (cache)
* [x] Meta
* [x] Title
2024-10-30 21:18:43 +02:00
* [ ] Navigation
* [x] Request
* [ ] History
2024-10-30 21:03:02 +02:00
* [ ] User settings
2024-10-30 21:04:24 +02:00
### Protocols
2024-10-30 21:27:21 +02:00
* [ ] [Gemini](https://geminiprotocol.net/docs/protocol-specification.gmi)
2024-11-05 10:14:29 +02:00
* [ ] [Status code](https://geminiprotocol.net/docs/protocol-specification.gmi#status-codes)
2024-10-30 20:56:48 +02:00
* [x] Success
2024-10-30 21:05:41 +02:00
* [x] `20`
2024-10-30 20:56:48 +02:00
* [x] Input
2024-10-30 21:05:41 +02:00
* [x] `10` Input
* [x] `11` Sensitive input
2024-11-02 21:38:05 +02:00
* [x] Redirection
* [x] `30` Temporary
* [x] `31` Permanent
2024-10-30 21:05:41 +02:00
* [ ] Temporary failure
2024-11-01 18:11:01 +02:00
* [ ] `40` Unspecified condition
* [ ] `41` Server unavailable
* [ ] `42` CGI error
* [ ] `43` Proxy error
* [ ] `44` Slow down
2024-10-30 21:05:41 +02:00
* [ ] Permanent failure
2024-11-01 18:11:01 +02:00
* [ ] `50` General
* [ ] `51` Not found
* [ ] `52` Gone
* [ ] `53` Proxy request refused
* [ ] `59` Bad request
2024-10-30 20:56:48 +02:00
* [ ] Client certificates
2024-11-01 18:11:01 +02:00
* [ ] `60` Certificate requested
* [ ] `61` Certificate not authorized
* [ ] `62` Certificate not valid
2024-11-05 18:22:23 +02:00
* [x] [Gemtext](https://geminiprotocol.net/docs/gemtext-specification.gmi) (by [ggemtext](https://github.com/YGGverse/ggemtext))
* [x] Code (inline/multiline)
2024-11-05 18:27:11 +02:00
* [x] Inline
* [x] Multiline
* [x] Alt
2024-11-05 18:29:08 +02:00
* [ ] Terminal emulation*
* [ ] Syntax highlight*
2024-11-05 18:32:19 +02:00
* [x] Header
* [x] H1
* [x] H2
* [x] H3
2024-11-05 18:22:23 +02:00
* [x] Link
2024-11-05 18:25:49 +02:00
* [x] Address
* [x] Date
* [x] Alt
2024-11-05 18:22:23 +02:00
* [x] List
* [x] Quote
2024-11-05 10:14:29 +02:00
* [ ] Gemfeed
2024-10-31 15:39:24 +02:00
* [ ] Titan
2024-11-03 16:24:06 +02:00
* [ ] [NEX](https://nightfall.city/nex/info/specification.txt) - useful for networks with build-in encryption (e.g. [Yggdrasil](https://yggdrasil-network.github.io))
2024-10-31 15:39:24 +02:00
* [ ] [NPS](https://nightfall.city/nps/info/specification.txt)
2024-11-03 16:24:06 +02:00
* [ ] `file://` - localhost browser
2024-11-03 16:59:02 +02:00
* [ ] `config://` - low-level key/value settings editor
2024-10-30 21:03:02 +02:00
2024-10-30 20:56:48 +02:00
### Media types
2024-10-30 21:03:02 +02:00
2024-10-30 21:10:04 +02:00
#### Text
2024-10-30 20:56:48 +02:00
* [x] `text/gemini`
2024-10-30 21:06:28 +02:00
* [ ] `text/plain`
2024-10-30 21:10:04 +02:00
#### Images
2024-10-30 20:56:48 +02:00
* [x] `image/gif`
* [x] `image/jpeg`
* [x] `image/png`
* [x] `image/webp`
2024-11-01 17:47:54 +02:00
* [ ] `image/svg+xml`
2024-10-30 21:10:04 +02:00
#### Audio
2024-10-30 21:31:31 +02:00
* [ ] `audio/flac`
2024-10-30 20:56:48 +02:00
* [ ] `audio/mpeg`
* [ ] `audio/ogg`
2024-10-30 21:10:04 +02:00
#### Video
2024-10-30 20:55:32 +02:00
2024-10-10 16:17:59 +03:00
## Build
2024-09-18 20:51:18 +03:00
2024-10-12 04:24:17 +03:00
### Requirements
2024-10-10 16:17:59 +03:00
2024-10-12 04:24:17 +03:00
Make sure your system support:
2024-10-10 22:26:09 +03:00
2024-10-13 01:22:00 +03:00
* Glib 2.56+
2024-10-13 08:52:53 +03:00
* GTK 4.10+
2024-10-13 20:41:10 +03:00
* Libadwaita 1.6+
2024-10-10 22:26:09 +03:00
2024-10-12 04:25:34 +03:00
Use [rustup](https://rustup.rs) installer to setup latest Rust compiler and Cargo package manager:
2024-10-10 16:17:59 +03:00
``` bash
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
```
#### Debian
_todo_
#### Fedora
``` bash
sudo dnf install git gcc\
cairo-devel glib2-devel gtk4-devel libadwaita-devel pango-devel\
sqlite-devel
```
### Install
#### Stable
2024-09-20 17:54:28 +03:00
``` bash
cargo install Yoda
```
2024-10-10 16:17:59 +03:00
#### Repository
2024-09-19 13:23:28 +03:00
``` bash
git clone https://github.com/YGGverse/Yoda.git
cd Yoda
2024-10-10 16:17:59 +03:00
cargo build
2024-09-19 13:23:28 +03:00
```
2024-09-23 14:26:24 +03:00
## Development
2024-10-12 04:31:06 +03:00
Quick start guide and maintenance protocol
2024-09-23 14:26:24 +03:00
2024-09-27 23:00:20 +03:00
### `browser`
2024-09-23 14:26:24 +03:00
2024-09-27 23:00:20 +03:00
#### Filesystem
2024-09-23 14:26:24 +03:00
2024-09-27 22:35:53 +03:00
* Use [modern path pattern](https://doc.rust-lang.org/edition-guide/rust-2018/path-changes.html#no-more-modrs)
* One module implements one GTK widget, it may include additional helper files in same location (like template, CSS or DB API)
2024-09-27 22:37:53 +03:00
* For children widget - create children module, located according to hierarchy
2024-09-27 23:00:20 +03:00
#### Codebase
2024-10-04 03:35:44 +03:00
* Every module should be as minimal as possible, separate:
2024-09-27 22:35:53 +03:00
* different tasks
* massive structures
* structures with implementation
2024-09-26 00:29:08 +03:00
* Every module must:
* encapsulate members - use objects, not static names (unlike native GTK actions API)
2024-10-04 03:27:46 +03:00
* implement only one public API `struct` per file (same as one file for one class)
2024-10-02 02:21:20 +03:00
* implementable `struct` is public, where it members - private
2024-09-27 20:49:44 +03:00
* contain main `struct` implementation:
2024-10-03 01:30:13 +03:00
* at least one constructor that must:
2024-11-08 05:21:08 +02:00
* have common for application names: `from`, `new` or/and `new_rc`, `new_mutex`, etc - on return object in container
2024-10-03 01:30:13 +03:00
* grant ownership for new `Self` object created
2024-10-04 03:27:46 +03:00
* public `activate` action if the new object can not be activated on construct
2024-10-04 03:34:01 +03:00
* public `link` getter for GTK `widget` (parental composition)
2024-09-28 01:29:05 +03:00
* Public API oriented to simple (`integer`, `boolean`), standard (`std::*`) or system-wide (`gio`, `glib`, etc) data types usage to reduce internal dependencies from app implementation
2024-10-05 15:59:12 +03:00
#### Database
2024-10-05 16:01:25 +03:00
* [SQLite](https://sqlite.org) used to operate with user profile: for example, restore and save widget sessions, manage auth, history, bookmarks, etc
* Database stored in system config directory (could be detected simply using browser tools menu)
2024-10-12 04:24:17 +03:00
* Structure of table should not be modified on `CARGO_PKG_VERSION_PATCH` change
2024-10-05 15:59:12 +03:00
* Every `browser` mod may have own table, where table must:
* contain same name as mod location, for example `app_browser_widget` for `src/app/browser/widget.rs`
* every table include autoincrement `id` column and parental primary ID if exist
* column name for parental ID must have absolute namespace prefix, for example `app_browser_id` column for `app_browser_widget` table. For example, if the table has few parental keys, column set could be `id`, `parent_one_id`, `parent_two_id`, `some_data`
2024-10-05 16:16:07 +03:00
* _todo_
2024-10-05 16:15:44 +03:00
* [ ] version control for auto-migrations
2024-10-06 00:43:35 +03:00
* [x] transactions support for update operations
2024-10-05 15:59:12 +03:00
2024-09-28 01:29:05 +03:00
#### GTK
2024-09-28 01:31:03 +03:00
* Operate with [action objects](https://docs.gtk.org/gio/class.SimpleAction.html) instead of names like `win.action`. This allows to follow encapsulation, by the our goal, module must know nothing about parent presets. For example, define some action in parent, then delegate object created as construction argument
2024-10-05 16:08:50 +03:00
* Started refactory on separate widgets implementation to separated mods, because widgets may contain own tables in database and require additional mods dependencies like ORM API _todo_
2024-09-26 00:29:08 +03:00
2024-09-23 14:26:24 +03:00
### Contribution
2024-10-08 07:42:10 +03:00
* Before commit, please make sure:
2024-09-23 14:26:24 +03:00
* new branch created for every new PR `git checkout -b 'contribution-name'`
* new code follows common [rustfmt](https://rust-lang.github.io/rustfmt/) style `cargo fmt --check`
2024-11-08 06:03:42 +02:00
* run `cargo clippy` for final optimization
2024-09-23 14:26:24 +03:00
2024-11-01 01:37:57 +02:00
#### Contributors
![wakatime](https://wakatime.com/badge/user/0b7fe6c1-b091-4c98-b930-75cfee17c7a5/project/018ebca8-4d22-4f9e-b557-186be6553d9a.svg) ![StandWithUkraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/badges/StandWithUkraine.svg)
2024-10-08 07:42:10 +03:00
### Releases
2024-10-08 07:54:07 +03:00
* Package version in repository should be increased immediately after stable release on [crates.io](https://crates.io/crates/yoda) and before apply new changes
* Currently, profile data stored in separated sub-directories, auto-created on every `CARGO_PKG_VERSION_MAJOR` or/and `CARGO_PKG_VERSION_MINOR` change
2024-10-20 12:50:39 +03:00
### See also
2024-11-05 18:22:23 +02:00
* [ggemtext](https://github.com/YGGverse/ggemtext) - Glib-oriented [Gemtext](https://geminiprotocol.net/docs/gemtext-specification.gmi) API
* [ggemini](https://github.com/YGGverse/ggemini) - Glib-oriented client for [Gemini protocol](https://geminiprotocol.net/docs/protocol-specification.gmi)