Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/koajs/atomic-session
DEPRECATED
https://github.com/koajs/atomic-session
Last synced: 3 months ago
JSON representation
DEPRECATED
- Host: GitHub
- URL: https://github.com/koajs/atomic-session
- Owner: koajs
- License: mit
- Archived: true
- Created: 2014-12-29T06:57:56.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2021-08-22T05:46:46.000Z (over 3 years ago)
- Last Synced: 2024-04-14T13:08:39.065Z (9 months ago)
- Language: JavaScript
- Homepage: https://github.com/koajs/redis-session-sets
- Size: 13.7 KB
- Stars: 15
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-koa - atomic-session - Atomic sessions for Koa (Middleware)
README
# atomic-session
[![NPM version][npm-image]][npm-url]
[![Build status][travis-image]][travis-url]
[![Test coverage][coveralls-image]][coveralls-url]
[![Dependency Status][david-image]][david-url]
[![License][license-image]][license-url]
[![Downloads][downloads-image]][downloads-url]
[![Gittip][gittip-image]][gittip-url]Atomic sessions for Koa.
- Currently uses MongoDB.
- Atomic updates - don't butcher the entire session.
- Don't grab the session from the database unless necessary.
- Better error handling.
- Includes CSRF token handling## Usage
```js
// create the app
var app = koa()// attach the session to the app
var MongoDBSession = require('koa-atomic-session')(app, {
maxAge: '1 month'
})// asynchronously attach the collection
// you should not start the app until you do this
require('mongodb').MongoClient.connect('mongodb://localhost', function (err, db) {
if (err) throw err
// set the collection
MongoDBSession.collection = db.collection('sessions')
// ensure indexes every time!
MongoDBSession.ensureIndex()
})// use it in your app
app.use(function* (next) {
var session = yield this.session()yield session.unset('user_id')
yield session.set('user_id', new ObjectID()).then(session.update)
})
```## API
### var Session = Session(app, [options])
Options:
- `key` - cookie key
- `maxAge` - default to 14 days### this.session().then( session => )
Grab the session from the database asynchronously.
### session.touch().then( session => )
Updates the new `expires` time.
### session\[command\](arguments...).then( => )
Change properties of the session.
See database-specific options below.### session.update().then( => )
Updates all the properties of the `session` object after running a command.
Should always be added to a `.then()`.```js
yield session.set('message', 'hello')
.then(session.update)
assert.equal(session.message, 'hello')
```### session.destroy.then( => )
Destroys the session without creating a new one.
### session.regenerate.then( session => )
Creates a brand new session.
### var csrf = session.createCSRF()
Create a CSRF token.
### session.assertCSRF(csrf)
Assert that a CSRF token is valid.
## MongoDB API
### MongoDBSession.ensureIndex().then( => )
Adds indexes on the `expires` property so that expires are automatically set.
### MongoDBSession.collection =
Set the collection asynchronously.
You should set this collection before starting your app.### session\[command\](arguments...).then( => )
Supports most MongoDB properties.
This uses [mongodb-next](https://www.npmjs.com/package/mongodb-next) internally.
Some commands that are supported are:- `.set(key, value)``
- `.unset(key)`
- `.rename(name, newName)`
- `.pull()`
- `.addToSet()`[gitter-image]: https://badges.gitter.im/koajs/atomic-session.png
[gitter-url]: https://gitter.im/koajs/atomic-session
[npm-image]: https://img.shields.io/npm/v/koa-atomic-session.svg?style=flat-square
[npm-url]: https://npmjs.org/package/koa-atomic-session
[github-tag]: http://img.shields.io/github/tag/koajs/atomic-session.svg?style=flat-square
[github-url]: https://github.com/koajs/atomic-session/tags
[travis-image]: https://img.shields.io/travis/koajs/atomic-session.svg?style=flat-square
[travis-url]: https://travis-ci.org/koajs/atomic-session
[coveralls-image]: https://img.shields.io/coveralls/koajs/atomic-session.svg?style=flat-square
[coveralls-url]: https://coveralls.io/r/koajs/atomic-session
[david-image]: http://img.shields.io/david/koajs/atomic-session.svg?style=flat-square
[david-url]: https://david-dm.org/koajs/atomic-session
[license-image]: http://img.shields.io/npm/l/koa-atomic-session.svg?style=flat-square
[license-url]: LICENSE
[downloads-image]: http://img.shields.io/npm/dm/koa-atomic-session.svg?style=flat-square
[downloads-url]: https://npmjs.org/package/koa-atomic-session
[gittip-image]: https://img.shields.io/gratipay/jonathanong.svg?style=flat-square
[gittip-url]: https://gratipay.com/jonathanong/