no infinite bitfield grow from malicious peers
This commit is contained in:
		
							parent
							
								
									64b42aab47
								
							
						
					
					
						commit
						03798c1c0d
					
				
							
								
								
									
										10
									
								
								index.js
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								index.js
									
									
									
									
									
								
							| @ -4,6 +4,7 @@ var EventEmitter = require('events').EventEmitter | |||||||
| var inherits = require('inherits') | var inherits = require('inherits') | ||||||
| var Rusha = require('rusha-browserify') // Fast SHA1 (works in browser)
 | var Rusha = require('rusha-browserify') // Fast SHA1 (works in browser)
 | ||||||
| 
 | 
 | ||||||
|  | var BITFIELD_GROW = 100000 | ||||||
| var PIECE_LENGTH = 16 * 1024 | var PIECE_LENGTH = 16 * 1024 | ||||||
| 
 | 
 | ||||||
| function sha1 (buf) { | function sha1 (buf) { | ||||||
| @ -23,7 +24,11 @@ module.exports = function (metadata) { | |||||||
|     this._metadataSize = null |     this._metadataSize = null | ||||||
|     this._remainingRejects = null // how many reject messages to tolerate before quitting
 |     this._remainingRejects = null // how many reject messages to tolerate before quitting
 | ||||||
|     this._fetching = false |     this._fetching = false | ||||||
|     this._bitfield = new BitField(0) | 
 | ||||||
|  |     // The largest torrent that I know of (the Geocities archive) is ~641 GB and has
 | ||||||
|  |     // ~41,000 pieces. Therefore, cap the bitfield to 100,000 bits so a malicious peer
 | ||||||
|  |     // can't make it grow to fill all memory.
 | ||||||
|  |     this._bitfield = new BitField(0, { grow: BITFIELD_GROW }) | ||||||
| 
 | 
 | ||||||
|     if (Buffer.isBuffer(metadata)) { |     if (Buffer.isBuffer(metadata)) { | ||||||
|       this._gotMetadata(metadata) |       this._gotMetadata(metadata) | ||||||
| @ -196,7 +201,8 @@ module.exports = function (metadata) { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   ut_metadata.prototype._failedMetadata = function () { |   ut_metadata.prototype._failedMetadata = function () { | ||||||
|     this._bitfield = new BitField(0) // reset bitfield & try again
 |     // reset bitfield & try again
 | ||||||
|  |     this._bitfield = new BitField(0, { grow: BITFIELD_GROW }) | ||||||
|     this._remainingRejects -= this._numPieces |     this._remainingRejects -= this._numPieces | ||||||
|     if (this._remainingRejects > 0) { |     if (this._remainingRejects > 0) { | ||||||
|       this._requestPieces() |       this._requestPieces() | ||||||
|  | |||||||
| @ -11,7 +11,7 @@ | |||||||
|     "url": "https://github.com/feross/ut_metadata/issues" |     "url": "https://github.com/feross/ut_metadata/issues" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "bitfield": "^0.2.0", |     "bitfield": "^1.0.1", | ||||||
|     "bncode": "^0.5.0", |     "bncode": "^0.5.0", | ||||||
|     "inherits": "^2.0.1", |     "inherits": "^2.0.1", | ||||||
|     "rusha-browserify": "^0.7.3" |     "rusha-browserify": "^0.7.3" | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Feross Aboukhadijeh
						Feross Aboukhadijeh