New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

file-send

Package Overview
Dependencies
Maintainers
1
Versions
54
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

file-send

A http file send

  • 1.0.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
88
increased by51.72%
Maintainers
1
Weekly downloads
 
Created
Source

file-send

A http file send

NPM Version Download Status Linux Status Windows Status Test Coverage Node Version Dependencies

Installation

$ npm install file-send

API

var http = require('http'),
  FileSend = require('file-send'),
  Send = FileSend('/', {
    etag: false,
    maxAge: '30d'
  });

// open debug log
FileSend.debug = true;

http.createServer(function (request, response){
  Send.parse(request) // Create a new send stream
    .pipe(response); // Send stream to client
});

FileSend(root, [options])

Create a new Send for the given root path and options to initialize.

Options
dotFiles

Set how "dotFiles" are treated when encountered. A dotFile is a file or directory that begins with a dot ("."). Note this check is done on the path itself without checking if the path actually exists on the disk. If root is specified, only the dotfiles above the root are checked (i.e. the root itself can be within a dotfile).

The default value is 'ignore'.

  • 'allow' No special treatment for dotfiles.
  • 'deny' Send a 403 for any request for a dotfile.
  • 'ignore' Pretend like the dotfile does not exist and 404.
etag

Enable or disable etag generation, defaults to true.

extensions

If a given file doesn't exist, try appending one of the given extensions, in the given order. By default, this is disabled (set to false). An example value that will serve extension-less HTML files: ['html', 'htm']. This is skipped if the requested file already has an extension.

index

By default send supports "index.html" files, to disable this set false or to supply a new index pass a string or an array in preferred order.

lastModified

Enable or disable Last-Modified header, defaults to true. Uses the file system's last modified value.

maxAge

Provide a max-age in milliseconds for http caching, defaults to 0. This can also be a string accepted by the ms module.

Send.parse(request)

var stream = Send.parse(request); // The Send.parse return a new send stream

Create a new SendStream for the given request and response.

Events

The SendStream is an event emitter and will emit the following events:

  • error an error occurred (err)
  • directory a directory was requested
  • file a file was requested (path, stat)
  • headers the headers are about to be set on a file (response, path, stat)
  • stream file streaming has started (stream, next(stream))
  • end streaming has completed

stream.pipe(response)

The pipe method is used to pipe the response into the Node.js HTTP response object, typically Send.parse(req).pipe(res).

Error-handling

By default when no error listeners are present an automatic response will be made, otherwise you have full control over the response, aka you may show a 5xx page etc.

Caching

It does not perform internal caching, you should use a reverse proxy cache such as Varnish for this, or those fancy things called CDNs. If your application is small enough that it would benefit from single-node memory caching, it's small enough that it does not need caching at all ;).

Debugging

To enable debug() instrumentation:

$ node app -v

or:

$ node app -verbose

Running tests

$ npm install
$ npm test

Examples

Serving from a root directory with custom error-handling:

var http = require('http'),
  FileSend = require('file-send'),
  Send = FileSend('/www/example.com/public'); // Set root

// Your custom error-handling logic:
function error(err) {
  var res = this.response;
  res.statusCode = err.status || 500;
  res.end(err.message);
}

// Your custom headers
function headers(res, path, stat) {
  // serve all files for download
  res.setHeader('Content-Disposition', 'attachment');
}

// Your custom directory handling logic:
function directory(path, stat) {
  // TODO You can do something here
  // Like displays the current directory file list
  this.response.end('This is a directory !');
}

var app = http.createServer(function(request, response){
  // Transfer arbitrary files from within /www/example.com/public/*
  Send.parse(request)
    .on('error', error)
    .on('directory', directory)
    .on('headers', headers)
    .pipe(response);
}).listen(3000);

License

MIT

Keywords

FAQs

Package last updated on 01 Mar 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc