aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2012-08-25 01:21:41 +0200
committerKim Alvefur <zash@zash.se>2012-08-25 01:21:41 +0200
commitccb65a89715175ff75f01e8e2b5508f4c56dbf23 (patch)
tree0f44f5daf715f695a2ad93035f9b3266fe7ad4fb
parent8bf181b4fc4b21d41df98b31c8b606a7232d26be (diff)
downloadprosody-ccb65a89715175ff75f01e8e2b5508f4c56dbf23.tar.gz
prosody-ccb65a89715175ff75f01e8e2b5508f4c56dbf23.zip
util.datamanager: Collect errors when deleting all stores of a user, but ignore "no such file"
-rw-r--r--util/datamanager.lua10
1 files changed, 6 insertions, 4 deletions
diff --git a/util/datamanager.lua b/util/datamanager.lua
index 9f7600ee..b745cd39 100644
--- a/util/datamanager.lua
+++ b/util/datamanager.lua
@@ -312,15 +312,17 @@ end
function purge(username, host)
local host_dir = format("%s/%s/", data_path, encode(host));
local deleted = 0;
+ local errs = {};
for file in lfs.dir(host_dir) do
if lfs.attributes(host_dir..file, "mode") == "directory" then
local store = decode(file);
- deleted = deleted + (os_remove(getpath(username, host, store)) and 1 or 0);
- deleted = deleted + (os_remove(getpath(username, host, store, "list")) and 1 or 0);
- -- We this will generate loads of "No such file or directory", but do we care?
+ local ok, err = os_remove(getpath(username, host, store));
+ if not ok and not err:lower():match("no such") then errs[#errs+1] = err; end
+ local ok, err = os_remove(getpath(username, host, store, "list"));
+ if not ok and not err:lower():match("no such") then errs[#errs+1] = err; end
end
end
- return deleted > 0, deleted;
+ return #errs == 0, t_concat(errs, ", ");
end
return _M;