Событие Acpid отклонено SELinux. Как можно безопасно разрешить событие, не создавая дыр в безопасности?

Событие Acpid отклонено SELinux. Как можно безопасно разрешить событие, не создавая дыр в безопасности?

Я установил Fedora (3.17.2-200.fc20.x86_64) на свой новый ноутбук (Lenovo Yoga Pad) и хотел добавить этот скрипт для срабатывания при переворачивании экрана. Скрипт срабатывал, когда событие находилось в /etc/acpi/actionsroot и принадлежало ему.

Проблема: Когда я перевернул экран, ничего не произошло, кроме различных предупреждений SELinux (вроде отказано в доступе, что-то про ioctl и read и т. д., что я не могу вспомнить). В любом случае, он сказал мне запустить grep tablet_mode.ori /var/log/audit/audit.log | audit2allow -M mypolи semodule -i mypol.ppисправить это, я так и сделал, но после перезагрузки ничего не произошло, когда я перевернул экран. Теперь я удалил файлы mypol в своем домашнем каталоге, потому что думал, что смогу снова посмотреть на вывод SELinux.

Я застрял и боюсь открыть дыры в безопасности моего SELinux, какое правильное решение для этого? Самое смешное, что когда я перезапускаю acpid с sudo killall acpid && sudo acpidсобытием, оно срабатывает и работает, единственное, что не работает в этом случае, это команда gsettings, она не показывает никаких ошибок, но и не меняет настройки моего пользователя (toor).

Это скрипт, который запускается событием:

#!/bin/bash

su toor -c "/home/toor/backup/scripts/toggle_keyboard.sh"
touchpad=$(xinput list-props "SynPS/2 Synaptics TouchPad" | grep "Device Enabled" | awk -F ":" '{print $2}')
if [ $touchpad -eq 1 ]; then
    /home/toor/backup/scripts/rotate.sh inverted
    xinput --set-prop "SynPS/2 Synaptics TouchPad" "Device Enabled" 0
else
    /home/toor/backup/scripts/rotate.sh normal
    xinput --set-prop "SynPS/2 Synaptics TouchPad" "Device Enabled" 1
fi

Это rotate.sh:

#!/bin/bash

current_orientation(){
    xrandr|grep " connected" |awk '{print $4}'
}
rotate_left(){
    xrandr -o left
    xsetwacom set "Wacom ISDv4 EC Pen stylus" rotate ccw
        xsetwacom set "Wacom ISDv4 EC Pen eraser" rotate ccw
    xinput set-prop "ELAN Touchscreen" "Coordinate Transformation Matrix" 0 -1 1 1 0 0 0 0 1
}
rotate_right(){
    xrandr -o right
    xsetwacom set "Wacom ISDv4 EC Pen stylus" rotate cw
        xsetwacom set "Wacom ISDv4 EC Pen eraser" rotate cw
    xinput set-prop "ELAN Touchscreen" "Coordinate Transformation Matrix" 0 1 0 -1 0 1 0 0 1
}
rotate_inverted(){
    xrandr -o inverted
    xsetwacom set "Wacom ISDv4 EC Pen stylus" rotate half
        xsetwacom set "Wacom ISDv4 EC Pen eraser" rotate half
    xinput set-prop "ELAN Touchscreen" "Coordinate Transformation Matrix" -1 0 1 0 -1 1 0 0 1
}
rotate_normal(){
    xrandr -o normal
    xsetwacom set "Wacom ISDv4 EC Pen stylus" rotate none
        xsetwacom set "Wacom ISDv4 EC Pen eraser" rotate none
    xinput set-prop "ELAN Touchscreen" "Coordinate Transformation Matrix" 1 0 0 0 1 0 0 0 1
}

orientation=$(current_orientation)

# if the orientation argument was given to this script, sets orientation variable
# according to the way we want to rotate in next loop.
if [ -n "$1" ]; then
    if [ "$1" == "normal" ]; then
        orientation="right"
    fi
    if [ "$1" == "left" ]; then
        orientation="(normal"
    fi
    if [ "$1" == "right" ]; then
        orientation="inverted"
    fi
    if [ "$1" == "inverted" ]; then
        orientation="left"
    fi
fi

# turns 90° counter-clockwise
case $orientation in
    "(normal" )
        rotate_left
        ;;
    "inverted" )
        rotate_right
        ;;
    "right" )
        rotate_normal
        ;;
    "left" )
        rotate_inverted
        ;;
    * )
        echo "it fucked up"
        exit 1
        ;;
esac

exit 0

и это будет toggle_keyboard.sh

#!/bin/bash
# toggle onboard keyboard

obk=$(gsettings get org.gnome.desktop.a11y.applications screen-keyboard-enabled)

if [ $obk == 'false' ]; then
        gsettings set org.gnome.desktop.a11y.applications screen-keyboard-enabled true
else
        gsettings set org.gnome.desktop.a11y.applications screen-keyboard-enabled false
fi

Надеюсь, вы сможете мне помочь с этим, я буду признателен за любую помощь.

Связанный контент