Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Needs sudo before each command #241

Open
vdegenne opened this issue May 13, 2024 · 6 comments
Open

Needs sudo before each command #241

vdegenne opened this issue May 13, 2024 · 6 comments

Comments

@vdegenne
Copy link

I enabled the service:

systemctl enable ydotool

But when I reboot, and try running ydotool ... I get the following:

failed to connect socket `/run/user/1000/.ydotool_socket': Connection refused
Please check if ydotoold is running.

The only way to get rid of this issue is to use sudo before every command, but now I can't use ydotool in scripts because the shell interupts the program asking for the password (which makes sense).

Versions:

  • Fedora release 39 (Thirty Nine)
  • Environment: wayland (wayfire)
  • ydotool 1.0.4
@cyber-sushi
Copy link

If you launch ydotoold as a system service, you need to specify the directory and owner of its socket so that the ydotool executable can connect to it

Launch the daemon with the following arguments: --socket-path="<your_home>/.ydotool_socket" --socket-own="<your_user_id>:<your_group_id>"

@g-h-97
Copy link

g-h-97 commented May 30, 2024

@cyber-sushi same issue here as well, the problem is that ydotool unlike ydotoold does not support socket path it's hard-coded to /run/user/.ydotool_socket so I had to set the path to that while starting the daemon.

@Paiusco
Copy link
Contributor

Paiusco commented May 31, 2024

@g-h-97 ydotool does support you defining the socket path, it actually queries for an env var named YDOTOOL_SOCKET. It only goes for the "hardcoded" one if you don't define the envvar

@vdegenne I'd like to ask you to check who is the owner of the socket?
Please post the output of: ls -l <socket_path>, so I can try to help you out.

I'm considering that you don't have access to the socket, as it's by default owned by root... so you can change that, changing the ownership of the ydotoold socket creation. Using the --socket-own= parameter when starting the daemon (you can change this on the .service file)

I think this is issue is repeating itself too much, we should make in a way that ydotoold runs as root, opens the socket already considering the user ownership somehow.... maybe making it #230 can improve that, but I'm not completely sure, it has to be a better way

@g-h-97
Copy link

g-h-97 commented Jun 4, 2024

@Paiusco , thanks for the heads-up. Still there is the issue of the service getting added as a "user" instead of a "system" service,

@Paiusco
Copy link
Contributor

Paiusco commented Jun 6, 2024

@g-h-97 not necessarily (even tho for now that forces you to recompile it), this was addressed at #237.

So you can make the service as a system with a CMake option, or if you don't want to recompile you can just move the file to the system location and systemd will consider it a system service instead

@g-h-97
Copy link

g-h-97 commented Nov 8, 2024

Thanks for the response @Paiusco. I wrote this simple guide on how to get ydotool running on a Systemd based distro. hope people will find it helpful.

First copy the user service and edit it (or edit directly using sudo or doas)

cp /usr/lib/systemd/user/ydotool.service ~
vim ~/ydotool.service

Add the argument --socket-own=UID:GID to the line ExecStart=, where UID and GID are the user ID and group ID you want to run ydotool as

[Unit]
Description=Starts ydotoold service

[Service]
Type=simple
Restart=always
ExecStart=/usr/bin/ydotoold --socket-own=1000:1000
ExecReload=/usr/bin/kill -HUP $MAINPID
KillMode=process
TimeoutSec=180

[Install]
WantedBy=default.target

Copy the new service unit to /usr/lib/systemd/system/ directory

cp ~/ydotool.service /user/lib/systemd/system/

Export the following environment variable in you .zshenv

export YDOTOOL_SOCKET=/tmp/.ydotool_socket

Start and enable the service and check it's running

doas systemctl enable --now ydotool.service
systemctl status ydotool.service

Test. This should type "test" on the current terminal window

ydotool type "test"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants