greetd

提供: ArchWiki
2024年7月23日 (火) 16:24時点におけるAshMyzk (トーク | 投稿記録)による版 (同期)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

関連記事

greetd は、コンソールベースであれグラフィカルであれ、ユーザが何を起動したいのかを仮定しない、軽量で柔軟なログインマネージャデーモンです。コンソールから起動できるスクリプトやプログラムはすべて greetd で起動できるので、Wayland コンポジタに特に適しています。greeter を起動して、他のディスプレイマネージャと同様にユーザセッションを開始することもできます。

インストール

greetd パッケージか greetd-gitAUR パッケージをインストールしてください。

デフォルトの設定ファイルは /etc/greetd/config.toml です。PAM 固有のオプションは、/etc/pam.d/greetd で設定します。

Greeter

Greetd には greetd-agreety という内蔵の greeter がありますが、これは最小限の実装です。他の利用可能な greeter を使用することを検討するべきでしょう:

  • greetd-agreety — デフォルト。agetty に似たテキストベースの greeter。
https://git.sr.ht/~kennylevinsen/greetd || greetd-agreety
  • dlm — fbdev の greeter。
https://git.sr.ht/~kennylevinsen/dlm || greetd-dlm-gitAUR
  • ddlm — fbdev の greeter。dlm の強化/拡張バージョン。
https://github.com/deathowl/ddlm || greetd-ddlm-gitAUR
  • gtkgreetGTK の greeter。
https://git.sr.ht/~kennylevinsen/gtkgreet || greetd-gtkgreet, greetd-gtkgreet-gitAUR
  • ReGreetGTK の greeter。様々なカスタムオプションが利用可能。Wayland 限定。
https://github.com/rharish101/ReGreet || greetd-regreet, greetd-regreet-gitAUR
https://git.sr.ht/~kennylevinsen/wlgreet || greetd-wlgreetAUR, greetd-wlgreet-gitAUR
  • tuigreet — コンソール UI の greeter。
https://github.com/apognu/tuigreet || greetd-tuigreet
  • qtgreetQt の greeter。
https://gitlab.com/marcusbritanicus/QtGreet || greetd-qtgreetAUR

Greetd を開始する

greetd.service有効化してください。これで、greetd がブート時に開始されます。

ディスプレイマネージャ#ディスプレイマネージャをロードする も参照。

Greeter の設定

greetd によって実行される greeter は、/etc/greetd/config.toml 内の default_session セクションで command オプションを使用して設定します。設定に変更が加えられていない場合は、同梱されている agreety greeter が使用されます。また、#agreety も参照してください。

デフォルトでは、greeter は greeter ユーザーとして実行されます。設定ファイル内の default_session セクションで user オプションを変更すれば、別のユーザとして実行できます。例 (another_user の部分は置き換えてください):

...
[default_session]
user = "another_user"
...

また、/etc/greetd ディレクトリの所有権も適切に変更してください。

agreety

これがデフォルトの greeter です。以下のように設定ファイルを変更すれば、agreety が起動されます:

...
[default_session]
command = "agreety --cmd $SHELL"
...

agreety は、ユーザのログイン時に任意のコマンドを実行することができます。例えば、Sway を起動するには、上の例の $SHELLsway に置き換えてください。

gtkgreet

gtkgreet が動作するには、コンポジターが必要です。完全なエクスペリエンスを得るには、wlr-layer-shell-unstable をサポートするコンポジターが必要ですが、他のものでも動作します。そのため、sway を使うことが推奨されますが、cage のようなものを使うことも可能です。cage と sway の両方の例が以下に示されています。

gtkgreet で起動できるログイン環境を指定するには、/etc/greetd/environments にその一覧を記述してください。例:

sway
bash

また、gtkgreet を呼び出す際に -c mycommand パラメータを使うこともできます (mycommand はログイン成功時に実行したいプログラムに置き換えてください。例えば、gtkgreet -c bashgtkgreet -c sway)。以下のコンポジタの例では、必要に応じてそのようにしてください。

cage を使う

cageインストールし、以下のように command オプションを設定してください:

...
[default_session]
command = "cage gtkgreet"
...

sway を使う

swayインストールしてください。Sway を gtkgreet のコンポジタとして使用する場合、ユーザがログインしたら終了しなければなりません。そのために、特定の設定ファイル (例えば /etc/greetd/sway-config) を以下の内容で作成する必要があります:

# `-l` は layer-shell モードを有効化します。
# `swaymsg exit` が gtkgreet の後に実行されることに注意してください。
exec "gtkgreet -l; swaymsg exit"

bindsym Mod4+shift+e exec swaynag \
-t warning \
-m 'What do you want to do?' \
-b 'Poweroff' 'systemctl poweroff' \
-b 'Reboot' 'systemctl reboot'

include /etc/sway/config.d/*

次に、上記の設定ファイルで Sway を開始するように greetd を設定する必要があります。command オプションを以下のように設定してください:

...
[default_session]
command = "sway --config /etc/greetd/sway-config"
...

ReGreet

gtkgreet と同じように、ReGreet もコンポジタが必要です。例えば、Cage と Sway は両方とも gtkgreet のときのように使用することができます (ただし、gtkgreet コマンドは regreet に置き換えてください)。Sway をコンポジタとして使用する場合の設定は以下のようになるでしょう:

# `swaymsg exit` は ReGreet の後に実行されることに注意してください。
exec "regreet; swaymsg exit"

bindsym Mod4+shift+e exec swaynag \
-t warning \
-m 'What do you want to do?' \
-b 'Poweroff' 'systemctl poweroff' \
-b 'Reboot' 'systemctl reboot'

include /etc/sway/config.d/*

ReGreet は /usr/share/xsession ディレクトリ (X11 セッション) と /usr/share/wayland-sessions ディレクトリ (Wayland セッション) から利用可能なセッションを認識します。なので、/etc/greetd/environments にセッションのリストを記述する必要はありません。

ReGreet は TOML ファイル /etc/greetd/regreet.toml で設定することができます。サンプルのファイルは /usr/share/doc/greetd-regreet/regreet.sample.toml にあり、このファイルには利用可能な全オプションが記述されています。このファイルを /etc/greetd/regreet.toml にコピーし、好きなように変更してください。必要ない行はコメントアウトしたり削除したりしてください。無効なオプションは全て無視されます。

wlgreet

wlgreet を開始するには、wlr-layer-shell-unstable をサポートするコンポジタが必要です。#sway を使う で説明されているように gtkgreet を Sway でセットアップするときと同じ手順を行ってください。ただし、/etc/greetd/sway-config ファイルは以下のようにしてください:

exec "wlgreet --command sway; swaymsg exit"

bindsym Mod4+shift+e exec swaynag \
-t warning \
-m 'What do you want to do?' \
-b 'Poweroff' 'systemctl poweroff' \
-b 'Reboot' 'systemctl reboot'
 
include /etc/sway/config.d/*

tuigreet

tuigreet は特別な設定を必要しないので、以下のように command オプションを設定するだけで十分です:

...
[default_session]
command = "tuigreet --cmd sway"
...

tuigreet --help を実行すればカスタマイズオプションが表示されます。

ddlm

ddlm は特別な設定を必要しないので、以下のように command オプションを設定するだけで十分です:

...
[default_session]
command = "ddlm --target sway"
...

qtgreet

qtgreet を使用するには、WLR ベースのコンポジタ (wayfireAURsway など) が必要です。

Wayfire を使う

wayfireAURインストールし、以下のように command オプションを設定してください:

...
[default_session]
command = "wayfire --config /etc/qtgreet/wayfire.ini"
...

ここで参照されている Wayfire の設定ファイルは qtgreet に同梱されています。

Hyprland を使う

以下のように command オプションを設定してください:

...
[default_session]
command = "Hyprland --config /etc/greetd/hyprland.conf"
...

そして、以下のように /etc/greetd/hyprland.conf を作成してください:

/etc/greetd/hyprland.conf
exec-once = qtgreet; hyprctl dispatch exit

ヒントとテクニック

自動ログインを有効にする

特定のユーザに自動的にログインするようにしたい場合は、/etc/greetd/config.toml 内に initial_session セクションを定義する必要があります:

...
[initial_session]
command = "sway"
user = "myuser"
...

command オプションには、任意の実行可能ファイルの名前を指定することができます。上記の例では、ブート時に Sway が myuser ユーザによって開始され、ユーザーがログアウトシた後に gtkgreet が起動されます。

greetd を使用せず、常に自動ログインを有効にしておきたい場合は、autologin を参照してください。

ローカルのプログラムを実行する

パスを ~/.profile に追加してください。さもないと、greetd によって呼び出されたデスクトップ環境がローカルのプログラムを実行できません。Greetd はユーザのホームディレクトリ内の .bashrc.zshrc にアクセスできないので、これらのファイルにパスを指定しても意味がありません。

~/.profile
export PATH="$HOME/.local/bin:$PATH"

環境変数を設定する

選択済みのセッションに応じて環境変数を設定する greeter を使用していない限り (例えば、TUI は、セッションファイルの場所に応じて XDG_SESSION_TYPE を設定します)、デフォルトでは greetd は XDG_SESSION_TYPE や XDG_CURRENT_DESKTOP といった環境変数を設定しません。環境変数を設定する方法としては、実際のコマンドを実行する前に環境変数を設定するラッパスクリプトを使用するというものがあります。例えば、sway を起動する場合は:

/usr/local/bin/start-sway
#!/bin/sh
export XDG_SESSION_TYPE=wayland
export XDG_SESSION_DESKTOP=sway
export XDG_CURRENT_DESKTOP=sway

# Wayland stuff
export QT_QPA_PLATFORM=wayland
export SDL_VIDEODRIVER=wayland
export _JAVA_AWT_WM_NONREPARENTING=1

exec sway "$@"

Greeter が実行するコマンドとしてこのラッパスクリプトを使用してください。例えば、gtkgreet の場合:

/etc/greetd/config.toml
...
[default_session]
command = "gtkgreet -c /usr/local/bin/start-sway"
...

あるいは、/etc/greetd/environmentsstart-sway を配置してください。

How to Set XDG_SESSION_TYPE=wayland を参照。

Logind セッションタイプを設定する

ノート: これは GNOME を Wayland で正常に動作させるために必要です。

Logind セッションタイプは XDG_SESSION_TYPE 環境変数で設定されます。しかし、この環境変数は PAM セッションが開かれる前に設定しなければなりません。そのため、~/.profile やラッパースクリプトを使ってこの環境変数を設定する方法ではうまく行きません (これらは両方とも PAM セッションが開かれた後に実行されます)。

正しい方法は greeter から環境変数を送ることです (これはセッションが開かれる前に設定されます)。なので、greeter がサポートしているのであれば、適切な XDG_SESSION_TYPE=xxx を送るだけです。

Greeter がこれをサポートしていない場合は、auth セクションで pam_env を使っても同じことができます。欠点は、greetd によって開始されたセッションは全て同じセッションタイプに設定されてしまうことです。場合によっては、これは問題になり得ます。

以下は pam_env の方法で Wayland セッションを設定する例です:

/etc/greetd/config.toml
[general]
service = "greetd-spawn"
/etc/greetd/greetd-spawn.pam_env.conf
XDG_SESSION_TYPE DEFAULT=wayland OVERRIDE=wayland
/etc/pam.d/greetd-spawn
auth       include      greetd
auth       required     pam_env.so conffile=/etc/greetd/greetd-spawn.pam_env.conf
account    include      greetd
session    include      greetd

マウスカーソルが表示されない

qtgreetwayfire といったコンポジタで使用している場合、マウスカーソルを正しく機能させるには WLR_NO_HARDWARE_CURSORS=1 などの環境変数を export しなければならない場合があります。解決方法としては、別の実行可能なスクリプトを作成し、/etc/greetd/config.toml からそのスクリプトを呼び出すというものがあります。

/usr/local/bin/greetd-startup.sh
#!/bin/sh
export WLR_NO_HARDWARE_CURSORS=1
exec wayfire --config /etc/qtgreet/wayfire.ini
/etc/greetd/config.toml
...
[default_session]
command = "/usr/local/bin/greetd-startup.sh"
...

参照

翻訳ステータス: このページは en:greetd の翻訳バージョンです。最後の翻訳日は 2024-07-23 です。もし英語版に 変更 があれば、翻訳の同期を手伝うことができます。