lhl 2bdf874dbb create 1 month ago
..
example 2bdf874dbb create 1 month ago
test 2bdf874dbb create 1 month ago
.travis.yml 2bdf874dbb create 1 month ago
LICENSE 2bdf874dbb create 1 month ago
index.js 2bdf874dbb create 1 month ago
package.json 2bdf874dbb create 1 month ago
readme.markdown 2bdf874dbb create 1 month ago

readme.markdown

oppressor

streaming http compression response negotiator

build status

example

You can use plain old streams:

var oppressor = require('oppressor');
var fs = require('fs');
var http = require('http');

var server = http.createServer(function (req, res) {
    fs.createReadStream(__dirname + '/data.txt')
        .pipe(oppressor(req))
        .pipe(res)
    ;
});
server.listen(8000);

or you can use fancy streaming static file server modules like filed that set handy things like etag, last-modified, and content-type headers for you:

(For now you'll need to use my fork until this pull request gets merged.)

var oppressor = require('oppressor');
var filed = require('filed');
var http = require('http');

var server = http.createServer(function (req, res) {
     filed(__dirname + '/data.txt')
        .pipe(oppressor(req))
        .pipe(res)
    ;
});
server.listen(8000);

methods

var oppressor = require('oppressor')

var stream = oppressor(req)

Return a duplex stream that will be compressed with gzip, deflate, or no compression depending on the accept-encoding headers sent.

oppressor will emulate calls to http.ServerResponse methods like writeHead() so that modules like filed that expect to be piped directly to the response object will work.

install

With npm do:

npm install oppressor

license

MIT