com.untzuntz.ustack.data.WebAppSession Maven / Gradle / Ivy
package com.untzuntz.ustack.data;
import java.net.URL;
import java.util.Calendar;
import java.util.Date;
import org.apache.log4j.Logger;
import org.bson.types.ObjectId;
import com.mongodb.BasicDBObject;
import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.untzuntz.ustack.main.UOpts;
/**
* A session (for long term tracking)
*
* @author jdanner
*
*/
public class WebAppSession extends UntzDBObject {
private static final long serialVersionUID = 1L;
private static Logger logger = Logger.getLogger(WebAppSession.class);
public String getCollectionName() { return "webSession"; }
private WebAppSession() {
put("created", new Date());
}
public WebAppSession(DBObject obj)
{
putAll(obj);
}
public String getId() {
return get("_id") + "";
}
/** Gets the DB Collection for the UserAccount object */
public static DBCollection getDBCollection() {
return new WebAppSession().getCollection();
}
public static WebAppSession createSession(String appServer, String sessionId, String userName, String appName, String sourceIP, String sourceCountry, URL url)
{
if (appServer == null)
appServer = System.getProperty("ApplicationServer.Name", "PrimaryServer");
if (appServer == null)
logger.warn("Unknown App Server? Session ID => " + sessionId);
WebAppSession session = new WebAppSession();
session.put("userName", userName);
session.put("appServer", appServer);
session.put("sessionId", sessionId);
session.put("applicationName", appName);
session.put("host", url.getHost());
session.put("path", url.getFile());
session.put("sourceIP", sourceIP);
session.put("sourceCountry", sourceCountry);
session.put("startTime", new Date());
session.save(userName);
return session;
}
public static void endSession(String sessionId, String endReason, String actor, boolean audit) {
endSession(null, sessionId, endReason, actor, audit);
}
public static void endSession(String appServer, String sessionId, String endReason, String actor, boolean audit) {
if (appServer == null)
appServer = System.getProperty("ApplicationServer.Name", "PrimaryServer");
WebAppSession session = WebAppSession.getRecentSessionByServerSessionIdUser(appServer, sessionId);
if (session != null)
{
endSession(session, endReason, audit);
session.save(actor);
}
// else
// logger.info("Session not found in session database - too old? : " + appServer + "/" + sessionId);
}
private static void endSession(DBObject session, String endReason, boolean audit) {
if (session.get("endTime") != null)
{
// logger.info("Session already ended (" + session.get("endTime") + ") : => " + session.get("_id"));
return;
}
Date now = new Date();
Date start = (Date)session.get("startTime");
long durMs = now.getTime() - start.getTime();
session.put("endTime", now);
session.put("duration", (long)((float)durMs / 1000.0f / 60.0f));
session.put("reason", endReason);
if (audit && session.get("userName") != null)
AuditLog.log("core", UOpts.SUBSYS_AUTH, "Logout", new BasicDBObject("userName", session.get("userName")).append("type", "sessionTimeout"));
}
public static void endSessionById(String id, String endReason, String actor, boolean audit) {
WebAppSession session = getById(id);
if (session != null)
{
endSession(session, endReason, audit);
session.save(actor);
}
}
public static void closeOutstandingSessions(String appServer)
{
if (appServer == null)
appServer = System.getProperty("ApplicationServer.Name", "PrimaryServer");
Calendar c = Calendar.getInstance();
c.add(Calendar.DATE, -1);
BasicDBObject sort = new BasicDBObject("startTime", -1);
BasicDBObject search = new BasicDBObject("appServer", appServer).append("startTime", new BasicDBObject("$gte", c.getTime())).append("endTime", new BasicDBObject("$exists", false));
logger.info("Close-out Session Search: " + search);
DBCollection col = new WebAppSession().getCollection();
DBCursor cur = col.find(search).sort(sort);
int idx = 0;
long st = System.currentTimeMillis();
logger.info("Close-out Session -> " + cur.count() + " sessions to close-out");
while (cur.hasNext())
{
DBObject session = (DBObject)cur.next();
endSession(session, "Closed Outstanding", true);
col.save(session);
idx++;
if (idx % 10 == 0)
logger.info("Close-out Session -> " + (cur.count() - idx) + " remaining to close-out");
}
logger.info("Close-out Session -> DONE! Took: " + (System.currentTimeMillis() - st) + " ms");
}
public static WebAppSession getRecentSessionByServerSessionIdUser(String appServer, String sessionId) {
if (appServer == null || sessionId == null)
return null;
Calendar c = Calendar.getInstance();
c.add(Calendar.DATE, -1);
BasicDBObject sort = new BasicDBObject("startTime", -1);
BasicDBObject search = new BasicDBObject("appServer", appServer).append("sessionId", sessionId).append("startTime", new BasicDBObject("$gte", c.getTime()));
// logger.info("Session Search: " + search);
DBCursor cur = new WebAppSession().getCollection().find(search).sort(sort);
if (cur != null && cur.hasNext())
return new WebAppSession(cur.next());
return null;
}
public static WebAppSession getById(String id)
{
if (id == null)
return null;
DBObject book = new WebAppSession().getCollection().findOne(BasicDBObjectBuilder.start("_id", new ObjectId(id)).get());
if (book == null)
return null;
return new WebAppSession(book);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy