Gathering detailed insights and metrics for bonjour-hap
Gathering detailed insights and metrics for bonjour-hap
Gathering detailed insights and metrics for bonjour-hap
Gathering detailed insights and metrics for bonjour-hap
npm install bonjour-hap
Module System
Min. Node Version
Typescript Support
Node Version
NPM Version
12 Stars
190 Commits
7 Forks
9 Watching
5 Branches
4 Contributors
Updated on 27 Jun 2024
JavaScript (100%)
Cumulative downloads
Total Downloads
Last day
-5.6%
4,706
Compared to previous day
Last week
29.3%
45,581
Compared to previous week
Last month
121%
140,636
Compared to previous month
Last year
27.3%
745,102
Compared to previous year
A Bonjour/Zeroconf protocol implementation in pure JavaScript. Publish services on the local network or discover existing services using multicast DNS.
The bonjour-hap
library was used in HAP-NodeJS in versions
prior to v0.8.0.
bonjour-hap
does NOT correctly implement mdns service discovery as it does not correctly implement
RFC 6762 or RFC 6763. The library heavily congest the network with unnecessary traffic, does not implement
certain features and does not behave as expected from a mdns responder (or querier).
It SHOULD NOT be used anymore. It is not maintained anymore. The code should not be taken as reference for anything.
bonjour-hap
was replaced by the ciao library, which is basically a rewrite
and strongly adheres to the mentioned RFCs. Ciao is used in HAP-NodeJS
since v0.8.0.
npm install bonjour-hap
1var bonjour = require('bonjour-hap')() 2 3// advertise an HTTP server on port 3000 4bonjour.publish({ name: 'My Web Server', type: 'http', port: 3000 }) 5 6// browse for all http services 7bonjour.find({ type: 'http' }, function (service) { 8 console.log('Found an HTTP server:', service) 9})
1var bonjour = require('bonjour-hap')([options])
The options
are optional and will be used when initializing the
underlying multicast-dns server. For details see the multicast-dns
documentation.
var service = bonjour.publish(options)
Publishes a new service.
Options are:
name
(string)host
(string, optional) - defaults to local hostnameport
(number)type
(string)subtypes
(array of strings, optional)protocol
(string, optional) - udp
or tcp
(default)txt
(object, optional) - a key/value object to broadcast as the TXT
recordIANA maintains a list of official service types and port numbers.
bonjour.unpublishAll([callback])
Unpublish all services. The optional callback
will be called when the
services have been unpublished.
bonjour.destroy()
Destroy the mdns instance. Closes the udp socket.
var browser = bonjour.find(options[, onup])
Listen for services advertised on the network. An optional callback can
be provided as the 2nd argument and will be added as an event listener
for the up
event.
Options (all optional):
type
(string)subtypes
(array of strings)protocol
(string) - defaults to tcp
txt
(object) - passed into dns-txt
module contructor. Set to { binary: true }
if you want to keep the TXT records in binaryvar browser = bonjour.findOne(options[, callback])
Listen for and call the callback
with the first instance of a service
matching the options
. If no callback
is given, it's expected that
you listen for the up
event. The returned browser
will automatically
stop it self after the first matching service.
Options are the same as given in the browser.find
function.
Event: up
Emitted every time a new service is found that matches the browser.
Event: update
Emitted every time an update is received for existing service is found that matches the browser.
Event: down
Emitted every time an existing service emmits a goodbye message.
browser.services
An array of services known by the browser to be online.
browser.start()
Start looking for matching services.
browser.stop()
Stop looking for matching services.
browser.update()
Broadcast the query again.
Event: up
Emitted when the service is up, and if the txt record of the service is updated service.updateTxt(object)
.
Event: error
Emitted if an error occurrs while publishing the service.
service.stop([callback])
Unpublish the service. The optional callback
will be called when the
service have been unpublished.
service.start()
Publish the service.
service.updateTxt(object)
Update the txt record of the service.
service.name
The name of the service, e.g. Apple TV
.
service.type
The type of the service, e.g. http
.
service.subtypes
An array of subtypes. Note that this property might be null
.
service.protocol
The protocol used by the service, e.g. tcp
.
service.host
The hostname or ip address where the service resides.
service.port
The port on which the service listens, e.g. 5000
.
service.fqdn
The fully qualified domain name of the service. E.g. if given the name
Foo Bar
, the type http
and the protocol tcp
, the service.fqdn
property will be Foo Bar._http._tcp.local
.
service.txt
The TXT record advertised by the service (a key/value object). Note that
this property might be null
.
service.published
A boolean indicating if the service is currently published.
MIT
No vulnerabilities found.
Reason
no dangerous workflow patterns detected
Reason
no binaries found in the repo
Reason
license file detected
Details
Reason
security policy file detected
Details
Reason
1 existing vulnerabilities detected
Details
Reason
Found 5/25 approved changesets -- score normalized to 2
Reason
0 commit(s) and 1 issue activity found in the last 90 days -- score normalized to 0
Reason
detected GitHub workflow tokens with excessive permissions
Details
Reason
dependency not pinned by hash detected -- score normalized to 0
Details
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
project is not fuzzed
Details
Reason
SAST tool is not run on all commits -- score normalized to 0
Details
Score
Last Scanned on 2024-11-25
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More