oppressor

0.0.1 • Public • Published

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

Readme

Keywords

none

Package Sidebar

Install

npm i oppressor

Weekly Downloads

238

Version

0.0.1

License

MIT

Last publish

Collaborators

  • nopersonsmodules