3 # if this chart is called X.chart.sh, then all functions and global variables
6 sensors_sys_dir="/sys/devices"
8 sensors_source_update=1
10 # _update_every is a special variable - it holds the number of seconds
11 # between the calls of the _update() function
14 sensors_find_all_files() {
15 find $1 -maxdepth $sensors_sys_depth -name \*_input -o -name temp 2>/dev/null
18 sensors_find_all_dirs() {
19 sensors_find_all_files $1 | while read
25 # _check is called once, to find out if this chart should be enabled or not
29 # - 0 to enable the chart
30 # - 1 to disable the chart
32 [ ! -z "$( sensors_find_all_files $sensors_sys_dir )" ] && return 0
36 sensors_check_files() {
37 # we only need sensors that report a non-zero value
42 [ ! -f "$f" ] && continue
46 [ $v -ne 0 ] && echo "$f" && continue
48 echo >&2 "charts.d: sensors: $f gives zero values"
52 sensors_check_temp_type() {
53 # valid temp types are 1 to 6
54 # disabled sensors have the value 0
59 t=$( echo $f | sed "s|_input$|_type|g" )
60 [ "$f" = "$t" ] && echo "$f" && continue
61 [ ! -f "$t" ] && echo "$f" && continue
65 [ $v -ne 0 ] && echo "$f" && continue
67 echo >&2 "charts.d: sensors: $f is disabled"
71 # _create is called once, to create the charts
73 local path= dir= name= x= file= lfile= labelname= labelid= device= subsystem= id= type= mode= files= multiplier= divisor=
75 # we create a script with the source of the
76 # sensors_update() function
77 # - the highest speed we can achieve -
78 [ $sensors_source_update -eq 1 ] && echo >$TMP_DIR/temp.sh "sensors_update() {"
80 for path in $( sensors_find_all_dirs $sensors_sys_dir | sort -u )
82 dir=$( basename $path )
89 [ -h $path/device ] && device=$( readlink -f $path/device )
90 [ ! -z "$device" ] && device=$( basename $device )
91 [ -z "$device" ] && device="$dir"
93 [ -h $path/subsystem ] && subsystem=$( readlink -f $path/subsystem )
94 [ ! -z "$subsystem" ] && subsystem=$( basename $subsystem )
95 [ -z "$subsystem" ] && subsystem="$dir"
97 [ -f $path/name ] && name=$( cat $path/name )
98 [ -z "$name" ] && name="$dir"
100 [ -f $path/type ] && type=$( cat $path/type )
101 [ -z "$type" ] && type="$dir"
103 id="$( fixid "$device.$subsystem.$dir" )"
105 echo >&2 "charts.d: sensors: on path='$path', dir='$dir', device='$device', subsystem='$subsystem', id='$id', name='$name'"
107 for mode in temperature voltage fans power current energy humidity
116 files="$( ls $path/temp*_input 2>/dev/null; ls $path/temp 2>/dev/null )"
117 files="$( sensors_check_files $files )"
118 files="$( sensors_check_temp_type $files )"
119 [ -z "$files" ] && continue
120 echo "CHART sensors.temp_${id} '' '${name} Temperature' 'Celcius' '${device}' '' line 6000 $sensors_update_every"
121 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.temp_${id} \$1\""
126 files="$( ls $path/in*_input 2>/dev/null )"
127 files="$( sensors_check_files $files )"
128 [ -z "$files" ] && continue
129 echo "CHART sensors.volt_${id} '' '${name} Voltage' 'Volts' '${device}' '' line 6001 $sensors_update_every"
130 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.volt_${id} \$1\""
135 files="$( ls $path/curr*_input 2>/dev/null )"
136 files="$( sensors_check_files $files )"
137 [ -z "$files" ] && continue
138 echo "CHART sensors.curr_${id} '' '${name} Current' 'Ampere' '${device}' '' line 6002 $sensors_update_every"
139 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.curr_${id} \$1\""
144 files="$( ls $path/power*_input 2>/dev/null )"
145 files="$( sensors_check_files $files )"
146 [ -z "$files" ] && continue
147 echo "CHART sensors.power_${id} '' '${name} Power' 'Watt' '${device}' '' line 6003 $sensors_update_every"
148 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.power_${id} \$1\""
153 files="$( ls $path/fan*_input 2>/dev/null )"
154 files="$( sensors_check_files $files )"
155 [ -z "$files" ] && continue
156 echo "CHART sensors.fan_${id} '' '${name} Fans Speed' 'Rotations / Minute' '${device}' '' line 6004 $sensors_update_every"
157 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.fan_${id} \$1\""
161 files="$( ls $path/energy*_input 2>/dev/null )"
162 files="$( sensors_check_files $files )"
163 [ -z "$files" ] && continue
164 echo "CHART sensors.energy_${id} '' '${name} Energy' 'Joule' '${device}' '' areastack 6005 $sensors_update_every"
165 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.energy_${id} \$1\""
166 algorithm="incremental"
171 files="$( ls $path/humidity*_input 2>/dev/null )"
172 files="$( sensors_check_files $files )"
173 [ -z "$files" ] && continue
174 echo "CHART sensors.humidity_${id} '' '${name} Humidity' 'Percent' '${device}' '' line 6006 $sensors_update_every"
175 echo >>$TMP_DIR/temp.sh "echo \"BEGIN sensors.humidity_${id} \$1\""
187 fid="$( fixid "$file" )"
188 lfile="$( basename $file | sed "s|_input$|_label|g" )"
189 labelname="$( basename $file | sed "s|_input$||g" )"
191 if [ ! "$path/$lfile" = "$file" -a -f "$path/$lfile" ]
193 labelname="$( cat "$path/$lfile" )"
196 echo "DIMENSION $fid '$labelname' $algorithm $multiplier $divisor"
197 echo >>$TMP_DIR/temp.sh "printf \"SET $fid = \"; cat $file "
200 echo >>$TMP_DIR/temp.sh "echo END"
204 echo >>$TMP_DIR/temp.sh "}"
205 # cat >&2 $TMP_DIR/temp.sh
207 # ok, load the function sensors_update() we created
208 [ $sensors_source_update -eq 1 ] && . $TMP_DIR/temp.sh
213 # _update is called continiously, to collect the values
215 # the first argument to this function is the microseconds since last update
216 # pass this parameter to the BEGIN statement (see bellow).
218 # do all the work to collect / calculate the values
220 # remember: KEEP IT SIMPLE AND SHORT
222 [ $sensors_source_update -eq 0 ] && . $TMP_DIR/temp.sh $1