mirror of
				https://github.com/therootcompany/request.js.git
				synced 2024-11-16 17:28:58 +00:00 
			
		
		
		
	add unix domain socket support and update README
This commit is contained in:
		
							parent
							
								
									2be278364c
								
							
						
					
					
						commit
						dcc5ba0c7e
					
				
							
								
								
									
										53
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										53
									
								
								README.md
									
									
									
									
									
								
							| @ -21,6 +21,57 @@ request('http://www.google.com', function (error, response, body) { | ||||
| }); | ||||
| ``` | ||||
| 
 | ||||
| ## Table of contents | ||||
| 
 | ||||
| - [Custom HTTP Headers](#custom-http-headers) | ||||
| - [Unix Domain Sockets](#unix-domain-sockets) | ||||
| - [**All Available Options**](#requestoptions-callback) | ||||
| 
 | ||||
| ## Custom HTTP Headers | ||||
| 
 | ||||
| HTTP Headers, such as `User-Agent`, can be set in the `options` object. | ||||
| In the example below, we call the github API to find out the number | ||||
| of stars and forks for the request repository. This requires a | ||||
| custom `User-Agent` header as well as https. | ||||
| 
 | ||||
| ```js | ||||
| var request = require('request'); | ||||
| 
 | ||||
| var options = { | ||||
|   url: 'https://api.github.com/repos/request/request', | ||||
|   headers: { | ||||
|     'User-Agent': 'request' | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| function callback(error, response, body) { | ||||
|   if (!error && response.statusCode == 200) { | ||||
|     var info = JSON.parse(body); | ||||
|     console.log(info.stargazers_count + " Stars"); | ||||
|     console.log(info.forks_count + " Forks"); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| request(options, callback); | ||||
| ``` | ||||
| 
 | ||||
| [back to top](#table-of-contents) | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ## UNIX Domain Sockets | ||||
| 
 | ||||
| `request` supports making requests to [UNIX Domain Sockets](https://en.wikipedia.org/wiki/Unix_domain_socket). To make one, use the following URL scheme: | ||||
| 
 | ||||
| ```js | ||||
| /* Pattern */ 'http://unix:SOCKET:PATH' | ||||
| /* Example */ request.get('http://unix:/absolute/path/to/unix.socket:/request/path') | ||||
| ``` | ||||
| 
 | ||||
| Note: The `SOCKET` path is assumed to be absolute to the root of the host file system. | ||||
| 
 | ||||
| [back to top](#table-of-contents) | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ## request(options, callback) | ||||
| @ -133,3 +184,5 @@ There are at least <!--three--> two ways to debug the operation of `request`: | ||||
| 
 | ||||
| [back to top](#table-of-contents) | ||||
| --> | ||||
| 
 | ||||
| [back to top](#table-of-contents) | ||||
|  | ||||
							
								
								
									
										18
									
								
								index.js
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								index.js
									
									
									
									
									
								
							| @ -102,6 +102,7 @@ function setDefaults(defs) { | ||||
|           if (opts.removeRefererHeader && opts.headers) { | ||||
|             delete opts.headers.referer; | ||||
|           } | ||||
|           // TODO needs baseUrl, maybe test for host / socketPath?
 | ||||
|           opts.url = resp.headers.location; | ||||
|           opts.uri = url.parse(opts.url); | ||||
|           return urequestHelper(opts, cb); | ||||
| @ -206,6 +207,19 @@ function setDefaults(defs) { | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   function parseUrl(str) { | ||||
|     var obj = url.parse(str); | ||||
|     var paths; | ||||
|     if ('unix' !== (obj.hostname||obj.host||'').toLowerCase()) { | ||||
|       return obj; | ||||
|     } | ||||
|     obj.hostname = null; | ||||
|     paths = (obj.pathname||obj.path||'').split(':'); | ||||
|     obj.socketPath = paths.shift(); | ||||
|     obj.pathname = obj.path = paths.join(':'); | ||||
|     obj.href = null; | ||||
|   } | ||||
| 
 | ||||
|   function urequest(opts, cb) { | ||||
|     debug("\n[urequest] received options:"); | ||||
|     debug(opts); | ||||
| @ -231,10 +245,10 @@ function setDefaults(defs) { | ||||
|     if ('string' === typeof opts.url || 'string' === typeof opts.uri) { | ||||
|       if ('string' === typeof opts.url) { | ||||
|         reqOpts.url = opts.url; | ||||
|         reqOpts.uri = url.parse(opts.url); | ||||
|         reqOpts.uri = parseUrl(opts.url); | ||||
|       } else if ('string' === typeof opts.uri) { | ||||
|         reqOpts.url = opts.uri; | ||||
|         reqOpts.uri = url.parse(opts.uri); | ||||
|         reqOpts.uri = parseUrl(opts.uri); | ||||
|       } | ||||
|     } else { | ||||
|       if ('object' === typeof opts.uri) { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user