forked from JCMais/node-libcurl
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmulti-interface.js
More file actions
101 lines (76 loc) · 3.01 KB
/
multi-interface.js
File metadata and controls
101 lines (76 loc) · 3.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/**
* @author Jonathan Cardoso Machado
* @license MIT
* @copyright 2015, Jonathan Cardoso Machado
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
* of the Software, and to permit persons to whom the Software is furnished to do
* so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
/**
* Example showing how to use the Multi handle to make async requests.
*/
var Curl = require( '../lib/Curl' ),
Easy = require( '../lib/Easy' ),
Multi= require( '../lib/Multi' ),
urls = [
'http://google.com', 'http://bing.com',
'http://msn.com', 'http://ask.com/'
],
multi = new Multi(),
finished = 0,
handles = [],
handlesData = [],
handle;
multi.onMessage(function( err, handle, errCode ) {
var responseCode = handle.getInfo( 'RESPONSE_CODE' ).data,
handleData = handlesData[ handles.indexOf( handle ) ],
handleUrl = urls[ handles.indexOf( handle ) ],
responseData = '',
i, len;
console.log( '# of handles active: ' + multi.getCount() );
if ( err ) {
console.log( handleUrl + ' returned error: ' + err.message );
} else {
for ( i = 0, len = handleData.length; i < len; i++ ) {
responseData += handleData[i].toString();
}
console.log( handleUrl + ' returned response code: ' + responseCode );
console.log( handleUrl + ' returned response body: ' + responseData );
}
multi.removeHandle( handle );
handle.close();
if ( ++finished == urls.length ) {
console.log( 'Finished all requests!' );
multi.close();
}
});
//This callback is like the CURLOPT_WRITEFUNCTION libcurl option.
function onData( data, n, nmemb ) {
//this === the handle, see the .bind( handle ) call below.
var key = handles.indexOf( this );
handlesData[key].push( data );
return n * nmemb;
}
for ( var i = 0, len = urls.length; i < len; i++ ) {
handle = new Easy();
handle.setOpt( 'URL', urls[i] );
handle.setOpt( 'FOLLOWLOCATION', true );
handle.onData = onData.bind( handle );
handlesData.push( [] );
handles.push( handle );
multi.addHandle( handle );
}