mirror of
https://github.com/status-im/react-native-tcp.git
synced 2025-01-27 18:54:44 +00:00
96 lines
2.0 KiB
JavaScript
96 lines
2.0 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Peel Technologies, Inc.
|
|
* All rights reserved.
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
var React = require('react-native');
|
|
var {
|
|
AppRegistry,
|
|
StyleSheet,
|
|
Text,
|
|
View
|
|
} = React;
|
|
|
|
global.Buffer = global.Buffer || require('buffer').Buffer;
|
|
|
|
var net = require('net');
|
|
|
|
function randomPort() {
|
|
return Math.random() * 60536 | 0 + 5000; // 60536-65536
|
|
}
|
|
|
|
var serverPort = randomPort();
|
|
|
|
var server = net.createServer(function(socket) {
|
|
console.log('server connected on ' + JSON.stringify(socket.address()));
|
|
|
|
socket.on('data', function (data) {
|
|
console.log('Server Received: ' + data);
|
|
socket.write('Echo server\r\n');
|
|
});
|
|
|
|
socket.on('error', function(error) {
|
|
console.log('error ' + error);
|
|
});
|
|
}).listen(serverPort, function() {
|
|
console.log('opened server on ' + JSON.stringify(server.address()));
|
|
});
|
|
|
|
server.on('error', function(error) {
|
|
console.log('error ' + error);
|
|
});
|
|
|
|
var client = net.createConnection(serverPort, function() {
|
|
console.log('opened client on ' + JSON.stringify(client.address()));
|
|
client.write('Hello, server! Love, Client.');
|
|
});
|
|
|
|
client.on('data', function(data) {
|
|
console.log('Client Received: ' + data);
|
|
client.destroy(); // kill client after server's response
|
|
server.close();
|
|
});
|
|
|
|
client.on('error', function(error) {
|
|
console.log('client error ' + error);
|
|
});
|
|
|
|
client.on('close', function() {
|
|
console.log('client close');
|
|
});
|
|
|
|
var rctsockets = React.createClass({
|
|
render: function() {
|
|
return (
|
|
<View style={styles.container}>
|
|
<Text style={styles.welcome}>
|
|
Open Dev Tools to see socket chatter
|
|
</Text>
|
|
</View>
|
|
);
|
|
}
|
|
});
|
|
|
|
var styles = StyleSheet.create({
|
|
container: {
|
|
flex: 1,
|
|
justifyContent: 'center',
|
|
alignItems: 'center',
|
|
backgroundColor: '#F5FCFF',
|
|
},
|
|
welcome: {
|
|
fontSize: 20,
|
|
textAlign: 'center',
|
|
margin: 10,
|
|
},
|
|
instructions: {
|
|
textAlign: 'center',
|
|
color: '#333333',
|
|
marginBottom: 5,
|
|
},
|
|
});
|
|
|
|
AppRegistry.registerComponent('rctsockets', () => rctsockets);
|