X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=bacula%2Fscripts%2Fmtx-changer.in;h=a40e13769cf845cd3dd5be6a2601df9a9e74562f;hb=840f9cf38fa5839c9031ff6201f81287ed91aa5a;hp=67a7d5daafbe605b9bbf64654508477a28dbb875;hpb=e8085628fc65fbe7c5ec30a3d0a2888aed56f16f;p=bacula%2Fbacula diff --git a/bacula/scripts/mtx-changer.in b/bacula/scripts/mtx-changer.in index 67a7d5daaf..a40e13769c 100644 --- a/bacula/scripts/mtx-changer.in +++ b/bacula/scripts/mtx-changer.in @@ -46,40 +46,14 @@ # exit code, Bacula will assume the request failed. # -MTX=@MTX@ +# source our conf file +. @scriptdir@/mtx-changer.conf -# mt status output -# SunOS No Additional Sense -# FreeBSD Current Driver State: at rest. -# Linux ONLINE -# Note Debian has messed up their mt. When no tape is in the -# drive it waits 2 minutes. When a tape is in the drive, it -# prints user unfriendly output. -# - -OS=`uname` -case ${OS} in - SunOS) - ready="No Additional Sense" - ;; - FreeBSD) - ready="Current Driver State: at rest." - ;; - Linux) - if test -e /etc/debian_version ; then - ready="drive status" - else - ready="ONLINE" - fi - ;; -esac +MTX=@MTX@ -# -# log whats done -# -# to turn on logging, uncomment the following line -#touch @working_dir@/mtx.log -# +if test ${debug_log} -ne 0 ; then + touch @working_dir@/mtx.log +fi dbgfile="@working_dir@/mtx.log" debug() { if test -f $dbgfile; then @@ -170,10 +144,13 @@ debug "Parms: $ctl $cmd $slot $device $drive" case $cmd in unload) debug "Doing mtx -f $ctl unload $slot $drive" -# -# enable the following line if you need to eject the cartridge -# mt -f $device offline -# sleep 10 + + if test ${offline} -eq 1 ; then + mt -f $device offline + fi + if test ${offline_sleep} -ne 0 ; then + sleep ${offline_sleep} + fi ${MTX} -f $ctl unload $slot $drive ;; @@ -181,10 +158,9 @@ case $cmd in debug "Doing mtx -f $ctl load $slot $drive" ${MTX} -f $ctl load $slot $drive rtn=$? -# -# Increase the sleep time if you have a slow device -# or remove the sleep and add the following: -# sleep 15 + if test ${load_sleep} -ne 0 ; then + sleep ${load_sleep} + fi wait_for_drive $device exit $rtn ;; @@ -192,16 +168,16 @@ case $cmd in list) debug "Doing mtx -f $ctl -- to list volumes" make_temp_file -# Enable the following if you are using barcodes and need an inventory -# ${MTX} -f $ctl inventory + if test ${inventory} -ne 0 ; then + ${MTX} -f $ctl inventory + fi ${MTX} -f $ctl status >${TMPFILE} rtn=$? - cat ${TMPFILE} | grep " Storage Element [0-9]*:.*Full" | awk "{print \$3 \$4}" | sed "s/Full *\(:VolumeTag=\)*//" -# -# If you have a VXA PacketLoader and the above does not work, try -# turning it off and enabling the following line. -# cat ${TMPFILE} | grep " *Storage Element [0-9]*:.*Full" | sed "s/ Storage Element //" | sed "s/Full :VolumeTag=//" -# + if test ${vxa_packetloader} -ne 0 ; then + cat ${TMPFILE} | grep " *Storage Element [0-9]*:.*Full" | sed "s/ Storage Element //" | sed "s/Full :VolumeTag=//" + else + cat ${TMPFILE} | grep " Storage Element [0-9]*:.*Full" | awk "{print \$3 \$4}" | sed "s/Full *\(:VolumeTag=\)*//" + fi cat ${TMPFILE} | grep "^Data Transfer Element [0-9]*:Full (Storage Element [0-9]" | awk '{printf "%s:%s\n",$7,$10}' rm -f ${TMPFILE} >/dev/null 2>&1 exit $rtn