Low level multicast-dns implementation in pure javascript
npm install multicast-dns
Usage
varmdns=require('multicast-dns')()mdns.on('response',function(response){console.log('got a response packet:',response)})mdns.on('query',function(query){console.log('got a query packet:',query)})// lets query for an A record for 'brunhilde.local'mdns.query({questions:[{name:'brunhilde.local',type:'A'}]})
Running the above (change brunhilde.local to your-own-hostname.local) will print an echo of the query packet first
And then a response packet
CLI
API
A packet has the following format
Currently data from SRV, A, PTR, TXT, AAAA and HINFO records is passed
mdns = multicastdns([options])
Creates a new mdns instance. Options can contain the following
mdns.on('query', (packet, rinfo))
Emitted when a query packet is received.
mdns.on('response', (packet, rinfo))
Emitted when a response packet is received.
The response might not be a response to a query you send as this is the result of someone multicasting a response.
mdns.query(packet, [cb])
Send a dns query. The callback will be called when the packet was sent.
The following shorthands are equivalent
mdns.respond(packet, [cb])
Send a dns response. The callback will be called when the packet was sent.
The following shorthands are equivalent
mdns.destroy()
Destroy the mdns instance. Closes the udp socket.
Development
To start hacking on this module you can use this example to get started
{
questions: [{
name:'brunhilde.local',
type:'A'
}],
answers: [{
name:'brunhilde.local',
type:'A',
ttl:seconds,
data:(record type specific data)
}],
additionals: [
(same format as answers)
],
authorities: [
(same format as answers)
]
}
{
multicast: true // use udp multicasting
interface: '192.168.0.2' // explicitly specify a network interface. defaults to all
port: 5353, // set the udp port
ip: '224.0.0.251', // set the udp ip
ttl: 255, // set the multicast ttl
loopback: true, // receive your own packets
reuseAddr: true // set the reuseAddr option when creating the socket (requires node >=0.11.13)
}
mdns.on('query', function(query) {
if (query.questions[0] && query.questions[0].name === 'brunhilde.local') {
mdns.respond(someResponse) // see below
}
})