Upstart não está executando o script .sh

0

As informações na web referentes aos arquivos upstart , init e .conf são lixo. Muitos lugares diferentes mostram formas completamente diferentes de fazer as coisas.

De qualquer forma, eu tenho um arquivo de script /home/karl/.scripts/startup/sensei-raw-startup.sh (permissão de arquivo 775):

#!/bin/bash
# run as root

xinput list >> /var/log/trololol.log

echo trololol start >> /var/log/trololol.log

ids=$(xinput list | awk '/SteelSeries Sensei Raw Gaming Mouse .*pointer/ {print $8}' | sed 's/id=\(.*\)//')

echo trololol before ids >> /var/log/trololol.log
echo $ids >> /var/log/trololol.log
echo trololol after ids >> /var/log/trololol.log

if [ -z "$ids" ]; then
  exit 0;
fi

read -a ids_array <<< $ids

echo fixing id ${ids_array[0]}
xinput set-prop ${ids_array[0]} 'Device Accel Profile' -1
xinput set-prop ${ids_array[0]} 'Device Accel Constant Deceleration' 2.5
xinput set-prop ${ids_array[0]} 'Device Accel Adaptive Deceleration' 1
xinput set-prop ${ids_array[0]} 'Device Accel Velocity Scaling' 1

echo fixing id ${ids_array[1]}
xinput set-prop ${ids_array[1]} 'Device Accel Profile' -1
xinput set-prop ${ids_array[1]} 'Device Accel Constant Deceleration' 1.5
xinput set-prop ${ids_array[1]} 'Device Accel Adaptive Deceleration' 1
xinput set-prop ${ids_array[1]} 'Device Accel Velocity Scaling' 1

sensei-raw-ctl --show
sensei-raw-ctl --polling 500
sensei-raw-ctl --cpi-on 450
sensei-raw-ctl --cpi-off 5670

unset ids
unset ids_array

echo sensei-raw-startup.sh script 'date' >> /var/log/sensei-raw-startup.log

echo trololol end >> /var/log/trololol.log

Quando logado executando o script como sudo ele roda perfeitamente (log também é criado):

karl@karl-laptop:~/.scripts/startup$ sudo bash sensei-raw-startup.sh 
fixing id 12
fixing id 14
Backlight intensity: low
Backlight pulsation: slow
Speed in CPI (LED is off): 5670
Speed in CPI (LED is on): 450
Polling frequency: 500Hz
karl@karl-laptop:~/.scripts/startup$ 

Agora, desejo que isso seja executado automaticamente sempre que eu fizer login ou o computador for inicializado (isso deve afetar todos os usuários que fizerem login).

Eu criei o arquivo /etc/init/karl-startup.conf :

description "karls sexy startup script"
author "Karl Morrison"

start on started lightdm

pre-start script
        exec xinput 1> /var/log/karls.log 2>&1
end script

script
        exec bash /home/karl/.scripts/startup/sensei-raw-startup.sh
end script

Agora eu verifico o arquivo com:

karl@karl-laptop:~$ init-checkconf /etc/init/karl-startup.conf
File /etc/init/karl-startup.conf: syntax ok

Eu reinicio meu laptop, login e minhas configurações de mouse não foram alteradas, eu verifico os logs:

karl@karl-laptop:~$ sudo cat /var/log/trololol.log 
[sudo] password for karl: 
trololol start
trololol before ids

trololol after ids

Como você pode ver onde os IDs devem ser exibidos 12 14 , ele está em branco.

Recebi o seguinte erro:

karl@karl-laptop:~$ sudo cat /var/log/karls.log
Unable to connect to X server
    
por Karl Morrison 02.12.2015 / 02:08

1 resposta

0

O arquivo /etc/init/karl-startup.conf deve ler:

description "karls sexy startup script"

Como você diz em sua questão relacionada você quer iniciar o script no login , use ainda

start on desktop-session-start

se você quiser executá-lo na inicialização, use

start on startup

exec sudo -u $user /home/karl/.scripts/startup/sensei-raw-startup.sh
exec echo sensei-raw-startup.sh script 'date' >> /var/log/karl-startup.log start 

Mais detalhes sobre upstart aqui: link

    
por mcantsin 02.12.2015 / 02:37