@@ -46,33 +46,31 @@ function Agent(options) {
46
46
47
47
EventEmitter . call ( this ) ;
48
48
49
- var self = this ;
49
+ this . defaultPort = 80 ;
50
+ this . protocol = 'http:' ;
50
51
51
- self . defaultPort = 80 ;
52
- self . protocol = 'http:' ;
53
-
54
- self . options = util . _extend ( { } , options ) ;
52
+ this . options = util . _extend ( { } , options ) ;
55
53
56
54
// don't confuse net and make it think that we're connecting to a pipe
57
- self . options . path = null ;
58
- self . requests = { } ;
59
- self . sockets = { } ;
60
- self . freeSockets = { } ;
61
- self . keepAliveMsecs = self . options . keepAliveMsecs || 1000 ;
62
- self . keepAlive = self . options . keepAlive || false ;
63
- self . maxSockets = self . options . maxSockets || Agent . defaultMaxSockets ;
64
- self . maxFreeSockets = self . options . maxFreeSockets || 256 ;
65
-
66
- self . on ( 'free' , function ( socket , options ) {
67
- var name = self . getName ( options ) ;
55
+ this . options . path = null ;
56
+ this . requests = { } ;
57
+ this . sockets = { } ;
58
+ this . freeSockets = { } ;
59
+ this . keepAliveMsecs = this . options . keepAliveMsecs || 1000 ;
60
+ this . keepAlive = this . options . keepAlive || false ;
61
+ this . maxSockets = this . options . maxSockets || Agent . defaultMaxSockets ;
62
+ this . maxFreeSockets = this . options . maxFreeSockets || 256 ;
63
+
64
+ this . on ( 'free' , ( socket , options ) => {
65
+ var name = this . getName ( options ) ;
68
66
debug ( 'agent.on(free)' , name ) ;
69
67
70
68
if ( socket . writable &&
71
- self . requests [ name ] && self . requests [ name ] . length ) {
72
- self . requests [ name ] . shift ( ) . onSocket ( socket ) ;
73
- if ( self . requests [ name ] . length === 0 ) {
69
+ this . requests [ name ] && this . requests [ name ] . length ) {
70
+ this . requests [ name ] . shift ( ) . onSocket ( socket ) ;
71
+ if ( this . requests [ name ] . length === 0 ) {
74
72
// don't leak
75
- delete self . requests [ name ] ;
73
+ delete this . requests [ name ] ;
76
74
}
77
75
} else {
78
76
// If there are no pending requests, then put it in
@@ -81,21 +79,21 @@ function Agent(options) {
81
79
if ( req &&
82
80
req . shouldKeepAlive &&
83
81
socket . writable &&
84
- self . keepAlive ) {
85
- var freeSockets = self . freeSockets [ name ] ;
82
+ this . keepAlive ) {
83
+ var freeSockets = this . freeSockets [ name ] ;
86
84
var freeLen = freeSockets ? freeSockets . length : 0 ;
87
85
var count = freeLen ;
88
- if ( self . sockets [ name ] )
89
- count += self . sockets [ name ] . length ;
86
+ if ( this . sockets [ name ] )
87
+ count += this . sockets [ name ] . length ;
90
88
91
- if ( count > self . maxSockets || freeLen >= self . maxFreeSockets ) {
89
+ if ( count > this . maxSockets || freeLen >= this . maxFreeSockets ) {
92
90
socket . destroy ( ) ;
93
- } else if ( self . keepSocketAlive ( socket ) ) {
91
+ } else if ( this . keepSocketAlive ( socket ) ) {
94
92
freeSockets = freeSockets || [ ] ;
95
- self . freeSockets [ name ] = freeSockets ;
93
+ this . freeSockets [ name ] = freeSockets ;
96
94
socket [ async_id_symbol ] = - 1 ;
97
95
socket . _httpMessage = null ;
98
- self . removeSocket ( socket , options ) ;
96
+ this . removeSocket ( socket , options ) ;
99
97
freeSockets . push ( socket ) ;
100
98
} else {
101
99
// Implementation doesn't want to keep socket alive
@@ -196,39 +194,39 @@ Agent.prototype.addRequest = function addRequest(req, options, port/*legacy*/,
196
194
} ;
197
195
198
196
Agent . prototype . createSocket = function createSocket ( req , options , cb ) {
199
- var self = this ;
200
197
options = util . _extend ( { } , options ) ;
201
- util . _extend ( options , self . options ) ;
198
+ util . _extend ( options , this . options ) ;
202
199
if ( options . socketPath )
203
200
options . path = options . socketPath ;
204
201
205
202
if ( ! options . servername )
206
203
options . servername = calculateServerName ( options , req ) ;
207
204
208
- var name = self . getName ( options ) ;
205
+ var name = this . getName ( options ) ;
209
206
options . _agentKey = name ;
210
207
211
208
debug ( 'createConnection' , name , options ) ;
212
209
options . encoding = null ;
213
210
var called = false ;
214
- const newSocket = self . createConnection ( options , oncreate ) ;
215
- if ( newSocket )
216
- oncreate ( null , newSocket ) ;
217
211
218
- function oncreate ( err , s ) {
212
+ const oncreate = ( err , s ) => {
219
213
if ( called )
220
214
return ;
221
215
called = true ;
222
216
if ( err )
223
217
return cb ( err ) ;
224
- if ( ! self . sockets [ name ] ) {
225
- self . sockets [ name ] = [ ] ;
218
+ if ( ! this . sockets [ name ] ) {
219
+ this . sockets [ name ] = [ ] ;
226
220
}
227
- self . sockets [ name ] . push ( s ) ;
228
- debug ( 'sockets' , name , self . sockets [ name ] . length ) ;
229
- installListeners ( self , s , options ) ;
221
+ this . sockets [ name ] . push ( s ) ;
222
+ debug ( 'sockets' , name , this . sockets [ name ] . length ) ;
223
+ installListeners ( this , s , options ) ;
230
224
cb ( null , s ) ;
231
- }
225
+ } ;
226
+
227
+ const newSocket = this . createConnection ( options , oncreate ) ;
228
+ if ( newSocket )
229
+ oncreate ( null , newSocket ) ;
232
230
} ;
233
231
234
232
function calculateServerName ( options , req ) {
0 commit comments