summaryrefslogtreecommitdiff
path: root/docs/guide
diff options
context:
space:
mode:
authorAylur <[email protected]>2024-11-05 21:23:38 +0100
committerGitHub <[email protected]>2024-11-05 21:23:38 +0100
commitca6a37c98a784bcb652ebe3737c906274c0ff1ab (patch)
tree62d4ab53ce3f47a6927d47b5b1faeae1ef6baed7 /docs/guide
parent8c6d2185a68e9f09d6780284d1b61fcfaefa655b (diff)
parent524030ae79f5cffafef3ef09036064070e814879 (diff)
Merge pull request #66 from Aylur/feat/greetd
feat: greetd ipc client
Diffstat (limited to 'docs/guide')
-rw-r--r--docs/guide/libraries/greet.md94
1 files changed, 94 insertions, 0 deletions
diff --git a/docs/guide/libraries/greet.md b/docs/guide/libraries/greet.md
new file mode 100644
index 0000000..f0cd012
--- /dev/null
+++ b/docs/guide/libraries/greet.md
@@ -0,0 +1,94 @@
+# Greet
+
+Library and CLI tool for sending requests to [greetd](https://sr.ht/~kennylevinsen/greetd/).
+
+## Installation
+
+1. install dependencies
+
+:::code-group
+
+```sh [<i class="devicon-archlinux-plain"></i> Arch]
+sudo pacman -Syu meson vala json-glib gobject-introspection
+```
+
+```sh [<i class="devicon-fedora-plain"></i> Fedora]
+sudo dnf install meson vala valadoc json-glib-devel gobject-introspection-devel
+```
+
+```sh [<i class="devicon-ubuntu-plain"></i> Ubuntu]
+sudo apt install meson valac libjson-glib-dev gobject-introspection
+```
+
+:::
+
+::: info
+Although `greetd` is not a direct build dependency,
+it should be self-explanatory that the daemon is required to be available at runtime.
+:::
+
+2. clone repo
+
+```sh
+git clone https://github.com/aylur/astal.git
+cd astal/lib/greet
+```
+
+3. install
+
+```sh
+meson setup --prefix /usr build
+meson install -C build
+```
+
+## Usage
+
+You can browse the [Greet reference](https://aylur.github.io/libastal/greet).
+
+### CLI
+
+```sh
+astal-greet --help
+```
+
+### Library
+
+:::code-group
+
+```js [<i class="devicon-javascript-plain"></i> JavaScript]
+import Greet from "gi://AstalGreet"
+
+Greet.login("username", "password", "compositor", (_, res) => {
+ try {
+ Greet.login_finish(res)
+ } catch (err) {
+ printerr(err)
+ }
+})
+```
+
+```py [<i class="devicon-python-plain"></i> Python]
+# Not yet documented
+
+```
+
+```lua [<i class="devicon-lua-plain"></i> Lua]
+local Greet = require("lgi").require("AstalGreet")
+
+Greet.login("username", "password", "compositor", function (_, res)
+ local err = Greet.login_finish(res)
+ if err ~= nil then
+ print(err)
+ end
+end)
+```
+
+```vala [<i class="devicon-vala-plain"></i> Vala]
+try {
+ yield AstalGreet.login("username", "password", "compositor");
+} catch (Error err) {
+ printerr(err.message);
+}
+```
+
+:::