Redis powered session middleware for Telegraf
npm install telegraf-session-redis


Redis powered session middleware for Telegraf.
``js`
$ npm install telegraf-session-redis
`js
const Telegraf = require('telegraf')
const RedisSession = require('telegraf-session-redis')
const bot = new Telegraf(process.env.BOT_TOKEN)
const session = new RedisSession({
store: {
host: process.env.TELEGRAM_SESSION_HOST || '127.0.0.1',
port: process.env.TELEGRAM_SESSION_PORT || 6379
}
})
bot.use(session)
bot.on('text', (ctx) => {
ctx.session.counter = ctx.session.counter || 0
ctx.session.counter++
console.log('Session', ctx.session)
})
bot.launch()
`
When you have stored the session key beforehand, you can access a
session without having access to a context object. This is useful when
you perform OAUTH or something similar, when a REDIRECT_URI is called
on your bot server.
`js
const redisSession = new RedisSession()
// Retrieve session state by session key
redisSession.getSession(key)
.then((session) => {
console.log('Session state', session)
})
// Save session state
redisSession.saveSession(key, session)
`
* store:host
: Redis host (default: 127.0.0.1*)port
: Redis port (default: 6379*)path
* : Unix socket stringurl
* : Redis url...
* : Other redis connection optionsproperty
* : context property name (default: session)ttl
* : session ttl in seconds (default: forever)getSessionKey
* : session key resolver function (ctx) => any)
Default implementation of getSessionKey:
`js${ctx.from.id}:${ctx.chat.id}
function getSessionKey (ctx) {
if (!ctx.from || !ctx.chat) {
return
}
return `
}
To destroy a session simply set it to null.
`js
bot.on('text', (ctx) => {
ctx.session = null
})
``