2013-07-27 18:33:20 +02:00
|
|
|
package com.sismics.util.context;
|
|
|
|
|
2016-08-26 21:22:27 +02:00
|
|
|
import com.google.common.collect.Lists;
|
|
|
|
import com.sismics.docs.core.model.context.AppContext;
|
|
|
|
|
2013-07-27 18:33:20 +02:00
|
|
|
import javax.persistence.EntityManager;
|
2016-08-26 21:22:27 +02:00
|
|
|
import java.util.List;
|
2013-07-27 18:33:20 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Context associated to a user request, and stored in a ThreadLocal.
|
|
|
|
*
|
|
|
|
* @author jtremeaux
|
|
|
|
*/
|
|
|
|
public class ThreadLocalContext {
|
|
|
|
/**
|
|
|
|
* ThreadLocal to store the context.
|
|
|
|
*/
|
2016-04-18 00:00:46 +02:00
|
|
|
private static final ThreadLocal<ThreadLocalContext> threadLocalContext = new ThreadLocal<>();
|
2013-07-27 18:33:20 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Entity manager.
|
|
|
|
*/
|
|
|
|
private EntityManager entityManager;
|
2016-08-26 21:22:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* List of async events posted during this request.
|
|
|
|
*/
|
|
|
|
private List<Object> asyncEventList = Lists.newArrayList();
|
|
|
|
|
2013-07-27 18:33:20 +02:00
|
|
|
/**
|
|
|
|
* Private constructor.
|
|
|
|
*/
|
|
|
|
private ThreadLocalContext() {
|
|
|
|
// NOP
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an instance of this thread context.
|
|
|
|
*
|
|
|
|
* @return Thread local context
|
|
|
|
*/
|
|
|
|
public static ThreadLocalContext get() {
|
|
|
|
ThreadLocalContext context = threadLocalContext.get();
|
|
|
|
if (context == null) {
|
|
|
|
context = new ThreadLocalContext();
|
|
|
|
threadLocalContext.set(context);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Cleans up the instance of this thread context.
|
|
|
|
*/
|
|
|
|
public static void cleanup() {
|
|
|
|
threadLocalContext.set(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Getter of entityManager.
|
|
|
|
*
|
|
|
|
* @return entityManager
|
|
|
|
*/
|
|
|
|
public EntityManager getEntityManager() {
|
|
|
|
return entityManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setter of entityManager.
|
|
|
|
*
|
|
|
|
* @param entityManager entityManager
|
|
|
|
*/
|
|
|
|
public void setEntityManager(EntityManager entityManager) {
|
|
|
|
this.entityManager = entityManager;
|
|
|
|
}
|
2016-08-26 21:22:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an async event to the queue to be fired after the current request.
|
|
|
|
*
|
|
|
|
* @param asyncEvent Async event
|
|
|
|
*/
|
|
|
|
public void addAsyncEvent(Object asyncEvent) {
|
|
|
|
asyncEventList.add(asyncEvent);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fire all pending async events.
|
|
|
|
*/
|
|
|
|
public void fireAllAsyncEvents() {
|
|
|
|
for (Object asyncEvent : asyncEventList) {
|
|
|
|
AppContext.getInstance().getAsyncEventBus().post(asyncEvent);
|
|
|
|
}
|
|
|
|
}
|
2013-07-27 18:33:20 +02:00
|
|
|
}
|