「Greetd」の版間の差分
(セクション追加し忘れ: "マウスカーソルが表示されない") |
(同期) |
||
244行目: | 244行目: | ||
[https://man.sr.ht/~kennylevinsen/greetd/#how-to-set-xdg_session_typewayland How to Set XDG_SESSION_TYPE=wayland] を参照。 |
[https://man.sr.ht/~kennylevinsen/greetd/#how-to-set-xdg_session_typewayland How to Set XDG_SESSION_TYPE=wayland] を参照。 |
||
+ | |||
+ | === Logind セッションタイプを設定する === |
||
+ | |||
+ | {{Note|これは GNOME を Wayland で正常に動作させるために必要です。}} |
||
+ | |||
+ | Logind セッションタイプは {{ic|XDG_SESSION_TYPE}} [[環境変数]]で設定されます。しかし、この環境変数は PAM セッションが開かれる'''前に'''設定しなければなりません。そのため、{{ic|~/.profile}} やラッパースクリプトを使ってこの環境変数を設定する方法ではうまく行きません (これらは両方とも PAM セッションが開かれた後に実行されます)。 |
||
+ | |||
+ | 正しい方法は greeter から環境変数を送ることです (これはセッションが開かれる前に設定されます)。なので、greeter がサポートしているのであれば、適切な {{ic|1=XDG_SESSION_TYPE=xxx}} を送るだけです。 |
||
+ | |||
+ | Greeter がこれをサポートしていない場合は、auth セクションで [[環境変数#pam_env を使う|pam_env]] を使っても同じことができます。欠点は、greetd によって開始されたセッションは全て同じセッションタイプに設定されてしまうことです。場合によっては、これは問題になり得ます。 |
||
+ | |||
+ | 以下は pam_env の方法で Wayland セッションを設定する例です: |
||
+ | |||
+ | {{hc|/etc/greetd/config.toml|2= |
||
+ | [general] |
||
+ | service = "greetd-spawn" |
||
+ | }} |
||
+ | |||
+ | {{hc|/etc/greetd/greetd-spawn.pam_env.conf|2= |
||
+ | XDG_SESSION_TYPE DEFAULT=wayland OVERRIDE=wayland |
||
+ | }} |
||
+ | |||
+ | {{hc|/etc/pam.d/greetd-spawn|2= |
||
+ | auth include greetd |
||
+ | auth required pam_env.so conffile=/etc/greetd/greetd-spawn.pam_env.conf |
||
+ | account include greetd |
||
+ | session include greetd |
||
+ | }} |
||
=== マウスカーソルが表示されない === |
=== マウスカーソルが表示されない === |
||
268行目: | 296行目: | ||
* [https://man.sr.ht/%7Ekennylevinsen/greetd/ greetd wiki] |
* [https://man.sr.ht/%7Ekennylevinsen/greetd/ greetd wiki] |
||
− | {{TranslationStatus|greetd|2024- |
+ | {{TranslationStatus|greetd|2024-07-23|812781}} |
2024年7月23日 (火) 16:24時点における最新版
関連記事
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。
- dlm — fbdev の greeter。
- ddlm — fbdev の greeter。
dlm
の強化/拡張バージョン。
- gtkgreet — GTK の greeter。
- ReGreet — GTK の greeter。様々なカスタムオプションが利用可能。Wayland 限定。
- wlgreet — Wayland の greeter。
- tuigreet — コンソール UI の greeter。
- qtgreet — Qt の greeter。
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 を起動するには、上の例の $SHELL
を sway
に置き換えてください。
gtkgreet
gtkgreet が動作するには、コンポジターが必要です。完全なエクスペリエンスを得るには、wlr-layer-shell-unstable
をサポートするコンポジターが必要ですが、他のものでも動作します。そのため、sway を使うことが推奨されますが、cage のようなものを使うことも可能です。cage と sway の両方の例が以下に示されています。
gtkgreet で起動できるログイン環境を指定するには、/etc/greetd/environments
にその一覧を記述してください。例:
sway bash
また、gtkgreet を呼び出す際に -c mycommand
パラメータを使うこともできます (mycommand はログイン成功時に実行したいプログラムに置き換えてください。例えば、gtkgreet -c bash
や gtkgreet -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 ベースのコンポジタ (wayfireAUR、sway など) が必要です。
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/environments
に start-sway
を配置してください。
How to Set XDG_SESSION_TYPE=wayland を参照。
Logind セッションタイプを設定する
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
マウスカーソルが表示されない
qtgreet
を wayfire
といったコンポジタで使用している場合、マウスカーソルを正しく機能させるには 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" ...