react-native-udp/README.md

108 lines
2.5 KiB
Markdown
Raw Normal View History

2015-05-10 14:50:44 +00:00
# UDP in React Native
node's [dgram](https://nodejs.org/api/dgram.html) API in React Native
2015-05-10 14:58:08 +00:00
This module is used by [Tradle](https://github.com/tradle)
2015-05-10 14:50:44 +00:00
## Install
* Create a new react-native project. [Check react-native getting started](http://facebook.github.io/react-native/docs/getting-started.html#content)
2015-05-11 17:51:52 +00:00
* In your project dir:
2015-05-10 14:50:44 +00:00
```
npm install --save react-native-udp
```
## Link in the native dependency
```
2016-09-14 18:31:56 +00:00
react-native link react-native-udp
2016-09-14 21:03:34 +00:00
# OR, if you're using react-native older than 0.31:
rnpm link react-native-udp
```
### `Android`
* Register and load the Native Module in your Main application
([import](examples/rctsockets/android/app/src/main/java/com/rctsockets/MainApplication.java#L11), [getPackages](examples/rctsockets/android/app/src/main/java/com/rctsockets/MainApplication.java#L28))
* __Note:__ prior to react-native 0.29.2, this should happen in your Main Activity
```java
...
import com.tradle.react.UdpSocketsModule; // <--- import //
public class MainApplication extends Application implements ReactApplication {
...
@Override
protected List<ReactPackage> getPackages() {
return Arrays.<ReactPackage>asList(
new MainReactPackage(),
new UdpSocketsModule() // <- add here //
);
}
}
```
2015-05-10 14:50:44 +00:00
Buckle up, Dorothy
## Usage
### package.json
_only if you want to write require('dgram') in your javascript_
```json
{
"browser": {
"dgram": "react-native-udp"
}
}
```
### JS
_see/run [index.js](examples/rctsockets) for a complete example, but basically it's just like dgram_
2015-05-10 14:50:44 +00:00
2015-05-10 14:58:41 +00:00
```js
2015-05-10 14:50:44 +00:00
var dgram = require('dgram')
// OR, if not shimming via package.json "browser" field:
2015-11-22 13:01:00 +00:00
// var dgram = require('react-native-udp')
2015-05-10 14:50:44 +00:00
var socket = dgram.createSocket('udp4')
socket.bind(12345)
socket.once('listening', function() {
var buf = toByteArray('excellent!')
socket.send(buf, 0, buf.length, remotePort, remoteHost, function(err) {
if (err) throw err
2015-05-10 14:50:44 +00:00
console.log('message was sent')
})
})
socket.on('message', function(msg, rinfo) {
console.log('message was received', msg)
})
2015-05-10 15:03:52 +00:00
```
2015-05-10 14:50:44 +00:00
### Note
2015-05-10 15:03:52 +00:00
If you want to send and receive node Buffer objects, you'll have to "npm install buffer" and set it as a global for UdpSockets to pick it up:
2015-05-10 14:50:44 +00:00
```js
global.Buffer = global.Buffer || require('buffer').Buffer
```
2015-05-10 14:58:08 +00:00
### TODO
add select tests from node's tests for dgram
2015-05-10 14:50:44 +00:00
## Contributors
2015-05-10 15:03:52 +00:00
[Mark Vayngrib](https://github.com/mvayngrib)
[Ellen Katsnelson](https://github.com/pgmemk)
2015-05-10 14:58:08 +00:00
[Tradle, Inc.](https://github.com/tradle/about/wiki)
[Andy Prock](https://github.com/aprock)
2015-05-11 17:51:52 +00:00
PR's welcome!