From c5109408c02db3ca14a9a5382373066299c39d25 Mon Sep 17 00:00:00 2001 From: Isaac Aymerich Date: Mon, 3 Oct 2022 12:24:58 +0200 Subject: [PATCH] rc: handle external unmount when mounting Before this change, if the a mount was created via the rc but unmounted externally with `fusermount -u` say, rclone would still believe the mount was active when it wasn't. --- cmd/mountlib/rc.go | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/cmd/mountlib/rc.go b/cmd/mountlib/rc.go index 7a89787fe..b675abda9 100644 --- a/cmd/mountlib/rc.go +++ b/cmd/mountlib/rc.go @@ -122,7 +122,15 @@ func mountRc(ctx context.Context, in rc.Params) (out rc.Params, err error) { log.Printf("mount FAILED: %v", err) return nil, err } - + go func() { + if err = mnt.Wait(); err != nil { + log.Printf("unmount FAILED: %v", err) + return + } + mountMu.Lock() + defer mountMu.Unlock() + delete(liveMounts, mountPoint) + }() // Add mount to list if mount point was successfully created liveMounts[mountPoint] = mnt