Software /
code /
prosody
Comparison
core/rostermanager.lua @ 5024:d25e1b9332cc
Merge with Florob
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Sat, 28 Jul 2012 01:14:31 +0100 |
parent | 5021:85b2689dbcfe |
parent | 4993:5243b74a4cbb |
child | 5060:b0e36777f715 |
comparison
equal
deleted
inserted
replaced
5023:dcc8e789df36 | 5024:d25e1b9332cc |
---|---|
81 end | 81 end |
82 end | 82 end |
83 | 83 |
84 function load_roster(username, host) | 84 function load_roster(username, host) |
85 local jid = username.."@"..host; | 85 local jid = username.."@"..host; |
86 log("debug", "load_roster: asked for: "..jid); | 86 log("debug", "load_roster: asked for: %s", jid); |
87 local user = bare_sessions[jid]; | 87 local user = bare_sessions[jid]; |
88 local roster; | 88 local roster; |
89 if user then | 89 if user then |
90 roster = user.roster; | 90 roster = user.roster; |
91 if roster then return roster; end | 91 if roster then return roster; end |
92 log("debug", "load_roster: loading for new user: "..username.."@"..host); | 92 log("debug", "load_roster: loading for new user: %s@%s", username, host); |
93 else -- Attempt to load roster for non-loaded user | 93 else -- Attempt to load roster for non-loaded user |
94 log("debug", "load_roster: loading for offline user: "..username.."@"..host); | 94 log("debug", "load_roster: loading for offline user: %s@%s", username, host); |
95 end | 95 end |
96 local data, err = datamanager.load(username, host, "roster"); | 96 local data, err = datamanager.load(username, host, "roster"); |
97 roster = data or {}; | 97 roster = data or {}; |
98 if user then user.roster = roster; end | 98 if user then user.roster = roster; end |
99 if not roster[false] then roster[false] = { broken = err or nil }; end | 99 if not roster[false] then roster[false] = { broken = err or nil }; end |
100 if roster[jid] then | 100 if roster[jid] then |
101 roster[jid] = nil; | 101 roster[jid] = nil; |
102 log("warn", "roster for "..jid.." has a self-contact"); | 102 log("warn", "roster for %s has a self-contact", jid); |
103 end | 103 end |
104 if not err then | 104 if not err then |
105 hosts[host].events.fire_event("roster-load", username, host, roster); | 105 hosts[host].events.fire_event("roster-load", username, host, roster); |
106 end | 106 end |
107 return roster, err; | 107 return roster, err; |
108 end | 108 end |
109 | 109 |
110 function save_roster(username, host, roster) | 110 function save_roster(username, host, roster) |
111 log("debug", "save_roster: saving roster for "..username.."@"..host); | 111 log("debug", "save_roster: saving roster for %s@%s", username, host); |
112 if not roster then | 112 if not roster then |
113 roster = hosts[host] and hosts[host].sessions[username] and hosts[host].sessions[username].roster; | 113 roster = hosts[host] and hosts[host].sessions[username] and hosts[host].sessions[username].roster; |
114 --if not roster then | 114 --if not roster then |
115 -- --roster = load_roster(username, host); | 115 -- --roster = load_roster(username, host); |
116 -- return true; -- roster unchanged, no reason to save | 116 -- return true; -- roster unchanged, no reason to save |
236 if not item then | 236 if not item then |
237 item = {subscription = "none", groups = {}}; | 237 item = {subscription = "none", groups = {}}; |
238 roster[jid] = item; | 238 roster[jid] = item; |
239 end | 239 end |
240 item.ask = "subscribe"; | 240 item.ask = "subscribe"; |
241 log("debug", "set_contact_pending_out: saving roster; set "..username.."@"..host..".roster["..jid.."].ask=subscribe"); | 241 log("debug", "set_contact_pending_out: saving roster; set %s@%s.roster[%q].ask=subscribe", username, host, jid); |
242 return save_roster(username, host, roster); | 242 return save_roster(username, host, roster); |
243 end | 243 end |
244 function unsubscribe(username, host, jid) | 244 function unsubscribe(username, host, jid) |
245 local roster = load_roster(username, host); | 245 local roster = load_roster(username, host); |
246 local item = roster[jid]; | 246 local item = roster[jid]; |