https://github.com/reklatsmasters/dgram-server
Stream-based UDP server (may have minimal internal changes due to incomplete tests).
https://github.com/reklatsmasters/dgram-server
dgram nodejs server stream udp
Last synced: 11 months ago
JSON representation
Stream-based UDP server (may have minimal internal changes due to incomplete tests).
- Host: GitHub
- URL: https://github.com/reklatsmasters/dgram-server
- Owner: reklatsmasters
- License: mit
- Created: 2018-02-18T21:22:42.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-02-19T23:03:10.000Z (almost 8 years ago)
- Last Synced: 2025-03-01T00:57:03.042Z (11 months ago)
- Topics: dgram, nodejs, server, stream, udp
- Language: JavaScript
- Homepage:
- Size: 58.6 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# dgram-server
[](https://travis-ci.org/reklatsmasters/dgram-server)
[](https://npmjs.org/package/dgram-server)
[](https://npmjs.org/package/dgram-server)
[](https://npmjs.org/package/dgram-server)
[](https://npmjs.org/package/dgram-server)
[](https://coveralls.io/github/reklatsmasters/dgram-server?branch=master)
[](https://github.com/sindresorhus/xo)
Stream-based UDP server.
Doesn't properly work with [cluster](https://nodejs.org/api/cluster.html).
## Usage
```js
const dgramsrv = require('dgram-server')
const server = dgramsrv.createServer()
server.on('socket', (socket) => {
socket.on('data', (data) => {
console.log('got %s bytes from %s:%s', data.length, socket.remoteAddress, socket.remotePort)
socket.write('hello, world!', () => {
socket.close()
})
})
})
server.listen(() => {
console.log('udp server started on 0.0.0.0:%s', server.address().port)
})
```
## API
* `createServer([options: Object]): Server`
Creates a new UDP server. Also accept all options for `dgram.createSocket()`. If `options.socket` is provided, these options will be ignored.
* `option.socket: dgram.Socket`
An optional internal `dgram` socket used as transport layer.
* `class Server`
This class is used to create a UDP server. `Server` is an [EventEmitter](https://nodejs.org/api/events.html#events_class_eventemitter) with the following events:
* `Event: 'socket'`
* `socket: unicast.Socket`
Emitted when a new association is made. `socket` is an instance of `unicast.Socket`.
* `Event: 'listening'`
Emitted when the server has been bound after calling `server.listen()`
* `server.listen([port: number[, host: string]][, callback: function])`
* `server.listen()`
Start a server listening for associations. When the server starts listening, the `'listening'` event will be emitted. The last parameter `callback` will be added as a listener for the `'listening'` event.
* `server.close()`
Close the underlying socket and stop listening for data on it.
* `server.address(): Object`
Returns the bound address, the address family name, and port of the server as reported by the operating system. Useful to find which port was assigned when getting an OS-assigned address. Returns an object with `port`, `family`, and `address` properties: `{ port: 12346, family: 'IPv4', address: '127.0.0.1' }`.
Don't call `server.address()` until the 'listening' event has been emitted.
* `server.connections: number`
The number of concurrent associations on the server.
## Related
* [`unicast`](https://npmjs.org/package/unicast) - Unicast implementation of UDP Datagram sockets.
## License
MIT, 20!8 (c) Dmitriy Tsvettsikh