Merge pull request #460 from Unrud/patch-25

Run hook while storage is still locked
This commit is contained in:
Guillaume Ayoub 2016-08-05 17:47:38 +02:00 committed by GitHub
commit 7703008d8f

View File

@ -372,14 +372,14 @@ class Application:
"""Lock the collection with ``permission`` and execute hook.""" """Lock the collection with ``permission`` and execute hook."""
with self.Collection.acquire_lock(lock_mode) as value: with self.Collection.acquire_lock(lock_mode) as value:
yield value yield value
hook = self.configuration.get("storage", "hook") hook = self.configuration.get("storage", "hook")
if lock_mode == "w" and hook: if lock_mode == "w" and hook:
self.logger.debug("Running hook") self.logger.debug("Running hook")
folder = os.path.expanduser(self.configuration.get( folder = os.path.expanduser(self.configuration.get(
"storage", "filesystem_folder")) "storage", "filesystem_folder"))
subprocess.check_call( subprocess.check_call(
hook % {"user": shlex.quote(user or "Anonymous")}, hook % {"user": shlex.quote(user or "Anonymous")},
shell=True, cwd=folder) shell=True, cwd=folder)
def do_DELETE(self, environ, path, content, user): def do_DELETE(self, environ, path, content, user):
"""Manage DELETE request.""" """Manage DELETE request."""