# 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
```
:::