Commit 12441e34 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Implemented UserEventListener interface to delete user data when user is...

Implemented UserEventListener interface to delete user data when user is deleted from system. JM-510

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@3331 b35dd754-fafc-0310-a699-88a17e54d16e
parent e85a544a
...@@ -16,6 +16,9 @@ import org.dom4j.io.SAXReader; ...@@ -16,6 +16,9 @@ import org.dom4j.io.SAXReader;
import org.jivesoftware.database.DbConnectionManager; import org.jivesoftware.database.DbConnectionManager;
import org.jivesoftware.database.SequenceManager; import org.jivesoftware.database.SequenceManager;
import org.jivesoftware.wildfire.container.BasicModule; import org.jivesoftware.wildfire.container.BasicModule;
import org.jivesoftware.wildfire.event.UserEventListener;
import org.jivesoftware.wildfire.event.UserEventDispatcher;
import org.jivesoftware.wildfire.user.User;
import org.jivesoftware.util.*; import org.jivesoftware.util.*;
import org.xmpp.packet.Message; import org.xmpp.packet.Message;
...@@ -36,7 +39,7 @@ import java.util.concurrent.LinkedBlockingQueue; ...@@ -36,7 +39,7 @@ import java.util.concurrent.LinkedBlockingQueue;
* *
* @author Iain Shigeoka * @author Iain Shigeoka
*/ */
public class OfflineMessageStore extends BasicModule { public class OfflineMessageStore extends BasicModule implements UserEventListener {
private static final String INSERT_OFFLINE = private static final String INSERT_OFFLINE =
"INSERT INTO jiveOffline (username, messageID, creationDate, messageSize, message) " + "INSERT INTO jiveOffline (username, messageID, creationDate, messageSize, message) " +
...@@ -383,17 +386,35 @@ public class OfflineMessageStore extends BasicModule { ...@@ -383,17 +386,35 @@ public class OfflineMessageStore extends BasicModule {
return size; return size;
} }
public void userCreated(User user, Map params) {
//Do nothing
}
public void userDeleting(User user, Map params) {
// Delete all offline messages of the user
deleteMessages(user.getUsername());
}
public void userModified(User user, Map params) {
//Do nothing
}
public void start() throws IllegalStateException { public void start() throws IllegalStateException {
super.start(); super.start();
// Initialize the pool of sax readers // Initialize the pool of sax readers
for (int i=0; i<10; i++) { for (int i=0; i<10; i++) {
xmlReaders.add(new SAXReader()); xmlReaders.add(new SAXReader());
} }
// Add this module as a user event listener so we can delete
// all offline messages when a user is deleted
UserEventDispatcher.addListener(this);
} }
public void stop() { public void stop() {
super.stop(); super.stop();
// Clean up the pool of sax readers // Clean up the pool of sax readers
xmlReaders.clear(); xmlReaders.clear();
// Remove this module as a user event listener
UserEventDispatcher.removeListener(this);
} }
} }
\ No newline at end of file
...@@ -16,6 +16,9 @@ import org.dom4j.Element; ...@@ -16,6 +16,9 @@ import org.dom4j.Element;
import org.dom4j.io.SAXReader; import org.dom4j.io.SAXReader;
import org.jivesoftware.database.DbConnectionManager; import org.jivesoftware.database.DbConnectionManager;
import org.jivesoftware.wildfire.container.BasicModule; import org.jivesoftware.wildfire.container.BasicModule;
import org.jivesoftware.wildfire.event.UserEventListener;
import org.jivesoftware.wildfire.event.UserEventDispatcher;
import org.jivesoftware.wildfire.user.User;
import org.jivesoftware.util.JiveGlobals; import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.LocaleUtils; import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
...@@ -27,6 +30,7 @@ import java.sql.PreparedStatement; ...@@ -27,6 +30,7 @@ import java.sql.PreparedStatement;
import java.sql.ResultSet; import java.sql.ResultSet;
import java.util.concurrent.BlockingQueue; import java.util.concurrent.BlockingQueue;
import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.LinkedBlockingQueue;
import java.util.Map;
/** /**
* Private storage for user accounts (JEP-0049). It is used by some XMPP systems * Private storage for user accounts (JEP-0049). It is used by some XMPP systems
...@@ -34,7 +38,7 @@ import java.util.concurrent.LinkedBlockingQueue; ...@@ -34,7 +38,7 @@ import java.util.concurrent.LinkedBlockingQueue;
* *
* @author Iain Shigeoka * @author Iain Shigeoka
*/ */
public class PrivateStorage extends BasicModule { public class PrivateStorage extends BasicModule implements UserEventListener {
private static final String LOAD_PRIVATE = private static final String LOAD_PRIVATE =
"SELECT value FROM jivePrivate WHERE username=? AND namespace=?"; "SELECT value FROM jivePrivate WHERE username=? AND namespace=?";
...@@ -42,6 +46,8 @@ public class PrivateStorage extends BasicModule { ...@@ -42,6 +46,8 @@ public class PrivateStorage extends BasicModule {
"INSERT INTO jivePrivate (value,name,username,namespace) VALUES (?,?,?,?)"; "INSERT INTO jivePrivate (value,name,username,namespace) VALUES (?,?,?,?)";
private static final String UPDATE_PRIVATE = private static final String UPDATE_PRIVATE =
"UPDATE jivePrivate SET value=?, name=? WHERE username=? AND namespace=?"; "UPDATE jivePrivate SET value=?, name=? WHERE username=? AND namespace=?";
private static final String DELETE_PRIVATES =
"DELETE FROM jivePrivate WHERE username=?";
// Currently no delete supported, we can detect an add of an empty element and // Currently no delete supported, we can detect an add of an empty element and
// use that to signal a delete but that optimization doesn't seem necessary. // use that to signal a delete but that optimization doesn't seem necessary.
...@@ -171,7 +177,9 @@ public class PrivateStorage extends BasicModule { ...@@ -171,7 +177,9 @@ public class PrivateStorage extends BasicModule {
} }
finally { finally {
// Return the sax reader to the pool // Return the sax reader to the pool
if (xmlReader != null) xmlReaders.add(xmlReader); if (xmlReader != null) {
xmlReaders.add(xmlReader);
}
try { if (pstmt != null) { pstmt.close(); } } try { if (pstmt != null) { pstmt.close(); } }
catch (Exception e) { Log.error(e); } catch (Exception e) { Log.error(e); }
try { if (con != null) { con.close(); } } try { if (con != null) { con.close(); } }
...@@ -181,17 +189,51 @@ public class PrivateStorage extends BasicModule { ...@@ -181,17 +189,51 @@ public class PrivateStorage extends BasicModule {
return data; return data;
} }
public void userCreated(User user, Map params) {
//Do nothing
}
public void userDeleting(User user, Map params) {
// Delete all private properties of the user
java.sql.Connection con = null;
PreparedStatement pstmt = null;
try {
con = DbConnectionManager.getConnection();
pstmt = con.prepareStatement(DELETE_PRIVATES);
pstmt.setString(1, user.getUsername());
pstmt.executeUpdate();
}
catch (Exception e) {
Log.error(LocaleUtils.getLocalizedString("admin.error"), e);
}
finally {
try { if (pstmt != null) { pstmt.close(); } }
catch (Exception e) { Log.error(e); }
try { if (con != null) { con.close(); } }
catch (Exception e) { Log.error(e); }
}
}
public void userModified(User user, Map params) {
//Do nothing
}
public void start() throws IllegalStateException { public void start() throws IllegalStateException {
super.start(); super.start();
// Initialize the pool of sax readers // Initialize the pool of sax readers
for (int i=0; i<10; i++) { for (int i=0; i<10; i++) {
xmlReaders.add(new SAXReader()); xmlReaders.add(new SAXReader());
} }
// Add this module as a user event listener so we can delete
// all user properties when a user is deleted
UserEventDispatcher.addListener(this);
} }
public void stop() { public void stop() {
super.stop(); super.stop();
// Clean up the pool of sax readers // Clean up the pool of sax readers
xmlReaders.clear(); xmlReaders.clear();
// Remove this module as a user event listener
UserEventDispatcher.removeListener(this);
} }
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment