| 
									
										
										
										
											2017-04-28 11:29:30 -06:00
										 |  |  | # StreamPair
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | [](http://badge.fury.io/js/socket-pair) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 11:54:08 -06:00
										 |  |  | A pair of coupled Unix sockets (or Windows pipes). | 
					
						
							| 
									
										
										
										
											2017-04-28 11:29:30 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | Similar to `stream-pair`, but with sockets with real fds. A workaround for <https://github.com/nodejs/node/issues/12716>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Usage
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```javascript | 
					
						
							|  |  |  | var socketPair = require('socket-pair'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 11:54:08 -06:00
										 |  |  | socketPair.create(function (err, pair) { | 
					
						
							|  |  |  |   var a = pair.client;      // as in `client = net.connect()` | 
					
						
							|  |  |  |   var b = pair.connection;  // as in `server.on('connection', function (conn) { ... })` | 
					
						
							| 
									
										
										
										
											2017-04-28 11:29:30 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |   a.write('123'); | 
					
						
							|  |  |  |   b.on('data', function (chunk) { | 
					
						
							|  |  |  |     console.log(chunk.toString('utf8')); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   socketPair.closeAll(); | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 11:54:08 -06:00
										 |  |  | I named them `client` and `connection`, but their names really have no meaning. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You can call them `a` and `b` or `other` and `one` or `red` and `blue`. It makes no difference. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 11:29:30 -06:00
										 |  |  | ## API
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | socketPair.create(cb)     // creates or reuses a socket server | 
					
						
							|  |  |  | socketPair.closeAll()     // closes the server and all sockets | 
					
						
							|  |  |  | ``` |