Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@mkkr/ipp-printer
Advanced tools
Create a printer on your network using nothing but Node.js. This module implements version 1.1 of the IPP protocol and uses Bonjour/Zeroconf to advertise a printer on your local network that anyone can print to.
For a video introduction, check out the talk I gave at Node.js Interactive 2015 in Portland.
This module have been confirmed to work with both OS X and Windows clients. But if you experience any problems please don't hesitate to open an issue.
Be aware that this module currently doesn't support any of the security features build into IPP, so don't print anything you don't want others to know on an open network.
Install globally to use CLI:
npm install ipp-printer -g
Or install locally to use in your project:
npm install ipp-printer --save
Just run:
$ ipp-printer
The printer will now advertise it self on the network using Bonjour/Zeroconf and write all jobs to the current working directory.
var fs = require('fs')
var Printer = require('ipp-printer')
var printer = new Printer('My Printer')
printer.on('job', function (job) {
console.log('[job %d] Printing document: %s', job.id, job.name)
var filename = 'job-' + job.id + '.ps' // .ps = PostScript
var file = fs.createWriteStream(filename)
job.on('end', function () {
console.log('[job %d] Document saved as %s', job.id, filename)
})
job.pipe(file)
})
new Printer([options])
The Printer object can be initialized with either the printer name as a string or an object containing:
name
- Name of the printer (default: Node JS
)port
- Port the printer should listen on (defaults to a random
available port)zeroconf
- Boolean. If true
, the printer will advertise it self on
the network using Bonjour/Zeroconf for easier setup (default: true
)fallback
- Boolean. If true
, responses to IPP/1.0 requests will
identify them selfs as coming from an IPP/1.0 server. This shouldn't
be necessary in a perfect world, but some versions of Windows doesn't
like connecting to a server running a different version of the IPP
protocol than it self (default: true
)onerror
- Function. Callback for catching http.Server
errors. Useful for catching server initialization errors if there are network or configuration problems.Note that the IPP standard specifies port 631 as the default IPP port, but most IPP clients are fine with connecting to another port.
function (job) {}
Emitted each time a new job is sent to the printer. The job
is an
instance of the Job class.
Example writing a print job document to a file:
printer.on('job', function (job) {
var filename = 'job-' + job.id + '.ps' // expect Postscript
var file = fs.createWriteStream(filename)
job.on('end', function () {
console.log('written job to', filename)
})
job.pipe(file)
})
function (operation) {}
Emitted each time a new IPP operation is received. This event is more low level than the job event as it will be emitted on all incoming IPP operations.
This module currently supports the minimum set of operations required by the IPP standard:
The operation
object have the following properties supplied by the
printer client:
version
- An object containing the major and minor IPP version of
the request (e.g. { major: 1, minor: 1 }
)operationId
- The id of the IPP operationrequestId
- The id of the IPP requestgroups
- An array of IPP attribute groupsSee the ipp-encoder for an explanation of the different operation types.
printer.name
The printer name.
printer.port
The port of the printer is listening on.
printer.jobs
An array of all jobs handled by the printer.
printer.server
An instance of http.Server
.
printer.destroy
A function to shut down the printer server and bonjour service.
printer.destroy();
A job is a readable stream containing the document to be printed. In many cases this will be in Postscript format.
function () {}
Emitted if the job is cancelled prior to completion.
function () {}
Emitted if the job is aborted prior to completion.
function (error) {}
Emitted if the job encounters an error.
job.id
The id of the job.
job.state
The job state.
See the ipp-encoder for an explanation of the job states.
job.uri
The job URI.
job.name
The document name.
job.userName
The name of the requesting user.
job.attributes([filter])
Returns an array of job attributes.
If an array of attribute names or attribute groups is given as the first argument, the returned array will only include the attributes maching the supplied names or groups.
Attributes example:
[
{ tag: 0x45, name: 'job-printer-uri', value: 'ipp://watson.local.:3000/' },
{ tag: 0x45, name: 'job-uri', value: 'ipp://watson.local.:3000/1' },
{ tag: 0x42, name: 'job-name', value: 'My Document Title' },
{ tag: 0x42, name: 'job-originating-user-name', value: 'watson' },
{ tag: 0x44, name: 'job-state-reasons', value: 'none' },
{ tag: 0x21, name: 'time-at-creation', value: 40 },
{ tag: 0x47, name: 'attributes-charset', value: 'utf-8' },
{ tag: 0x48, name: 'attributes-natural-language', value: 'en-us' }
]
See the ipp-encoder for an explanation of the tag values.
To see the communication between the client and the server, enable
debugging mode by setting the environment variable DEBUG=ipp-printer
.
If you open an issue because the module crashes or if the client cannot communicate properly with the printer it helps a lot if you attach the client/server communication to the issue.
MIT
FAQs
Create a printer on the network
We found that @mkkr/ipp-printer demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.