You are not logged in.
i hope that this would be in the right thread, but I've run into a problem. I'm currently trying to make it so that when i press the power-button a menu pops up with a few options for power/sleep/reboot
im using sway and wofi as my menu launcher. i currently was able to set up an app launcher with wofi , so i know that wofi is working properly. I download acpid in order to find the correct output/events from when my power-button is pressed. i modified the default bash script to hopefully get this working, but nothing happens. I'm not sure what the problem is, i think it has to do with the script, but i guess im posting this here in hopes maybe someone experienced something similar? when i run the handler script with the acpi output the menu does pop up but for some reason when i hit the poewr-button it doesn't execute?
I've also already changed the handlepowerbutton=ignore in systemd/logind.config.
has anyone had something similar happen to them ? if it is the script what resources can i utilize in order to make the script correct?
thank you for taking the time to read this!
Offline
And... where's this script? If you want help with it you're going to need to let us see it. Post it in code tags here or link to it on a file sharing site.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
And... where's this script? If you want help with it you're going to need to let us see it. Post it in code tags here or link to it on a file sharing site.
Sorry about that, here is the handler.Sh script
#!/bin/sh
case "$1" in
button/power)
case "$2" in
PBTN)
logger "Power button PBIN pressed"
/etc/acpi/powermenu.sh
;;
LNXPWRBN:00)
logger "Power button LNXPWRBN:00 pressed"
/etc/acpi/powermenu.sh
;;
*)
logger "ACPI action undefined: $2"
;;
esac
;;
adapter)
case "$2" in
AC|ACAD)
case "$4" in
00000000)
logger "AC unplugged"
;;
00000001)
logger "AC plugged"
;;
*)
logger "ACPI action undefined: $4"
;;
esac
;;
*)
logger "ACPI action undefined: $2"
;;
esac
;;
battery)
case "$2" in
BATO)
case "$4" in
00000000)
logger "Battery online"
;;
00000001)
logger "Battery offline"
;;
*)
logger "ACPI action undefined: $4"
;;
esac
;;
*)
logger "ACPI action undefined: $2"
;;
esac
;;
*)
logger "ACPI group/action undefined: $1 / $2"
;;
esac
# vim: set ts=4 sw=4 ft=sh et:
And here is the powermenu.Sh file:
#!/bin/bash
# Define the options
options="Shutdown\nReboot\nSleep"
# Get the choice using Wofi
choice=$(echo -e $options | wofi --dmenu --prompt="Power Options")
# Execute the choice
case $choice in
Shutdown)
systemctl poweroff
;;
Reboot)
systemctl reboot
;;
Sleep)
systemctl suspend
;;
*)
;;
esac
Offline
Are you sure "nothing" happens when you hit the power button? Add something to the very start of powermenu.sh that writes to a file to confirm the script is running, e.g.
date >> /tmp/powermenu.log
Note that I'd expect wofi to fail in this context as the acpid script doesn't run as your user or - more importantly - doesn't have the WAYLAND_DISPLAY environment variable. You could try the hackish approach of hardcoding the environment variable to wayland-0, and on a simple single user system this may work. Alternatively you could check for any running wayland sessions and connect to the first available to give the wofi prompt.
Last edited by Trilby (2024-06-29 20:17:05)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
Ya I think it is related to wofi. Do you have any suggestions for some alternatives ? It seems when I run journalctl -f I’m getting segmentation faults from wofi. I have the enviorment variables included in my bash file and the menu does pop up whenever I execute it through the command line
For example: /etc/acpi/handler.sh button/power PBTN
A window will pop up. So I think ut must be the way wofi is handling the acpi events ?
Offline
Mod note: not an installation issue, moving to Programming/Scripting.
Sakura:-
Mobo: MSI MAG X570S TORPEDO MAX // Processor: AMD Ryzen 9 5950X @4.9GHz // GFX: AMD Radeon RX 5700 XT // RAM: 32GB (4x 8GB) Corsair DDR4 (@ 3000MHz) // Storage: 1x 3TB HDD, 6x 1TB SSD, 2x 120GB SSD, 1x 275GB M2 SSD
Making lemonade from lemons since 2015.
Offline
Ya I think it is related to wofi.
Do you think or do you know? Did you run the test I suggested or not?
Do you have any suggestions for some alternatives?
Well ... yeah:
... doesn't have the WAYLAND_DISPLAY environment variable. You could try the hackish approach of hardcoding the environment variable to wayland-0, and on a simple single user system this may work. Alternatively you could check for any running wayland sessions and connect to the first available to give the wofi prompt.
I have the enviorment variables included in my bash file
Which "bash file"? If you mean your profile or bashrc that's a bad idea and that should be removed. Your compositor sets and exports the WAYLAND_DISPLAY variable.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
mistake
Last edited by fried (2024-07-01 01:32:04)
Offline
And when you're in your wayland session where you can successfully run the script manually, what's the output of "echo $WAYLAND_DISPLAY"?
Then given that you collect all that debugging information in /tmp/acpi_debug.log, you should post the content of that log.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
fried wrote:Ya I think it is related to wofi.
Do you think or do you know? Did you run the test I suggested or not?
fried wrote:Do you have any suggestions for some alternatives?
Well ... yeah:
Trilby wrote:... doesn't have the WAYLAND_DISPLAY environment variable. You could try the hackish approach of hardcoding the environment variable to wayland-0, and on a simple single user system this may work. Alternatively you could check for any running wayland sessions and connect to the first available to give the wofi prompt.
fried wrote:I have the enviorment variables included in my bash file
Which "bash file"? If you mean your profile or bashrc that's a bad idea and that should be removed. Your compositor sets and exports the WAYLAND_DISPLAY variable.
I’m sorry, I didn’t run your specific test because I’ve already done something similar. I’ve written several debug statements in the powermenu.Sh script. My apologies as I was on my phone and was having trouble with logging into arch on my PC. So I had to make the best with doing an obscure way of getting you the closest thing to my script. But yes I have the variables in there for XDG_RUNTIME_DIR , WAYLAND_DISPLAY, and SWAY SOCK.
It’s interesting because hitting the power button does do “something” when I’m using ACPI_listen . It shows three different outputs:button/power PBTN 00000080 00000000 K button /power PBTN 00000080 00000000 button /power INXPWRBN: 00 00000080 0000000€
This is my powermenu.Sh script:
#!/bin/bash # Debugging log echo "powermenu.sh executed" >> /tmp/acpi_debug.log export XDG_RUNTIME_DIR=/run/user/1000 export WAYLAND_DISPLAY=wayland-1 export SWAYSOCK=$(find /run/user/1000/ -maxdepth 1 -name 'sway-ipc.*.sock' 2>/dev/null | head -n 1) echo "XDG_RUNTIME_DIR: $XDG_RUNTIME_DIR" >> /tmp/acpi_debug.log echo "WAYLAND_DISPLAY: $WAYLAND_DISPLAY" >> /tmp/acpi_debug.log echo "SWAYSOCK: $SWAYSOCK" >> /tmp/acpi_debug.log # Debugging to test if wofi runs or can run /usr/bin/wofi --version >> /tmp/acpi_debug.log 2>&1 options=("Shutdown" "Reboot" "Sleep") op=$(printf "%s\n" "${options[@]}" | sudo -u fried /usr/bin/wofi --dmenu --prompt="select power option" --normal-window) echo "Selected option: '$op'" >> /tmp/acpi_debug.log case $op in Shutdown) systemctl poweroff ;; Reboot) systemctl reboot ;; Sleep) systemctl suspend ;; *) echo "Invalid option selected" >> /tmp/acpi_debug.log ;; esac
My handler.Sh script:
#!/bin/bash echo "Parameters: $@" >> /tmp/acpi_debug.log logger "parameters: $@" case "$1" in button/power) case "$2" in PBTN|LNXPWRBN:00) logger "power button LNXPWRBN:00/PBTN pressed" sudo -E /etc/acpi/powermenu.sh ;; *) logger "ACPI action undefined: $2" ;; esac ;; ac_adapter) case "$2" in AC|ACAD|ADP0) case "$4" in 00000000) logger 'AC unplugged' ;; 00000001) logger 'AC plugged' ;; esac ;; *) logger "ACPI action undefined: $2" ;; esac ;; *) logger "ACPI group/action undefined: $1 / $2" ;; esac
My debug statements basically shows that it’s making it to the powermenu.Sh file but something weird happens there where when I check my acpi_debug.log it shows this:
Parameters: button/power LNXPWRBN:00 00000080 0000006b powermenu.sh executed XDG_RUNTIME_DIR: /run/user/1000 WAYLAND_DISPLAY: /run/user/1000/wayland-1 SWAYSOCK: /run/user/1000/sway-ipc.1000.509.sock 3f4a8c8c18d1 tip Selected option: ' ' Invalid option selected
It shows that my variables are correct but it’s saying invalid option selected? So im confused because it seems that my script is being executed, even if I just manually execute
/etc/acpi/powermenu.sh
The powermenu does pop up. But when I hit the power button nothing happens.
Also when I use
journalctl -f
It says wofi gets a segmentation fault
So I’m just confused.
Also I apologize if I’m not using the right terminology for something’s, I’m still fairly new to Linux.
Hope this helps the understanding of what I’m trying to deal with
Thank you!
Offline
edit: I assume you meant to edit, not massively quote. Please fix that and also answer my other question.
edit 2: and please check that what you are posting is actually accurate this time: there's no way that log output is from the script you posted.
Last edited by Trilby (2024-06-30 22:39:56)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
mistake
Last edited by fried (2024-07-01 01:31:33)
Offline
You see that as condescending? I gave you the benefit of the doubt that it was a mistake. But you've now refused to provide requested information several times, provided false and misleading information multiple times, and now refuse to fix your dumpster fire post that makes the thread nearly unreadable. Yeah, I think you will need to figure it out on your own - this is not a way to get help from others.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
I honestly only saw your comment about the edit and didn’t see that you actually left a good reply so I apologize about that. That’s what I was referring to as being condescending, but clearly that was my bad not reading it in the right context. Also I gave you what I have as far as information I’m capable of giving you at the moment, which was me going through notes of logs on my iPhone so they weren’t the best.
I don’t know how to delete posts on here yet because I just made an account. Sorry I couldn’t explain myself better.
Offline
Okay, one more try: you can click "edit" on your post to fix it. On top of that you need to gather the appropriate information. Summarizing logs on your iPhone is harmful to the goal here - we need actual / exact information.
Specifically, we need to know the WAYLAND_DISPLAY value from within your wayland session. My suspicion from the start was that this would be "wayland-0" yet your script hardcodes "wayland-1". If this is incorrect, that would explain *all* the problems you are facing.
As for the log, your log sets WAYLAND_DISPLAY=wayland-1, but a couple lines later records WAYLAND_DISPLAY allegedly as /run/user/1000/wayland-1 which is not possible: that is a wayland socket not a WAYLAND_DISPLAY value. I don't know if this disconnect is from the script not being what you posted as your script, or your log not being what you posted as your log. So we need the *actual* script and log, not your iPhone interpretation of them. Take time to gather the correct information and then post it.
Last edited by Trilby (2024-07-01 00:29:49)
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
ok well here is everything that i have right now
starting with output from
acpi_listen
when the powerbutton is pushed:
button/power PBTN 00000080 00000000 K
button/power PBTN 00000080 00000000
button/power LNXPWRBN:00 00000080 00000014
when i use
echo $WAYLAND_DISPLAY
the output is:
wayland-1
and then the other environment variables :
$SWAYSOCK:
echo $SWAYSOCK
output:
/run/user/1000/sway-ipc.1000.516.sock
$XDG_RUNTIME_DIR:
echo $XDG_RUNTIME_DIR
output:
/run/user/1000
here is my powermenu.sh script:
#!/bin/bash
# debugging log
echo "powermenu.sh executed" >> /tmp/acpi_debug.log
export XDG_RUNTIME_DIR=/run/user/1000
export WAYLAND_DISPLAY=/run/user/1000/wayland-1
export SWAYSOCK=$(find /run/user/1000/ -maxdepth 1 -name 'sway-ipc.*.sock' 2>/dev/null | head -n 1)
echo "XDG_RUNTIME_DIR: $XDG_RUNTIME_DIR" >> /tmp/acpi_debug.log
echo "WAYLAND_DISPLAY: $WAYLAND_DISPLAY" >> /tmp/acpi_debug.log
echo "SWAYSOCK: $SWAYSOCK" >> /tmp/acpi_debug.log
# debugging to test if wofi runs or can run
wofi --version >> tmp/acpi_debug.log 2>&1
options=("Shutdown" "Reboot" "Sleep")
op=$(printf "%s\n" "${options[@]}" |/usr/local/bin/wofi --dmenu --prompt="select power option" --normal-window)
echo "Selected option: '$op'" >> /tmp/acpi_debug.log
case "$op" in
Shutdown)
systemctl poweroff
;;
Reboot)
systemctl reboot
;;
Suspend)
systemctl suspend
;;
*)
echo "Invalid option selected" >> /tmp/acpi_debug.log
;;
esac
and here is my handler.sh script that is supposed to deal with the ACPI events:
#!/bin/bash
# Default acpi script that takes an entry for all actions
export XDG_RUNTIME_DIR=/run/user/1000
export WAYLAND_DISPLAY=/run/user/1000/wayland-1
export SWAYSOCK=$(find /run/user/1000/ -maxdepth 1 -name 'sway-ipc.*.sock' 2>/dev/null | head -n 1)
echo "Parameters: $@" >> /tmp/acpi_debug.log
logger "parameters: $@"
case "$1" in
button/power)
case "$2" in
PBTN|LNXPWRBN:00)
logger "power button LNXPWRBN:00/PBTN pressed"
sudo -E -u fried /etc/acpi/powermenu.sh
;;
*)
logger "ACPI action undefined: $2"
;;
esac
;;
ac_adapter)
case "$2" in
AC|ACAD|ADP0)
case "$4" in
00000000)
logger 'AC unpluged'
;;
00000001)
logger 'AC pluged'
;;
esac
;;
*)
logger "ACPI action undefined: $2"
;;
esac
;;
battery)
case "$2" in
BAT0)
case "$4" in
00000000)
logger 'Battery online'
;;
00000001)
logger 'Battery offline'
;;
esac
;;
CPU0)
;;
*) logger "ACPI action undefined: $2" ;;
esac
;;
button/lid)
case "$3" in
close)
logger 'LID closed'
;;
open)
logger 'LID opened'
;;
*)
logger "ACPI action undefined: $3"
;;
esac
;;
*)
logger "ACPI group/action undefined: $1 / $2"
;;
esac
# vim:set ts=4 sw=4 ft=sh et:
here is my output from my acpi_debug.log:
Parameters:
powermenu.sh executed
XDG_RUNTIME_DIR: /run/user/1000
WAYLAND_DISPLAY: /run/user/1000/wayland-1
SWAYSOCK: /run/user/1000/sway-ipc.1000.516.sock
3f4a8c8c18d1 tip
Selected option: ''
Invalid option selected
here is my output when i use
journalctl -f
:
Jun 30 18:36:59 Fried kernel: wofi[8926]: segfault at 0 ip 0000766a758838ba sp 00007fff256ae9e8 error 4 in libc.so.6[766a757f2000+16c000] likely on CPU 0 (core 0, socket 0)
Jun 30 18:36:59 Fried kernel: Code: f3 0f 1e fa 66 0f ef c0 66 0f ef c9 66 0f ef d2 66 0f ef db 48 89 f8 48 89 f9 48 81 e1 ff 0f 00 00 48 81 f9 cf 0f 00 00 77 66 <f3> 0f 6f 20 66 0f 74 e0 66 0f d7 d4 85 d2 74 04 0f bc c2 c3 48 83
Jun 30 18:36:59 Fried systemd-coredump[8928]: Process 8926 (wofi) of user 0 terminated abnormally with signal 11/SEGV, processing...
Jun 30 18:36:59 Fried systemd[1]: Started Process Core Dump (PID 8928/UID 0).
Jun 30 18:36:59 Fried systemd-coredump[8929]: [?] Process 8926 (wofi) of user 0 dumped core.
Stack trace of thread 8926:
#0 0x0000766a758838ba n/a (libc.so.6 + 0xb58ba)
#1 0x000063954b8e4dcd utils_concat (wofi + 0xbdcd)
#2 0x000063954b8e2b20 main (wofi + 0x9b20)
#3 0x0000766a757f3c88 n/a (libc.so.6 + 0x25c88)
#4 0x0000766a757f3d4c __libc_start_main (libc.so.6 + 0x25d4c)
#5 0x000063954b8e2ee5 _start (wofi + 0x9ee5)
ELF object binary architecture: AMD x86-64
Last edited by fried (2024-07-01 02:06:38)
Offline
So there's the problem in your script:
export WAYLAND_DISPLAY=/run/user/1000/wayland-1
Again, that's the path to a wayland socket. The wayland display is just the name, e.g.:
export WAYLAND_DISPLAY=wayland-1
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
i changed it to that but its still the same problem where it will execute and a window will pop up when i run
/etc/acpi/powermenu.sh
but not when i hit the power button?
im not very sure why in my acpi_debug.log that it shows invalid selection, it makes me think that the powermenu.sh file is just poorly written from my end and not executing properly. there isn't much information in the documentation about it.
my event script:
anything.sh the default script
# Pass all events to our one handler script
event=.*
action=/etc/acpi/handler.sh
the powerbutton.sh script i attempted to make:
#!/bin/bash
event=button/power.*
action=/etc/acpi/powermenu.sh %e
Last edited by fried (2024-07-01 04:23:39)
Offline
Please post the new log after the change.
"UNIX is simple and coherent" - Dennis Ritchie; "GNU's Not Unix" - Richard Stallman
Offline
No worries friend, I ended up figuring it out. It was a permissions issue essentially. I appreciate your help though!
Offline