2012-10-10 10 views
7

Ho uno script che viene eseguito ogni volta che un dispositivo USB del fornitore 1004 è collegato. La regola udev che sto usando funziona e sembra così.Passa ATTR {idVendor} come argomento nello script udev

SUBSYSTEM=="usb", ATTR{idVendor}=="1004", RUN+="/var/www/beta/trigger.php" 

Ora vorrei eseguire questo script ogni volta che UNO dispositivo USB è collegato e passare l'ID fornitore come parametro. (Così lo script può decidere se deve essere eseguito o meno.)

Aggiunta di un parametro che può essere letta nello script ha lavorato finora:

SUBSYSTEM=="usb", RUN+="/var/www/beta/trigger.php myparam" 

qualcuno può dirmi come sostituire "myparam" con il valore di ATTR {idVendor}? Ho provato tutti i tipi di combinazioni, ma non ho mai ottenuto il risultato previsto ...

Grazie mille!

+0

si prega di modificare la tua domanda include alcuni "tutti i tipi di combinazioni" Difficile dire come stai in avvicinamento e quali strumenti hai provato a utilizzare. In bocca al lupo. – shellter

risposta

7

udev imposta per voi diverse variabili ambientali che è possibile utilizzare, tra gli altri ID_VENDOR. Prova che piccolo script:

#!/bin/bash 

echo "Called by udev" >> /tmp/testenv 
env >> /tmp/testenv 
echo "Vendor id is $ID_VENDOR" >> /tmp/testenv 

metterlo in una regola, e vedrete quanto le cose siano impostato per voi.

+1

Grazie mille! In PHP ho potuto accedere a queste variabili ambientali tramite $ _SERVER, quindi ho usato per es. '$ _SERVER ['ID_VENDOR_ID']' per l'ID del venditore. – joshtucker

+0

Provo questa variabile ma niente file stampato! –

17

Solo per aggiungere a questa risposta, udev consente anche di passare argomenti a RUN e PROGRAM.

Dalla pagina udev man:

The NAME, SYMLINK, PROGRAM, OWNER, GROUP, MODE and RUN fields support simple 
    printf-like string substitutions. The RUN format chars gets applied after 
    all rules have been processed, right before the program is executed. It 
    allows the use of device properties set by earlier matching rules. For all 
    other fields, substitutions are applied while the individual rule is being 
    processed. 

Ad esempio, si potrebbe avere una regola come questa:

# Passes major, minor and serial number as parameters to script. 
ACTION=="add", SUBSYSTEM=="usb", RUN+="/tmp/test.sh %M %m $attr{serial}" 

Le sostituzioni disponibili sono:

$kernel, %k 
     The kernel name for this device. 

    $number, %n 
     The kernel number for this device. For example, ´sda3´ has kernel number 
     of ´3´ 

    $devpath, %p 
     The devpath of the device. 

    $id, %b 
     The name of the device matched while searching the devpath upwards for 
     SUBSYSTEMS, KERNELS, DRIVERS and ATTRS. 

    $driver 
     The driver name of the device matched while searching the devpath 
     upwards for SUBSYSTEMS, KERNELS, DRIVERS and ATTRS. 

    $attr{file}, %s{file} 
     The value of a sysfs attribute found at the device, where all keys of 
     the rule have matched. If the matching device does not have such an 
     attribute, follow the chain of parent devices and use the value of the 
     first attribute that matches. If the attribute is a symlink, the last 
     element of the symlink target is returned as the value. 

    $env{key}, %E{key} 
     A device property value. 

    $major, %M 
     The kernel major number for the device. 

    $minor, %m 
     The kernel minor number for the device. 

    $result, %c 
     The string returned by the external program requested with PROGRAM. A 
     single part of the string, separated by a space character may be 
     selected by specifying the part number as an attribute: %c{N}. If 
     the number is followed by the ´+´ char this part plus all remaining 
     parts of the result string are substituted: %c{N+} 

    $parent, %P 
     The node name of the parent device. 

    $name 
     The current name of the device node. If not changed by a rule, it 
     is the name of the kernel device. 

    $links 
     The current list of symlinks, separated by a space character. The 
     value is only set if an earlier rule assigned a value, or during a 
     remove events. 

    $root, %r 
     The udev_root value. 

    $sys, %S 
     The sysfs mount point. 

    $tempnode, %N 
     The name of a created temporary device node to provide access to the 
     device from a external program before the real node is created. 

    %% 
     The ´%´ character itself. 

    $$ 
     The ´$´ character itself.