From 91aea551987526a15ab1b9146738c5b3e9ffe21b Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Sat, 28 Jul 2012 21:30:24 +0200 Subject: storagemanager: Split out driver choosing from the open() method --- core/storagemanager.lua | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'core') diff --git a/core/storagemanager.lua b/core/storagemanager.lua index 71e79271..1a5f7d47 100644 --- a/core/storagemanager.lua +++ b/core/storagemanager.lua @@ -58,7 +58,7 @@ function load_driver(host, driver_name) return stores_available:get(host, driver_name); end -function open(host, store, typ) +function get_driver(host, store) local storage = config.get(host, "core", "storage"); local driver_name; local option_type = type(storage); @@ -77,7 +77,11 @@ function open(host, store, typ) driver_name = "null"; driver = null_storage_driver; end + return driver, driver_name; + end +function open(host, store, typ) + local driver, driver_name = get_driver(host, store); local ret, err = driver:open(store, typ); if not ret then if err == "unsupported-store" then -- cgit v1.2.3 From ae1c972cdd64e30c8a5daa5cca9a78bb19a6ba67 Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Sat, 28 Jul 2012 21:30:54 +0200 Subject: storagemanager: Add method for listing stores --- core/storagemanager.lua | 3 +++ 1 file changed, 3 insertions(+) (limited to 'core') diff --git a/core/storagemanager.lua b/core/storagemanager.lua index 1a5f7d47..4ae79213 100644 --- a/core/storagemanager.lua +++ b/core/storagemanager.lua @@ -100,5 +100,8 @@ end function datamanager.store(username, host, datastore, data) return open(host, datastore):set(username, data); end +function datamanager.list_stores(username, host) + return get_driver(host):list_stores(username, host); +end return _M; -- cgit v1.2.3 From c8d3eca7486cc4e3f707956490dbe4f7fb15eb38 Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Sat, 28 Jul 2012 21:38:22 +0200 Subject: storagemanager: Add method for removing all data belonging to a user --- core/storagemanager.lua | 3 +++ 1 file changed, 3 insertions(+) (limited to 'core') diff --git a/core/storagemanager.lua b/core/storagemanager.lua index 4ae79213..3379cc0c 100644 --- a/core/storagemanager.lua +++ b/core/storagemanager.lua @@ -103,5 +103,8 @@ end function datamanager.list_stores(username, host) return get_driver(host):list_stores(username, host); end +function datamanager.purge(username, host) + return get_driver(host):purge(username, host); +end return _M; -- cgit v1.2.3 From a5ad1b5b1739bd8c4393918e73d07ab5854f14b1 Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Sat, 28 Jul 2012 21:55:05 +0200 Subject: usermanager: Add method for deleting a user --- core/usermanager.lua | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'core') diff --git a/core/usermanager.lua b/core/usermanager.lua index 3aba5786..efc15b7c 100644 --- a/core/usermanager.lua +++ b/core/usermanager.lua @@ -10,11 +10,13 @@ local modulemanager = require "core.modulemanager"; local log = require "util.logger".init("usermanager"); local type = type; local ipairs = ipairs; +local pairs = pairs; local jid_bare = require "util.jid".bare; local jid_prep = require "util.jid".prep; local config = require "core.configmanager"; local hosts = hosts; local sasl_new = require "util.sasl".new; +local storagemanager = require "core.storagemanager"; local prosody = _G.prosody; @@ -88,7 +90,15 @@ function create_user(username, password, host) end function delete_user(username, host) - return hosts[host].users.delete_user(username); + local user = hosts[host].sessions[username]; + if user and user.sessions then + for jid, session in pairs(user.sessions) do + session:close{ condition = "not-authorized", text = "Account deleted" }; + end + end + local ok, err = hosts[host].users.delete_user(username); + if not ok then return nil, err; end + return storagemanager.get_driver(host):purge(username); end function get_sasl_handler(host, session) -- cgit v1.2.3