Overview
JAWCE session / cache management
JAWCE comes with default SessionManager
implementations out-of-the-box
Default implementations
- FileBasedSessionManager
- CaffeineSessionManager
- HazelcastSessionManager
- LMDBSessionManager
You can use any of the default implementations or switch any of them at any time.
The sample chatbot uses CaffeineSessionManager
by default
Session methods
All session managements implements a single ISessionManager
interface. You can also implement your own session manager
and use it in your chatbot
public interface ISessionManager {
ISessionManager session(String user);
void save(String user, String key, Object data);
Object get(String user, String key);
// get all user data
Map<String, Object> fetchAll(String user);
// remove data by key
void evict(String user, String key);
void clear(String user);
// save non-user related data - accessible to all users
void saveGlobal(String key, Object data);
void evictGlobal(String key);
// clear all user data except keys in > retain array
void clear(String user, List<String> retain);
// remove prop data by key
boolean evictProp(String user, String propKey);
Object getFromProps(String user, String propKey);
Map<String, Object> getUserProps(String user);
void saveProp(String user, String key, Object data);
// --- utility methods
<T> T get(String user, String key, Class<T> type);
<T> T getGlobal(String key, Class<T> type);
<T> T getFromProps(String user, String propKey, Class<T> propType);
}
ISessionManager
and its default implementations are not tightly coupled with JAWCE main engine.
You can use this in any other project