bwip-angular2
Version:
JavaScript barcode generator supporting over 90 types and standards.
55 lines (48 loc) • 1.73 kB
JavaScript
// file : bwip-js/server.js
//
// Simple node HTTP server that renders bar code images using bwip-js.
//
// Usage: node server [address:port] ...
//
// To specify all interfaces, use * as the address
//
// If no address:port are specified, the default is: *:3030
;
var http = require('http');
var bwipjs = require('./node-bwipjs'); // ./ required for local use
// To use the freetype library for font rendering, you must enable it via useFreetype(),
// then load your custom font(s). This shows how to load the Inconsolata font, supplied
// with the bwip-js distribution. The path to your fonts will likely be different.
//bwipjs.useFreetype();
//bwipjs.loadFont('Inconsolata', 108,
// require('fs').readFileSync(__dirname + '/fonts/Inconsolata.otf', 'binary'));
var server = http.createServer(function(req, res) {
// If the url does not begin /?bcid= then 404. Otherwise, we end up
// returning 400 on requests like favicon.ico.
if (req.url.indexOf('/?bcid=') != 0) {
res.writeHead(404, { 'Content-Type':'text/plain' });
res.end('BWIP-JS: Unknown request format.', 'utf8');
} else {
// Do not allow images to grow too large
bwipjs(req, res, { sizelimit:2048*2048 });
}
})
var binds = 0;
for (var i = 2; i < process.argv.length; i++) {
var a = /^([^:]+):(\d+)$/.exec(process.argv[i]);
if (a) {
if (a[1] == '*') {
server.listen(+a[2]);
} else {
server.listen(+a[2], a[1]);
}
} else {
console.log(process.argv[i] + ': option ignored...');
}
console.log('listening on ' + process.argv[i]);
binds++;
}
if (!binds) {
server.listen(process.env.PORT || 3030);
console.log('listening on *:' + (process.env.PORT || 3030));
}