Запуск сценария bash после gnome-keyring-daemon, но до gnome-encfs?

Мне нужно смонтировать sshfs после gnome-keyring-daemon становится доступным (то есть не в моем профиле. и, вероятно, после /etc/xdg/autostart/gnome-keyring-ssh.desktop завершен (однако у меня есть сомнения по этому вопросу, поскольку его разрешения -rw-r -r--)), но до gnome-encfs автозапуск (~/.config/autostart/gnome-encfs.desktop) Как мой encfs исходные папки sshfs монтирует.

Поэтому мне интересно, какой сценарий написать, где и как управлять зависимостями - т.е. готовность брелка deamon перед монтированием sshfs, а затем завершить монтирование перед запуском encfs,

Любая помощь оценена, так как мои поиски до сих пор были бесплодными.

Я на Ubuntu 10.04.

1 ответ

Решение

Не найдя лучшего решения, я решил изменить gnome-encfs, добавив опцию предварительной команды:

--- original gnome-encfs
+++ modified gnome-encfs
@@ -48,6 +48,7 @@
     econfig = None
     mpoint = None
     amount = None
+    precmd = None
# =============================================================================
# constants
@@ -125,6 +126,8 @@
                   help="Input for mount point edit")
     og.add_option("", "--amount", default=None,
                   help="Input for auto mount question")
+    og.add_option("", "--precmd", default=None,
+                  help="Input for pre-command question")
     og.add_option("", "--econfig", default=None,
                   help="Input for encfs config file question")
@@ -150,12 +153,12 @@
     opts.p2 = args and args.pop(0) or None

     if opts.add and not (opts.p1 and opts.p2):
-        op.error("add needs an EncFS path and a moint point")
+        op.error("add needs an EncFS path and a mount point")
         op.print_help()
         op.exit(1)

     if opts.remove and not opts.p1:
-        op.error("remove needs a moint point")
+        op.error("remove needs a mount point")
         op.print_help()
         op.exit(1)
@@ -164,6 +167,7 @@
     preset.epath = opts.epath
     preset.mpoint = opts.mpoint
     preset.amount = opts.amount
+    preset.precmd = opts.precmd
     preset.econfig = opts.econfig

     return opts
@@ -220,7 +224,7 @@    _items_cached = None  
-def _get_items(mpoint=None, epath=None, anypath=None, amount=None):
+def _get_items(mpoint=None, epath=None, anypath=None, amount=None, precmd=None):
     """Get all EncFS items or those matching given attributes."""

     global _items_cached
@@ -243,6 +247,8 @@
             continue
         if amount and item.attributes["auto-mount"] != amount:
             continue
+        if precmd and item.attributes["pre-command"] != precmd:
+            continue
         match.append(item)

     return match
@@ -292,10 +298,12 @@
         epath = item.attributes["encfs-path"]
         mpoint = item.attributes["mount-point"]
         amount = item.attributes["auto-mount"]
+        precmd = item.attributes["pre-command"]
         econfig = item.attributes.get("encfs-config", "-")
         print("* encfs path     : %s" % epath)
         print("  mount point    : %s" % mpoint)
         print("  mount at login : %s" % (amount == "y" and "yes" or "no"))
+        print("  pre command    : %s" % precmd)
         print("  encfs config   : %s" % econfig)

     return RC_OK
@@ -316,8 +324,9 @@
     secret = preset.password or getpass.getpass("EncFS password: ")
     amount = preset.amount or raw_input("Mount at login [Y/n]: ") or "y"
     amount = amount.strip()[0].lower() == "y" and "y" or "n"
+    precmd = preset.precmd or raw_input("Pre command: ") or None
     attr = {"encfs-path": epath, "mount-point": mpoint, "auto-mount": amount,
-        "encfs-config": econfig}
+        "pre-command": precmd, "encfs-config": econfig}
     attr.update(GENCFS_ATTR)
     name = "EncFS mount at %s" % mpoint
     gk.item_create_sync(KEYRING, ITYPE, name, attr, secret, False)
@@ -343,6 +352,7 @@
         epath = item.attributes["encfs-path"]
         mpoint = item.attributes["mount-point"]
         amount = item.attributes["auto-mount"]
+        precmd = item.attributes["pre-command"]
         econfig = item.attributes.get("encfs-config", "-")
         epath = preset.epath or raw_input("EncFS path [%s]: " % epath) or epath
         econfig = preset.econfig or raw_input("EncFS config file [%s] (`-`: default): " % econfig) or econfig
@@ -351,6 +361,7 @@
         hint = amount == "y" and "Y/n" or "y/N"
         amount = preset.amount or raw_input("Mount at login [%s]: " % hint) or amount
         amount = amount.strip()[0].lower() == "y" and "y" or "n"
+        precmd = preset.precmd or raw_input("Pre command: ") or None
         mpoint = _pathify(mpoint)
         epath = _pathify(epath)
@@ -368,6 +379,7 @@
         attributes["encfs-path"] = epath
         attributes["mount-point"] = mpoint
         attributes["auto-mount"] = amount
+        attributes["pre-command"] = precmd
         attributes["encfs-config"] = econfig
         gk.item_set_attributes_sync(KEYRING, item.item_id, attributes)
         info = gk.item_get_info_sync(KEYRING, item.item_id)
@@ -427,6 +440,18 @@
             msg += "mount point does not exist or is not a directory"
             rc |= RC_INVALID_PATH
         else:
+            if precmd != None:
+                # fire command and forget (do all the error handling in
+                # pre-command - no tie in here if it fails)
+                # My use case: mount sshfs before encfs, if the sshfs
+                # mount fails, then encfs will start on an empty
+                # directory.
+                cmd = precmd.split()
+       #print("pre command    : %s" % precmd)
+       #print("pre command    : %s" % cmd)
+                p = subprocess.Popen(cmd)
+                p.wait()
+                print("Pre command return code: %s" % p.returncode)
             cmd = ["encfs", "-o", "nonempty", "-S", epath, mpoint]
             p = subprocess.Popen(cmd, stdin=subprocess.PIPE,
                 env=_encfs_env(econfig))
Другие вопросы по тегам