Conversation Session
A session is a place to store data that you want to access to across requests. Each user that talks to your bot have a unique session. You can use sessions to store and access user data as they talk to your bot.
Session Expiration
You are able to set expired time for session optionally. The default value of expiration is one year after SessionStore
object is created.
The expiration should be sent as a Number of minutes when you are initializing a SessionStore
object.
Here is an example of creating a MongoSessionStore
object with expired time:
// Session will expire after 10 minutes
const { ConsoleBot, MongoSessionStore } = require('bottender');
const bot = new ConsoleBot({
sessionStore: new MongoSessionStore(
'mongodb://localhost:27017/',
{
collectionName: 'session',
},
10
),
});
Use Different Session Store
Session store is a place where session data is being stored on the server.
We implement the following kinds of session store. All kinds of bots will use memory session store as default.
- memory - sessions are stored in memory with LRU cache and will not be persisted. See example
- file - sessions are stored in
.sessions
by default. See example - mongo - sessions are stored in a mongo database. See example
- redis - sessions are stored in redis based stores. See example
Session Store Configuration
MemorySessionStore
import { MemorySessionStore } from 'bottender';
new MemorySessionStore(max, expiresIn);
Param | Type | Description |
---|---|---|
max | Number |
The max number of items in memory cache, defaults to
Infinity
. |
expiresIn | Number |
Optional. Session expiration time in minutes, defaults to
365 * 24 * 60
, or 1 year. |
Examples:
new MemorySessionStore();
new MemorySessionStore(1000);
FileSessionStore
import { FileSessionStore } from 'bottender';
new FileSessionStore(dirname, expiresIn);
Param | Type | Description |
---|---|---|
dirname | String |
Optional. The directory name to store session files, defaults to
.sessions
. |
expiresIn | Number |
Optional. Session expiration time in minutes, defaults to
365 * 24 * 60
, or 1 year. |
Examples:
new FileSessionStore();
new FileSessionStore('my-sessions-folder');
MongoSessionStore
import { MongoSessionStore } from 'bottender';
new MongoSessionStore(url, options, expiresIn);
Param | Type | Description |
---|---|---|
url | String |
The mongodb connection string to your database. |
options | Object |
Optional. The options object. See below for details. |
options.collectionName | String |
Optional. The collection name to store the sessions, defaults to
sessions
. |
expiresIn | Number |
Optional. Session expiration time in minutes, defaults to
365 * 24 * 60
, or 1 year. |
Examples:
new MongoSessionStore(); // Connect to 127.0.0.1:27017
new MongoSessionStore(
'mongodb://db1.example.net:27017,db2.example.net:2500/?replicaSet=test',
{ collectionName: 'my-sessions' }
);
RedisSessionStore
import { RedisSessionStore } from 'bottender';
new RedisSessionStore(redisOption, expiresIn);
Param | Type | Description |
---|---|---|
redisOption | String | Number | Object |
The ioredis connection option to your database. See below for examples. |
expiresIn | Number |
Optional. Session expiration time in minutes, defaults to
365 * 24 * 60
, or 1 year. |
Examples:
new RedisSessionStore(); // Connect to 127.0.0.1:6379
new RedisSessionStore(6380); // 127.0.0.1:6380
new RedisSessionStore({
port: 6379, // Redis port
host: '127.0.0.1', // Redis host
family: 4, // 4 (IPv4) or 6 (IPv6)
password: 'auth',
db: 0,
});
// Connect to 127.0.0.1:6380, db 4, using password "authpassword"
new RedisSessionStore('redis://:authpassword@127.0.0.1:6380/4');
Adding Custom Session Drivers
Your custom session driver should implement the SessionStore
interface. This interface contains just a few simple methods you need to implement. A stubbed store implementation looks something like this:
// @flow
class Store implements SessionStore {
init(): Promise<SessionStore> {
/* Initializes the session store */
}
read(sessionId: string): Promise<Session | null> {
/* Reads single session from the session store */
}
write(sessionId: string, data): Promise<void> {
/* Writes single session to the session store */
}
destroy(sessionId: string): Promise<void> {
/* Deletes single session from the session store */
}
all(): Promise<Array<Session>> {
/* Reads all sessions from the session store */
}
}
Manipulate Session State
See more on state.