encfs暗号化バックアップディスクをマウントするudevルールがあります。
ACTION=="add",KERNEL=="sd*1",ENV{ID_SERIAL}=="Seagate_GoFlex_Desk_NA0MEYKM-0:0" ,SYMLINK="ext_hd",RUN+="/root/bin/mount.encfs 'Large Backup Drive' /dev/%k"
mount.encfsの内容は次のとおりです。
#!/bin/bash
set -e
export XAUTHORITY=/home/me/.Xauthority
export DISPLAY=:0.0
NAME=$1
DEV=$2
ENCRYPTED_MOUNT_POINT=/media/ext_hd.encfs
UNENCRYPTED_MOUNT_POINT=/media/ext_hd
[ ! -e $ENCRYPTED_MOUNT_POINT ] && mkdir $ENCRYPTED_MOUNT_POINT
[ ! -e $UNENCRYPTED_MOUNT_POINT ] && mkdir $UNENCRYPTED_MOUNT_POINT
mount -t ext4 $DEV $ENCRYPTED_MOUNT_POINT
encfs -o allow_other --extpass="ssh-askpass $NAME" \
$ENCRYPTED_MOUNT_POINT $UNENCRYPTED_MOUNT_POINT
ディスクを挿入するとプロンプトが表示されますが、ls /media/ext_hdを試みるとクラシックFUSEが表示されます。
ls: cannot access '/media/ext_hd': Transport endpoint is not connected
手動でマウントを解除し、mount.encfsを手動で実行すると機能します。
mount の出力はどちらの場合も同じです。
encfs on /media/ext_hd type fuse.encfs (rw,nosuid,nodev,relatime,user_id=0,group_id=0,default_permissions,allow_other)
この問題の原因が何であるか、誰が間違っているのか、次のデバッグ手順が何であるのかわかりません。どんなアイデアがありますか?