# Auth Library and CLI tool for authentication using [pam](https://github.com/linux-pam/linux-pam). ## Installation 1. install dependencies :::code-group ```sh [ Arch] sudo pacman -Syu meson pam gobject-introspection ``` ```sh [ Fedora] sudo dnf install meson pam-devel gobject-introspection-devel ``` ```sh [ Ubuntu] # Not yet documented ``` ::: ::: warning On NixOS you have to add `astal-auth` to `security.pam`. ::: code-group ```nix [configuration.nix] { security.pam.services.astal-auth = {} } ``` ::: 2. clone repo ```sh git clone https://github.com/aylur/astal.git cd astal/lib/auth ``` 3. install ```sh meson setup build meson install -C build ``` :::tip Most distros recommend manual installs in `/usr/local`, which is what `meson` defaults to. If you want to install to `/usr` instead which most package managers do, set the `prefix` option: ```sh meson setup --prefix /usr build ``` ::: ## Usage You can browse the [Auth reference](https://aylur.github.io/libastal/auth). ### CLI ```sh astal-auth --password my-password ``` ### Library :::code-group ```js [ JavaScript] import Auth from "gi://AstalAuth"; import Gio from "gi://Gio"; Gio._promisify(Auth.Pam, "authenticate"); await Auth.Pam.authenticate("password") .then(_ => print("authentication sucessful")) .catch(logError); ``` ```py [ Python] # Not yet documented ``` ```lua [ Lua] -- Not yet documented ``` ```vala [ Vala] // Not yet documented ``` :::