A MySQL session store for the connectjs session middleware for node.js.
Currently, this code appears to function correctly but it has not been optimized for performance. The store is implemented using sequelize ORM, simply dumping the JSON-serialized session into a MySQL TEXT column.
This fork of this project has been updated to let Node use Laravel's existing session table.
Using npm:
npm install opengovfoundation/node-laravel-mysql-session
By cloning the repo:
git clone [email protected]:opengovfoundation/node-laravel-mysql-session.git
cd node-laravel-mysql-session
npm link
(Note: in both cases you may need to use sudo
when performing the npm
step.)
The following example uses expressjs, but this should work fine using connectjs without the expressjs web app layer.
var express = require('express'),
MySQLSessionStore = require('node-laravel-mysql-session')(express);
var app = express.createServer();
app.use(express.cookieParser());
app.use(express.session({
store: new MySQLSessionStore("dbname", "user", "password", {
// options...
}),
secret: "keyboard cat"
}));
...
Default: false
. If set to true, the Sessions table will be dropped before being reinitialized, effectively clearing all session data.
Default: 1000*60*10
(10 minutes). How frequently the session store checks for and clears expired sessions.
Default: 1000*60*60*24
(1 day). How long session data is stored for "user session" cookies -- i.e. sessions that only last as long as the user keeps their browser open, which are created by doing req.session.maxAge = null
.
- Lazy initialization to ensure model is ready before accessing.
- Index the sid column.
- Initial version.