UNPKG

react-native-tcp-socket

Version:

React Native TCP socket API for Android & iOS with SSL/TLS support

146 lines (132 loc) 3.94 kB
'use strict'; import Server from './Server'; import Socket from './Socket'; import TLSServer from './TLSServer'; import TLSSocket from './TLSSocket'; /** * @typedef {object} ServerOptions * @property {boolean} [noDelay] * @property {boolean} [keepAlive] * @property {number} [keepAliveInitialDelay] * @property {boolean} [allowHalfOpen] * @property {boolean} [pauseOnConnect] */ /** * Creates a new TCP server. * * @param {ServerOptions | ((socket: Socket) => void)} [options] An options object or a connection listener * @param {(socket: Socket) => void} [connectionListener] A listener for the 'connection' event * @returns {Server} */ function createServer(options, connectionListener) { return new Server(options, connectionListener); } /** * @param {import('./TLSServer').TLSServerOptions} options * @param {(socket: TLSSocket) => void} connectionListener * @returns {TLSServer} */ function createTLSServer(options, connectionListener) { const server = new TLSServer(connectionListener); server.setSecureContext(options); return server; } /** * The `callback` function, if specified, will be added as a listener for the `'secureConnect'` event. * * @param {import('./TLSSocket').TLSSocketOptions & import('./Socket').ConnectionOptions} options * @param {() => void} [callback] * @returns {TLSSocket} */ function connectTLS(options, callback) { const socket = new Socket(); const tlsSocket = new TLSSocket(socket, options); socket.once('connect', () => tlsSocket.emit('secureConnect')); if (callback) tlsSocket.once('secureConnect', callback); socket.connect(options); return tlsSocket; } /** * @param {import('./Socket').ConnectionOptions} options * @param {() => void} callback * @returns {Socket} */ function createConnection(options, callback) { const tcpSocket = new Socket(); return tcpSocket.connect(options, callback); } // IPv4 Segment const v4Seg = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'; const v4Str = `(${v4Seg}[.]){3}${v4Seg}`; const IPv4Reg = new RegExp(`^${v4Str}$`); // IPv6 Segment const v6Seg = '(?:[0-9a-fA-F]{1,4})'; const IPv6Reg = new RegExp( '^(' + `(?:${v6Seg}:){7}(?:${v6Seg}|:)|` + `(?:${v6Seg}:){6}(?:${v4Str}|:${v6Seg}|:)|` + `(?:${v6Seg}:){5}(?::${v4Str}|(:${v6Seg}){1,2}|:)|` + `(?:${v6Seg}:){4}(?:(:${v6Seg}){0,1}:${v4Str}|(:${v6Seg}){1,3}|:)|` + `(?:${v6Seg}:){3}(?:(:${v6Seg}){0,2}:${v4Str}|(:${v6Seg}){1,4}|:)|` + `(?:${v6Seg}:){2}(?:(:${v6Seg}){0,3}:${v4Str}|(:${v6Seg}){1,5}|:)|` + `(?:${v6Seg}:){1}(?:(:${v6Seg}){0,4}:${v4Str}|(:${v6Seg}){1,6}|:)|` + `(?::((?::${v6Seg}){0,5}:${v4Str}|(?::${v6Seg}){1,7}|:))` + ')(%[0-9a-zA-Z-.:]{1,})?$' ); /** * Returns `true` if input is a version 4 IP address, otherwise returns `false`. * * @param {string} input */ function isIPv4(input) { return IPv4Reg.test(input); } /** * Returns `true` if input is a version 6 IP address, otherwise returns `false`. * * @param {string} input */ function isIPv6(input) { return IPv6Reg.test(input); } /** * Tests if input is an IP address. Returns `0` for invalid strings, returns `4` for IP version 4 addresses, and returns `6` for IP version 6 addresses. * * @param {string} input */ function isIP(input) { if (isIPv4(input)) return 4; else if (isIPv6(input)) return 6; return 0; } export default { connect: createConnection, createServer, createConnection, createTLSServer, connectTLS, isIP, isIPv4, isIPv6, Server, Socket, TLSServer, TLSSocket, hasIdentity: TLSSocket.hasIdentity, }; // @ts-ignore module.exports = { connect: createConnection, createServer, createConnection, createTLSServer, connectTLS, isIP, isIPv4, isIPv6, Server, Socket, TLSServer, TLSSocket, hasIdentity: TLSSocket.hasIdentity, };