koa-session-mysql

0.1.2 • Public • Published

koa-session-mysql

Features

Install

$ npm install koa-session-mysql --save
$ yarn add koa-session-mysql

Usage

MySQL Table Layout (required fields)

CREATE TABLE IF NOT EXISTS `session` (
  `session_id` varchar(50) NOT NULL,
  `created` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `modified` timestamp NULL DEFAULT NULL,
  `payload` text
) ENGINE=InnoDB;
 
ALTER TABLE `session` ADD PRIMARY KEY (`session_id`);

Examples

const _Koa = require('koa');
const _koaSession = require('koa-session');
const _mysql = require('mysql-magic');
const _koaSessionMysql = require('koa-session-mysql');
 
// initialize connection pool - koa-session-mysql access it by its name
// somewhere during your applications bootstrap...initialize a custom pool. 
// It consumes any pool-options of [mysqljs](https://github.com/mysqljs/mysql)
_mysql.initPool('koa-session', {
    host     : 'localhost',
    user     : 'dev',
    password : 'dev',
    database : 'koa_test'
});
 
// set db pool + table for storage
_koaSessionMysql.init('koa-session', 'session');
 
// new Koa app + keygrip keys
const _webapp = new _Koa();
_webapp.keys = ['1234567890'];
 
// initialize session middleware
cwebapp.use(_koaSession({
    store: _koaSessionMysql,
    key: 'sid',
    maxAge: 86400000,
}, _webapp));
 
_webapp.use(ctx => {
    // ignore favicon
    if (ctx.path === '/favicon.ico') return;
 
    // increase counter
    let n = ctx.session.views || 0;
    ctx.session.views = ++n;
 
    // show counter
    ctx.body = n + ' views';
});
 
_webapp.listen(3000);
console.log('listening on port 3000');

License

koa-session-mysql is OpenSource and licensed under the Terms of The MIT License (X11) - your're welcome to contribute

Package Sidebar

Install

npm i koa-session-mysql

Weekly Downloads

2

Version

0.1.2

License

MIT

Unpacked Size

7.38 kB

Total Files

8

Last publish

Collaborators

  • andidittrich