# HG changeset patch # User Matthew Wild # Date 1245676468 -3600 # Node ID 9b3b43b8963a9437388dfff6146b71613cb1eaf2 # Parent 03d8a930053f3019f8a5c9c26d4478c8b138e177 rostermanager: Fire event on roster load diff -r 03d8a930053f -r 9b3b43b8963a core/rostermanager.lua --- a/core/rostermanager.lua Mon Jun 22 02:58:28 2009 +0100 +++ b/core/rostermanager.lua Mon Jun 22 14:14:28 2009 +0100 @@ -82,19 +82,24 @@ function load_roster(username, host) log("debug", "load_roster: asked for: "..username.."@"..host); + local roster; if hosts[host] and hosts[host].sessions[username] then - local roster = hosts[host].sessions[username].roster; + roster = hosts[host].sessions[username].roster; if not roster then log("debug", "load_roster: loading for new user: "..username.."@"..host); roster = datamanager.load(username, host, "roster") or {}; if not roster[false] then roster[false] = { }; end hosts[host].sessions[username].roster = roster; + hosts[host].events.fire_event("roster-load", username, host, roster); end return roster; end + -- Attempt to load roster for non-loaded user log("debug", "load_roster: loading for offline user: "..username.."@"..host); - return datamanager.load(username, host, "roster") or {}; + roster = datamanager.load(username, host, "roster") or {}; + hosts[host].events.fire_event("roster-load", username, host, roster); + return roster; end function save_roster(username, host)