fsevents 1.2.4 → 1.2.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of fsevents might be problematic. Click here for more details.

Files changed (550) hide show
  1. package/.travis.yml +1 -1
  2. package/fsevents.cc +6 -15
  3. package/package.json +2 -2
  4. package/src/async.cc +2 -2
  5. package/src/thread.cc +5 -6
  6. package/build/.target.mk +0 -55
  7. package/build/Makefile +0 -352
  8. package/build/Release/.deps/Release/.node.d +0 -1
  9. package/build/Release/.deps/Release/fse.node.d +0 -1
  10. package/build/Release/.deps/Release/obj.target/action_after_build.stamp.d +0 -1
  11. package/build/Release/.deps/Release/obj.target/fse/fsevents.o.d +0 -67
  12. package/build/Release/.deps/Users/eshanker/Code/fsevents/lib/binding/Release/node-v64-darwin-x64/fse.node.d +0 -1
  13. package/build/Release/.node +0 -0
  14. package/build/Release/fse.node +0 -0
  15. package/build/Release/obj.target/action_after_build.stamp +0 -0
  16. package/build/Release/obj.target/fse/fsevents.o +0 -0
  17. package/build/action_after_build.target.mk +0 -32
  18. package/build/binding.Makefile +0 -6
  19. package/build/fse.target.mk +0 -184
  20. package/build/gyp-mac-tool +0 -611
  21. package/lib/binding/Release/node-v11-darwin-x64/fse.node +0 -0
  22. package/lib/binding/Release/node-v46-darwin-x64/fse.node +0 -0
  23. package/lib/binding/Release/node-v47-darwin-x64/fse.node +0 -0
  24. package/lib/binding/Release/node-v48-darwin-x64/fse.node +0 -0
  25. package/lib/binding/Release/node-v57-darwin-x64/fse.node +0 -0
  26. package/lib/binding/Release/node-v64-darwin-x64/fse.node +0 -0
  27. package/node_modules/abbrev/LICENSE +0 -46
  28. package/node_modules/abbrev/README.md +0 -23
  29. package/node_modules/abbrev/abbrev.js +0 -61
  30. package/node_modules/abbrev/package.json +0 -60
  31. package/node_modules/ansi-regex/index.js +0 -4
  32. package/node_modules/ansi-regex/license +0 -21
  33. package/node_modules/ansi-regex/package.json +0 -111
  34. package/node_modules/ansi-regex/readme.md +0 -39
  35. package/node_modules/aproba/LICENSE +0 -14
  36. package/node_modules/aproba/README.md +0 -94
  37. package/node_modules/aproba/index.js +0 -105
  38. package/node_modules/aproba/package.json +0 -65
  39. package/node_modules/are-we-there-yet/CHANGES.md +0 -31
  40. package/node_modules/are-we-there-yet/CHANGES.md~ +0 -27
  41. package/node_modules/are-we-there-yet/LICENSE +0 -5
  42. package/node_modules/are-we-there-yet/README.md +0 -195
  43. package/node_modules/are-we-there-yet/index.js +0 -4
  44. package/node_modules/are-we-there-yet/package.json +0 -66
  45. package/node_modules/are-we-there-yet/tracker-base.js +0 -11
  46. package/node_modules/are-we-there-yet/tracker-group.js +0 -107
  47. package/node_modules/are-we-there-yet/tracker-stream.js +0 -35
  48. package/node_modules/are-we-there-yet/tracker.js +0 -30
  49. package/node_modules/balanced-match/.npmignore +0 -5
  50. package/node_modules/balanced-match/LICENSE.md +0 -21
  51. package/node_modules/balanced-match/README.md +0 -91
  52. package/node_modules/balanced-match/index.js +0 -59
  53. package/node_modules/balanced-match/package.json +0 -80
  54. package/node_modules/brace-expansion/LICENSE +0 -21
  55. package/node_modules/brace-expansion/README.md +0 -129
  56. package/node_modules/brace-expansion/index.js +0 -201
  57. package/node_modules/brace-expansion/package.json +0 -78
  58. package/node_modules/chownr/LICENSE +0 -15
  59. package/node_modules/chownr/README.md +0 -3
  60. package/node_modules/chownr/chownr.js +0 -52
  61. package/node_modules/chownr/package.json +0 -59
  62. package/node_modules/code-point-at/index.js +0 -32
  63. package/node_modules/code-point-at/license +0 -21
  64. package/node_modules/code-point-at/package.json +0 -73
  65. package/node_modules/code-point-at/readme.md +0 -32
  66. package/node_modules/concat-map/.travis.yml +0 -4
  67. package/node_modules/concat-map/LICENSE +0 -18
  68. package/node_modules/concat-map/README.markdown +0 -62
  69. package/node_modules/concat-map/example/map.js +0 -6
  70. package/node_modules/concat-map/index.js +0 -13
  71. package/node_modules/concat-map/package.json +0 -91
  72. package/node_modules/concat-map/test/map.js +0 -39
  73. package/node_modules/console-control-strings/LICENSE +0 -13
  74. package/node_modules/console-control-strings/README.md +0 -145
  75. package/node_modules/console-control-strings/README.md~ +0 -140
  76. package/node_modules/console-control-strings/index.js +0 -125
  77. package/node_modules/console-control-strings/package.json +0 -64
  78. package/node_modules/core-util-is/LICENSE +0 -19
  79. package/node_modules/core-util-is/README.md +0 -3
  80. package/node_modules/core-util-is/float.patch +0 -604
  81. package/node_modules/core-util-is/lib/util.js +0 -107
  82. package/node_modules/core-util-is/package.json +0 -65
  83. package/node_modules/core-util-is/test.js +0 -68
  84. package/node_modules/debug/.coveralls.yml +0 -1
  85. package/node_modules/debug/.eslintrc +0 -11
  86. package/node_modules/debug/.npmignore +0 -9
  87. package/node_modules/debug/.travis.yml +0 -14
  88. package/node_modules/debug/CHANGELOG.md +0 -362
  89. package/node_modules/debug/LICENSE +0 -19
  90. package/node_modules/debug/Makefile +0 -50
  91. package/node_modules/debug/README.md +0 -312
  92. package/node_modules/debug/component.json +0 -19
  93. package/node_modules/debug/karma.conf.js +0 -70
  94. package/node_modules/debug/node.js +0 -1
  95. package/node_modules/debug/package.json +0 -91
  96. package/node_modules/debug/src/browser.js +0 -185
  97. package/node_modules/debug/src/debug.js +0 -202
  98. package/node_modules/debug/src/index.js +0 -10
  99. package/node_modules/debug/src/inspector-log.js +0 -15
  100. package/node_modules/debug/src/node.js +0 -248
  101. package/node_modules/deep-extend/CHANGELOG.md +0 -38
  102. package/node_modules/deep-extend/LICENSE +0 -20
  103. package/node_modules/deep-extend/README.md +0 -93
  104. package/node_modules/deep-extend/index.js +0 -1
  105. package/node_modules/deep-extend/lib/deep-extend.js +0 -150
  106. package/node_modules/deep-extend/package.json +0 -93
  107. package/node_modules/delegates/.npmignore +0 -1
  108. package/node_modules/delegates/History.md +0 -22
  109. package/node_modules/delegates/License +0 -20
  110. package/node_modules/delegates/Makefile +0 -8
  111. package/node_modules/delegates/Readme.md +0 -94
  112. package/node_modules/delegates/index.js +0 -121
  113. package/node_modules/delegates/package.json +0 -51
  114. package/node_modules/delegates/test/index.js +0 -94
  115. package/node_modules/detect-libc/.npmignore +0 -7
  116. package/node_modules/detect-libc/LICENSE +0 -201
  117. package/node_modules/detect-libc/README.md +0 -78
  118. package/node_modules/detect-libc/bin/detect-libc.js +0 -18
  119. package/node_modules/detect-libc/lib/detect-libc.js +0 -92
  120. package/node_modules/detect-libc/package.json +0 -73
  121. package/node_modules/fs-minipass/LICENSE +0 -15
  122. package/node_modules/fs-minipass/README.md +0 -70
  123. package/node_modules/fs-minipass/index.js +0 -386
  124. package/node_modules/fs-minipass/package.json +0 -65
  125. package/node_modules/fs.realpath/LICENSE +0 -43
  126. package/node_modules/fs.realpath/README.md +0 -33
  127. package/node_modules/fs.realpath/index.js +0 -66
  128. package/node_modules/fs.realpath/old.js +0 -303
  129. package/node_modules/fs.realpath/package.json +0 -62
  130. package/node_modules/gauge/CHANGELOG.md +0 -160
  131. package/node_modules/gauge/LICENSE +0 -13
  132. package/node_modules/gauge/README.md +0 -399
  133. package/node_modules/gauge/base-theme.js +0 -14
  134. package/node_modules/gauge/error.js +0 -24
  135. package/node_modules/gauge/has-color.js +0 -12
  136. package/node_modules/gauge/index.js +0 -233
  137. package/node_modules/gauge/package.json +0 -94
  138. package/node_modules/gauge/plumbing.js +0 -48
  139. package/node_modules/gauge/process.js +0 -3
  140. package/node_modules/gauge/progress-bar.js +0 -35
  141. package/node_modules/gauge/render-template.js +0 -181
  142. package/node_modules/gauge/set-immediate.js +0 -7
  143. package/node_modules/gauge/set-interval.js +0 -3
  144. package/node_modules/gauge/spin.js +0 -5
  145. package/node_modules/gauge/template-item.js +0 -73
  146. package/node_modules/gauge/theme-set.js +0 -115
  147. package/node_modules/gauge/themes.js +0 -54
  148. package/node_modules/gauge/wide-truncate.js +0 -25
  149. package/node_modules/glob/LICENSE +0 -15
  150. package/node_modules/glob/README.md +0 -368
  151. package/node_modules/glob/changelog.md +0 -67
  152. package/node_modules/glob/common.js +0 -240
  153. package/node_modules/glob/glob.js +0 -790
  154. package/node_modules/glob/package.json +0 -79
  155. package/node_modules/glob/sync.js +0 -486
  156. package/node_modules/has-unicode/LICENSE +0 -14
  157. package/node_modules/has-unicode/README.md +0 -43
  158. package/node_modules/has-unicode/index.js +0 -16
  159. package/node_modules/has-unicode/package.json +0 -61
  160. package/node_modules/iconv-lite/.travis.yml +0 -23
  161. package/node_modules/iconv-lite/Changelog.md +0 -146
  162. package/node_modules/iconv-lite/LICENSE +0 -21
  163. package/node_modules/iconv-lite/README.md +0 -156
  164. package/node_modules/iconv-lite/encodings/dbcs-codec.js +0 -555
  165. package/node_modules/iconv-lite/encodings/dbcs-data.js +0 -176
  166. package/node_modules/iconv-lite/encodings/index.js +0 -22
  167. package/node_modules/iconv-lite/encodings/internal.js +0 -188
  168. package/node_modules/iconv-lite/encodings/sbcs-codec.js +0 -72
  169. package/node_modules/iconv-lite/encodings/sbcs-data-generated.js +0 -451
  170. package/node_modules/iconv-lite/encodings/sbcs-data.js +0 -169
  171. package/node_modules/iconv-lite/encodings/tables/big5-added.json +0 -122
  172. package/node_modules/iconv-lite/encodings/tables/cp936.json +0 -264
  173. package/node_modules/iconv-lite/encodings/tables/cp949.json +0 -273
  174. package/node_modules/iconv-lite/encodings/tables/cp950.json +0 -177
  175. package/node_modules/iconv-lite/encodings/tables/eucjp.json +0 -182
  176. package/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +0 -1
  177. package/node_modules/iconv-lite/encodings/tables/gbk-added.json +0 -55
  178. package/node_modules/iconv-lite/encodings/tables/shiftjis.json +0 -125
  179. package/node_modules/iconv-lite/encodings/utf16.js +0 -177
  180. package/node_modules/iconv-lite/encodings/utf7.js +0 -290
  181. package/node_modules/iconv-lite/lib/bom-handling.js +0 -52
  182. package/node_modules/iconv-lite/lib/extend-node.js +0 -217
  183. package/node_modules/iconv-lite/lib/index.d.ts +0 -24
  184. package/node_modules/iconv-lite/lib/index.js +0 -153
  185. package/node_modules/iconv-lite/lib/streams.js +0 -121
  186. package/node_modules/iconv-lite/package.json +0 -79
  187. package/node_modules/ignore-walk/LICENSE +0 -15
  188. package/node_modules/ignore-walk/README.md +0 -60
  189. package/node_modules/ignore-walk/index.js +0 -265
  190. package/node_modules/ignore-walk/package.json +0 -74
  191. package/node_modules/inflight/LICENSE +0 -15
  192. package/node_modules/inflight/README.md +0 -37
  193. package/node_modules/inflight/inflight.js +0 -54
  194. package/node_modules/inflight/package.json +0 -61
  195. package/node_modules/inherits/LICENSE +0 -16
  196. package/node_modules/inherits/README.md +0 -42
  197. package/node_modules/inherits/inherits.js +0 -7
  198. package/node_modules/inherits/inherits_browser.js +0 -23
  199. package/node_modules/inherits/package.json +0 -67
  200. package/node_modules/ini/LICENSE +0 -15
  201. package/node_modules/ini/README.md +0 -102
  202. package/node_modules/ini/ini.js +0 -194
  203. package/node_modules/ini/package.json +0 -66
  204. package/node_modules/is-fullwidth-code-point/index.js +0 -46
  205. package/node_modules/is-fullwidth-code-point/license +0 -21
  206. package/node_modules/is-fullwidth-code-point/package.json +0 -80
  207. package/node_modules/is-fullwidth-code-point/readme.md +0 -39
  208. package/node_modules/isarray/.npmignore +0 -1
  209. package/node_modules/isarray/.travis.yml +0 -4
  210. package/node_modules/isarray/Makefile +0 -6
  211. package/node_modules/isarray/README.md +0 -60
  212. package/node_modules/isarray/component.json +0 -19
  213. package/node_modules/isarray/index.js +0 -5
  214. package/node_modules/isarray/package.json +0 -76
  215. package/node_modules/isarray/test.js +0 -20
  216. package/node_modules/minimatch/LICENSE +0 -15
  217. package/node_modules/minimatch/README.md +0 -209
  218. package/node_modules/minimatch/minimatch.js +0 -923
  219. package/node_modules/minimatch/package.json +0 -67
  220. package/node_modules/minimist/.travis.yml +0 -4
  221. package/node_modules/minimist/LICENSE +0 -18
  222. package/node_modules/minimist/example/parse.js +0 -2
  223. package/node_modules/minimist/index.js +0 -187
  224. package/node_modules/minimist/package.json +0 -74
  225. package/node_modules/minimist/readme.markdown +0 -73
  226. package/node_modules/minimist/test/dash.js +0 -24
  227. package/node_modules/minimist/test/default_bool.js +0 -20
  228. package/node_modules/minimist/test/dotted.js +0 -16
  229. package/node_modules/minimist/test/long.js +0 -31
  230. package/node_modules/minimist/test/parse.js +0 -318
  231. package/node_modules/minimist/test/parse_modified.js +0 -9
  232. package/node_modules/minimist/test/short.js +0 -67
  233. package/node_modules/minimist/test/whitespace.js +0 -8
  234. package/node_modules/minipass/README.md +0 -46
  235. package/node_modules/minipass/index.js +0 -304
  236. package/node_modules/minipass/package.json +0 -72
  237. package/node_modules/minizlib/LICENSE +0 -26
  238. package/node_modules/minizlib/README.md +0 -44
  239. package/node_modules/minizlib/constants.js +0 -46
  240. package/node_modules/minizlib/index.js +0 -364
  241. package/node_modules/minizlib/package.json +0 -74
  242. package/node_modules/mkdirp/.travis.yml +0 -8
  243. package/node_modules/mkdirp/LICENSE +0 -21
  244. package/node_modules/mkdirp/bin/cmd.js +0 -33
  245. package/node_modules/mkdirp/bin/usage.txt +0 -12
  246. package/node_modules/mkdirp/examples/pow.js +0 -6
  247. package/node_modules/mkdirp/index.js +0 -98
  248. package/node_modules/mkdirp/package.json +0 -67
  249. package/node_modules/mkdirp/readme.markdown +0 -100
  250. package/node_modules/mkdirp/test/chmod.js +0 -41
  251. package/node_modules/mkdirp/test/clobber.js +0 -38
  252. package/node_modules/mkdirp/test/mkdirp.js +0 -28
  253. package/node_modules/mkdirp/test/opts_fs.js +0 -29
  254. package/node_modules/mkdirp/test/opts_fs_sync.js +0 -27
  255. package/node_modules/mkdirp/test/perm.js +0 -32
  256. package/node_modules/mkdirp/test/perm_sync.js +0 -36
  257. package/node_modules/mkdirp/test/race.js +0 -37
  258. package/node_modules/mkdirp/test/rel.js +0 -32
  259. package/node_modules/mkdirp/test/return.js +0 -25
  260. package/node_modules/mkdirp/test/return_sync.js +0 -24
  261. package/node_modules/mkdirp/test/root.js +0 -19
  262. package/node_modules/mkdirp/test/sync.js +0 -32
  263. package/node_modules/mkdirp/test/umask.js +0 -28
  264. package/node_modules/mkdirp/test/umask_sync.js +0 -32
  265. package/node_modules/ms/index.js +0 -152
  266. package/node_modules/ms/license.md +0 -21
  267. package/node_modules/ms/package.json +0 -72
  268. package/node_modules/ms/readme.md +0 -51
  269. package/node_modules/needle/README.md +0 -593
  270. package/node_modules/needle/bin/needle +0 -40
  271. package/node_modules/needle/examples/deflated-stream.js +0 -22
  272. package/node_modules/needle/examples/digest-auth.js +0 -16
  273. package/node_modules/needle/examples/download-to-file.js +0 -18
  274. package/node_modules/needle/examples/multipart-stream.js +0 -25
  275. package/node_modules/needle/examples/parsed-stream.js +0 -23
  276. package/node_modules/needle/examples/parsed-stream2.js +0 -21
  277. package/node_modules/needle/examples/stream-events.js +0 -23
  278. package/node_modules/needle/examples/stream-to-file.js +0 -14
  279. package/node_modules/needle/examples/upload-image.js +0 -51
  280. package/node_modules/needle/lib/auth.js +0 -110
  281. package/node_modules/needle/lib/cookies.js +0 -77
  282. package/node_modules/needle/lib/decoder.js +0 -53
  283. package/node_modules/needle/lib/multipart.js +0 -98
  284. package/node_modules/needle/lib/needle.js +0 -783
  285. package/node_modules/needle/lib/parsers.js +0 -120
  286. package/node_modules/needle/lib/querystring.js +0 -49
  287. package/node_modules/needle/license.txt +0 -19
  288. package/node_modules/needle/package.json +0 -105
  289. package/node_modules/needle/test/basic_auth_spec.js +0 -196
  290. package/node_modules/needle/test/compression_spec.js +0 -94
  291. package/node_modules/needle/test/cookies_spec.js +0 -305
  292. package/node_modules/needle/test/decoder_spec.js +0 -86
  293. package/node_modules/needle/test/errors_spec.js +0 -286
  294. package/node_modules/needle/test/headers_spec.js +0 -198
  295. package/node_modules/needle/test/helpers.js +0 -72
  296. package/node_modules/needle/test/long_string_spec.js +0 -34
  297. package/node_modules/needle/test/output_spec.js +0 -254
  298. package/node_modules/needle/test/parsing_spec.js +0 -494
  299. package/node_modules/needle/test/post_data_spec.js +0 -1021
  300. package/node_modules/needle/test/proxy_spec.js +0 -202
  301. package/node_modules/needle/test/querystring_spec.js +0 -128
  302. package/node_modules/needle/test/redirect_spec.js +0 -392
  303. package/node_modules/needle/test/redirect_with_timeout.js +0 -45
  304. package/node_modules/needle/test/request_stream_spec.js +0 -202
  305. package/node_modules/needle/test/response_stream_spec.js +0 -139
  306. package/node_modules/needle/test/socket_pool_spec.js +0 -66
  307. package/node_modules/needle/test/url_spec.js +0 -147
  308. package/node_modules/needle/test/utils/formidable.js +0 -17
  309. package/node_modules/needle/test/utils/proxy.js +0 -62
  310. package/node_modules/needle/test/utils/test.js +0 -104
  311. package/node_modules/node-pre-gyp/CHANGELOG.md +0 -409
  312. package/node_modules/node-pre-gyp/LICENSE +0 -27
  313. package/node_modules/node-pre-gyp/README.md +0 -661
  314. package/node_modules/node-pre-gyp/appveyor.yml +0 -32
  315. package/node_modules/node-pre-gyp/bin/node-pre-gyp +0 -134
  316. package/node_modules/node-pre-gyp/bin/node-pre-gyp.cmd +0 -2
  317. package/node_modules/node-pre-gyp/contributing.md +0 -10
  318. package/node_modules/node-pre-gyp/lib/build.js +0 -51
  319. package/node_modules/node-pre-gyp/lib/clean.js +0 -32
  320. package/node_modules/node-pre-gyp/lib/configure.js +0 -52
  321. package/node_modules/node-pre-gyp/lib/info.js +0 -40
  322. package/node_modules/node-pre-gyp/lib/install.js +0 -221
  323. package/node_modules/node-pre-gyp/lib/node-pre-gyp.js +0 -203
  324. package/node_modules/node-pre-gyp/lib/package.js +0 -56
  325. package/node_modules/node-pre-gyp/lib/pre-binding.js +0 -30
  326. package/node_modules/node-pre-gyp/lib/publish.js +0 -79
  327. package/node_modules/node-pre-gyp/lib/rebuild.js +0 -21
  328. package/node_modules/node-pre-gyp/lib/reinstall.js +0 -20
  329. package/node_modules/node-pre-gyp/lib/reveal.js +0 -33
  330. package/node_modules/node-pre-gyp/lib/testbinary.js +0 -81
  331. package/node_modules/node-pre-gyp/lib/testpackage.js +0 -55
  332. package/node_modules/node-pre-gyp/lib/unpublish.js +0 -43
  333. package/node_modules/node-pre-gyp/lib/util/abi_crosswalk.json +0 -1734
  334. package/node_modules/node-pre-gyp/lib/util/compile.js +0 -87
  335. package/node_modules/node-pre-gyp/lib/util/handle_gyp_opts.js +0 -100
  336. package/node_modules/node-pre-gyp/lib/util/napi.js +0 -156
  337. package/node_modules/node-pre-gyp/lib/util/nw-pre-gyp/index.html +0 -26
  338. package/node_modules/node-pre-gyp/lib/util/nw-pre-gyp/package.json +0 -9
  339. package/node_modules/node-pre-gyp/lib/util/s3_setup.js +0 -27
  340. package/node_modules/node-pre-gyp/lib/util/versioning.js +0 -330
  341. package/node_modules/node-pre-gyp/package.json +0 -87
  342. package/node_modules/nopt/.npmignore +0 -1
  343. package/node_modules/nopt/.travis.yml +0 -8
  344. package/node_modules/nopt/CHANGELOG.md +0 -58
  345. package/node_modules/nopt/LICENSE +0 -15
  346. package/node_modules/nopt/README.md +0 -213
  347. package/node_modules/nopt/bin/nopt.js +0 -54
  348. package/node_modules/nopt/examples/my-program.js +0 -30
  349. package/node_modules/nopt/lib/nopt.js +0 -436
  350. package/node_modules/nopt/package.json +0 -61
  351. package/node_modules/nopt/test/basic.js +0 -303
  352. package/node_modules/npm-bundled/README.md +0 -46
  353. package/node_modules/npm-bundled/index.js +0 -227
  354. package/node_modules/npm-bundled/package.json +0 -63
  355. package/node_modules/npm-packlist/LICENSE +0 -15
  356. package/node_modules/npm-packlist/README.md +0 -68
  357. package/node_modules/npm-packlist/index.js +0 -220
  358. package/node_modules/npm-packlist/package.json +0 -69
  359. package/node_modules/npmlog/CHANGELOG.md +0 -49
  360. package/node_modules/npmlog/LICENSE +0 -15
  361. package/node_modules/npmlog/README.md +0 -216
  362. package/node_modules/npmlog/log.js +0 -309
  363. package/node_modules/npmlog/package.json +0 -64
  364. package/node_modules/number-is-nan/index.js +0 -4
  365. package/node_modules/number-is-nan/license +0 -21
  366. package/node_modules/number-is-nan/package.json +0 -70
  367. package/node_modules/number-is-nan/readme.md +0 -28
  368. package/node_modules/object-assign/index.js +0 -90
  369. package/node_modules/object-assign/license +0 -21
  370. package/node_modules/object-assign/package.json +0 -77
  371. package/node_modules/object-assign/readme.md +0 -61
  372. package/node_modules/once/LICENSE +0 -15
  373. package/node_modules/once/README.md +0 -79
  374. package/node_modules/once/once.js +0 -42
  375. package/node_modules/once/package.json +0 -70
  376. package/node_modules/os-homedir/index.js +0 -24
  377. package/node_modules/os-homedir/license +0 -21
  378. package/node_modules/os-homedir/package.json +0 -76
  379. package/node_modules/os-homedir/readme.md +0 -31
  380. package/node_modules/os-tmpdir/index.js +0 -25
  381. package/node_modules/os-tmpdir/license +0 -21
  382. package/node_modules/os-tmpdir/package.json +0 -76
  383. package/node_modules/os-tmpdir/readme.md +0 -32
  384. package/node_modules/osenv/LICENSE +0 -15
  385. package/node_modules/osenv/README.md +0 -63
  386. package/node_modules/osenv/osenv.js +0 -72
  387. package/node_modules/osenv/package.json +0 -76
  388. package/node_modules/path-is-absolute/index.js +0 -20
  389. package/node_modules/path-is-absolute/license +0 -21
  390. package/node_modules/path-is-absolute/package.json +0 -78
  391. package/node_modules/path-is-absolute/readme.md +0 -59
  392. package/node_modules/process-nextick-args/index.js +0 -44
  393. package/node_modules/process-nextick-args/license.md +0 -19
  394. package/node_modules/process-nextick-args/package.json +0 -53
  395. package/node_modules/process-nextick-args/readme.md +0 -18
  396. package/node_modules/rc/LICENSE.APACHE2 +0 -15
  397. package/node_modules/rc/LICENSE.BSD +0 -26
  398. package/node_modules/rc/LICENSE.MIT +0 -24
  399. package/node_modules/rc/README.md +0 -227
  400. package/node_modules/rc/browser.js +0 -7
  401. package/node_modules/rc/cli.js +0 -4
  402. package/node_modules/rc/index.js +0 -53
  403. package/node_modules/rc/lib/utils.js +0 -104
  404. package/node_modules/rc/node_modules/minimist/.travis.yml +0 -8
  405. package/node_modules/rc/node_modules/minimist/LICENSE +0 -18
  406. package/node_modules/rc/node_modules/minimist/example/parse.js +0 -2
  407. package/node_modules/rc/node_modules/minimist/index.js +0 -236
  408. package/node_modules/rc/node_modules/minimist/package.json +0 -76
  409. package/node_modules/rc/node_modules/minimist/readme.markdown +0 -91
  410. package/node_modules/rc/node_modules/minimist/test/all_bool.js +0 -32
  411. package/node_modules/rc/node_modules/minimist/test/bool.js +0 -166
  412. package/node_modules/rc/node_modules/minimist/test/dash.js +0 -31
  413. package/node_modules/rc/node_modules/minimist/test/default_bool.js +0 -35
  414. package/node_modules/rc/node_modules/minimist/test/dotted.js +0 -22
  415. package/node_modules/rc/node_modules/minimist/test/kv_short.js +0 -16
  416. package/node_modules/rc/node_modules/minimist/test/long.js +0 -31
  417. package/node_modules/rc/node_modules/minimist/test/num.js +0 -36
  418. package/node_modules/rc/node_modules/minimist/test/parse.js +0 -197
  419. package/node_modules/rc/node_modules/minimist/test/parse_modified.js +0 -9
  420. package/node_modules/rc/node_modules/minimist/test/short.js +0 -67
  421. package/node_modules/rc/node_modules/minimist/test/stop_early.js +0 -15
  422. package/node_modules/rc/node_modules/minimist/test/unknown.js +0 -102
  423. package/node_modules/rc/node_modules/minimist/test/whitespace.js +0 -8
  424. package/node_modules/rc/package.json +0 -66
  425. package/node_modules/rc/test/ini.js +0 -16
  426. package/node_modules/rc/test/nested-env-vars.js +0 -50
  427. package/node_modules/rc/test/test.js +0 -59
  428. package/node_modules/readable-stream/.travis.yml +0 -55
  429. package/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  430. package/node_modules/readable-stream/GOVERNANCE.md +0 -136
  431. package/node_modules/readable-stream/LICENSE +0 -47
  432. package/node_modules/readable-stream/README.md +0 -58
  433. package/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +0 -60
  434. package/node_modules/readable-stream/duplex-browser.js +0 -1
  435. package/node_modules/readable-stream/duplex.js +0 -1
  436. package/node_modules/readable-stream/lib/_stream_duplex.js +0 -131
  437. package/node_modules/readable-stream/lib/_stream_passthrough.js +0 -47
  438. package/node_modules/readable-stream/lib/_stream_readable.js +0 -1019
  439. package/node_modules/readable-stream/lib/_stream_transform.js +0 -214
  440. package/node_modules/readable-stream/lib/_stream_writable.js +0 -687
  441. package/node_modules/readable-stream/lib/internal/streams/BufferList.js +0 -79
  442. package/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -74
  443. package/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  444. package/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  445. package/node_modules/readable-stream/package.json +0 -84
  446. package/node_modules/readable-stream/passthrough.js +0 -1
  447. package/node_modules/readable-stream/readable-browser.js +0 -7
  448. package/node_modules/readable-stream/readable.js +0 -19
  449. package/node_modules/readable-stream/transform.js +0 -1
  450. package/node_modules/readable-stream/writable-browser.js +0 -1
  451. package/node_modules/readable-stream/writable.js +0 -8
  452. package/node_modules/rimraf/LICENSE +0 -15
  453. package/node_modules/rimraf/README.md +0 -101
  454. package/node_modules/rimraf/bin.js +0 -50
  455. package/node_modules/rimraf/package.json +0 -67
  456. package/node_modules/rimraf/rimraf.js +0 -364
  457. package/node_modules/safe-buffer/.travis.yml +0 -7
  458. package/node_modules/safe-buffer/LICENSE +0 -21
  459. package/node_modules/safe-buffer/README.md +0 -584
  460. package/node_modules/safe-buffer/index.js +0 -62
  461. package/node_modules/safe-buffer/package.json +0 -68
  462. package/node_modules/safe-buffer/test.js +0 -101
  463. package/node_modules/safer-buffer/LICENSE +0 -21
  464. package/node_modules/safer-buffer/Porting-Buffer.md +0 -268
  465. package/node_modules/safer-buffer/Readme.md +0 -156
  466. package/node_modules/safer-buffer/dangerous.js +0 -58
  467. package/node_modules/safer-buffer/package.json +0 -63
  468. package/node_modules/safer-buffer/safer.js +0 -77
  469. package/node_modules/safer-buffer/tests.js +0 -406
  470. package/node_modules/sax/LICENSE +0 -41
  471. package/node_modules/sax/README.md +0 -225
  472. package/node_modules/sax/lib/sax.js +0 -1565
  473. package/node_modules/sax/package.json +0 -64
  474. package/node_modules/semver/LICENSE +0 -15
  475. package/node_modules/semver/README.md +0 -388
  476. package/node_modules/semver/bin/semver +0 -143
  477. package/node_modules/semver/package.json +0 -57
  478. package/node_modules/semver/range.bnf +0 -16
  479. package/node_modules/semver/semver.js +0 -1324
  480. package/node_modules/set-blocking/CHANGELOG.md +0 -26
  481. package/node_modules/set-blocking/LICENSE.txt +0 -14
  482. package/node_modules/set-blocking/README.md +0 -31
  483. package/node_modules/set-blocking/index.js +0 -7
  484. package/node_modules/set-blocking/package.json +0 -73
  485. package/node_modules/signal-exit/CHANGELOG.md +0 -27
  486. package/node_modules/signal-exit/LICENSE.txt +0 -16
  487. package/node_modules/signal-exit/README.md +0 -40
  488. package/node_modules/signal-exit/index.js +0 -157
  489. package/node_modules/signal-exit/package.json +0 -69
  490. package/node_modules/signal-exit/signals.js +0 -53
  491. package/node_modules/string-width/index.js +0 -37
  492. package/node_modules/string-width/license +0 -21
  493. package/node_modules/string-width/package.json +0 -92
  494. package/node_modules/string-width/readme.md +0 -42
  495. package/node_modules/string_decoder/.travis.yml +0 -50
  496. package/node_modules/string_decoder/LICENSE +0 -48
  497. package/node_modules/string_decoder/README.md +0 -47
  498. package/node_modules/string_decoder/lib/string_decoder.js +0 -296
  499. package/node_modules/string_decoder/package.json +0 -62
  500. package/node_modules/strip-ansi/index.js +0 -6
  501. package/node_modules/strip-ansi/license +0 -21
  502. package/node_modules/strip-ansi/package.json +0 -105
  503. package/node_modules/strip-ansi/readme.md +0 -33
  504. package/node_modules/strip-json-comments/index.js +0 -70
  505. package/node_modules/strip-json-comments/license +0 -21
  506. package/node_modules/strip-json-comments/package.json +0 -77
  507. package/node_modules/strip-json-comments/readme.md +0 -64
  508. package/node_modules/tar/LICENSE +0 -15
  509. package/node_modules/tar/README.md +0 -949
  510. package/node_modules/tar/index.js +0 -18
  511. package/node_modules/tar/lib/buffer.js +0 -11
  512. package/node_modules/tar/lib/create.js +0 -105
  513. package/node_modules/tar/lib/extract.js +0 -112
  514. package/node_modules/tar/lib/header.js +0 -273
  515. package/node_modules/tar/lib/high-level-opt.js +0 -29
  516. package/node_modules/tar/lib/large-numbers.js +0 -92
  517. package/node_modules/tar/lib/list.js +0 -130
  518. package/node_modules/tar/lib/mkdir.js +0 -206
  519. package/node_modules/tar/lib/pack.js +0 -403
  520. package/node_modules/tar/lib/parse.js +0 -422
  521. package/node_modules/tar/lib/pax.js +0 -146
  522. package/node_modules/tar/lib/read-entry.js +0 -94
  523. package/node_modules/tar/lib/replace.js +0 -220
  524. package/node_modules/tar/lib/types.js +0 -44
  525. package/node_modules/tar/lib/unpack.js +0 -560
  526. package/node_modules/tar/lib/update.js +0 -36
  527. package/node_modules/tar/lib/warn-mixin.js +0 -14
  528. package/node_modules/tar/lib/winchars.js +0 -23
  529. package/node_modules/tar/lib/write-entry.js +0 -403
  530. package/node_modules/tar/package.json +0 -81
  531. package/node_modules/util-deprecate/History.md +0 -16
  532. package/node_modules/util-deprecate/LICENSE +0 -24
  533. package/node_modules/util-deprecate/README.md +0 -53
  534. package/node_modules/util-deprecate/browser.js +0 -67
  535. package/node_modules/util-deprecate/node.js +0 -6
  536. package/node_modules/util-deprecate/package.json +0 -59
  537. package/node_modules/wide-align/LICENSE +0 -14
  538. package/node_modules/wide-align/README.md +0 -47
  539. package/node_modules/wide-align/align.js +0 -65
  540. package/node_modules/wide-align/package.json +0 -69
  541. package/node_modules/wrappy/LICENSE +0 -15
  542. package/node_modules/wrappy/README.md +0 -36
  543. package/node_modules/wrappy/package.json +0 -62
  544. package/node_modules/wrappy/wrappy.js +0 -33
  545. package/node_modules/yallist/LICENSE +0 -15
  546. package/node_modules/yallist/README.md +0 -204
  547. package/node_modules/yallist/iterator.js +0 -8
  548. package/node_modules/yallist/package.json +0 -66
  549. package/node_modules/yallist/yallist.js +0 -376
  550. package/src/locking.cc +0 -27
@@ -1,68 +0,0 @@
1
- {
2
- "_args": [
3
- [
4
- "safe-buffer@5.1.1",
5
- "/Users/eshanker/Code/fsevents"
6
- ]
7
- ],
8
- "_from": "safe-buffer@5.1.1",
9
- "_id": "safe-buffer@5.1.1",
10
- "_inBundle": false,
11
- "_integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==",
12
- "_location": "/safe-buffer",
13
- "_phantomChildren": {},
14
- "_requested": {
15
- "type": "version",
16
- "registry": true,
17
- "raw": "safe-buffer@5.1.1",
18
- "name": "safe-buffer",
19
- "escapedName": "safe-buffer",
20
- "rawSpec": "5.1.1",
21
- "saveSpec": null,
22
- "fetchSpec": "5.1.1"
23
- },
24
- "_requiredBy": [
25
- "/minipass",
26
- "/readable-stream",
27
- "/string_decoder",
28
- "/tar"
29
- ],
30
- "_resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz",
31
- "_spec": "5.1.1",
32
- "_where": "/Users/eshanker/Code/fsevents",
33
- "author": {
34
- "name": "Feross Aboukhadijeh",
35
- "email": "feross@feross.org",
36
- "url": "http://feross.org"
37
- },
38
- "bugs": {
39
- "url": "https://github.com/feross/safe-buffer/issues"
40
- },
41
- "description": "Safer Node.js Buffer API",
42
- "devDependencies": {
43
- "standard": "*",
44
- "tape": "^4.0.0",
45
- "zuul": "^3.0.0"
46
- },
47
- "homepage": "https://github.com/feross/safe-buffer",
48
- "keywords": [
49
- "buffer",
50
- "buffer allocate",
51
- "node security",
52
- "safe",
53
- "safe-buffer",
54
- "security",
55
- "uninitialized"
56
- ],
57
- "license": "MIT",
58
- "main": "index.js",
59
- "name": "safe-buffer",
60
- "repository": {
61
- "type": "git",
62
- "url": "git://github.com/feross/safe-buffer.git"
63
- },
64
- "scripts": {
65
- "test": "standard && tape test.js"
66
- },
67
- "version": "5.1.1"
68
- }
@@ -1,101 +0,0 @@
1
- /* eslint-disable node/no-deprecated-api */
2
-
3
- var test = require('tape')
4
- var SafeBuffer = require('./').Buffer
5
-
6
- test('new SafeBuffer(value) works just like Buffer', function (t) {
7
- t.deepEqual(new SafeBuffer('hey'), new Buffer('hey'))
8
- t.deepEqual(new SafeBuffer('hey', 'utf8'), new Buffer('hey', 'utf8'))
9
- t.deepEqual(new SafeBuffer('686579', 'hex'), new Buffer('686579', 'hex'))
10
- t.deepEqual(new SafeBuffer([1, 2, 3]), new Buffer([1, 2, 3]))
11
- t.deepEqual(new SafeBuffer(new Uint8Array([1, 2, 3])), new Buffer(new Uint8Array([1, 2, 3])))
12
-
13
- t.equal(typeof SafeBuffer.isBuffer, 'function')
14
- t.equal(SafeBuffer.isBuffer(new SafeBuffer('hey')), true)
15
- t.equal(Buffer.isBuffer(new SafeBuffer('hey')), true)
16
- t.notOk(SafeBuffer.isBuffer({}))
17
-
18
- t.end()
19
- })
20
-
21
- test('SafeBuffer.from(value) converts to a Buffer', function (t) {
22
- t.deepEqual(SafeBuffer.from('hey'), new Buffer('hey'))
23
- t.deepEqual(SafeBuffer.from('hey', 'utf8'), new Buffer('hey', 'utf8'))
24
- t.deepEqual(SafeBuffer.from('686579', 'hex'), new Buffer('686579', 'hex'))
25
- t.deepEqual(SafeBuffer.from([1, 2, 3]), new Buffer([1, 2, 3]))
26
- t.deepEqual(SafeBuffer.from(new Uint8Array([1, 2, 3])), new Buffer(new Uint8Array([1, 2, 3])))
27
-
28
- t.end()
29
- })
30
-
31
- test('SafeBuffer.alloc(number) returns zeroed-out memory', function (t) {
32
- for (var i = 0; i < 10; i++) {
33
- var expected1 = new Buffer(1000)
34
- expected1.fill(0)
35
- t.deepEqual(SafeBuffer.alloc(1000), expected1)
36
-
37
- var expected2 = new Buffer(1000 * 1000)
38
- expected2.fill(0)
39
- t.deepEqual(SafeBuffer.alloc(1000 * 1000), expected2)
40
- }
41
- t.end()
42
- })
43
-
44
- test('SafeBuffer.allocUnsafe(number)', function (t) {
45
- var buf = SafeBuffer.allocUnsafe(100) // unitialized memory
46
- t.equal(buf.length, 100)
47
- t.equal(SafeBuffer.isBuffer(buf), true)
48
- t.equal(Buffer.isBuffer(buf), true)
49
- t.end()
50
- })
51
-
52
- test('SafeBuffer.from() throws with number types', function (t) {
53
- t.plan(5)
54
- t.throws(function () {
55
- SafeBuffer.from(0)
56
- })
57
- t.throws(function () {
58
- SafeBuffer.from(-1)
59
- })
60
- t.throws(function () {
61
- SafeBuffer.from(NaN)
62
- })
63
- t.throws(function () {
64
- SafeBuffer.from(Infinity)
65
- })
66
- t.throws(function () {
67
- SafeBuffer.from(99)
68
- })
69
- })
70
-
71
- test('SafeBuffer.allocUnsafe() throws with non-number types', function (t) {
72
- t.plan(4)
73
- t.throws(function () {
74
- SafeBuffer.allocUnsafe('hey')
75
- })
76
- t.throws(function () {
77
- SafeBuffer.allocUnsafe('hey', 'utf8')
78
- })
79
- t.throws(function () {
80
- SafeBuffer.allocUnsafe([1, 2, 3])
81
- })
82
- t.throws(function () {
83
- SafeBuffer.allocUnsafe({})
84
- })
85
- })
86
-
87
- test('SafeBuffer.alloc() throws with non-number types', function (t) {
88
- t.plan(4)
89
- t.throws(function () {
90
- SafeBuffer.alloc('hey')
91
- })
92
- t.throws(function () {
93
- SafeBuffer.alloc('hey', 'utf8')
94
- })
95
- t.throws(function () {
96
- SafeBuffer.alloc([1, 2, 3])
97
- })
98
- t.throws(function () {
99
- SafeBuffer.alloc({})
100
- })
101
- })
@@ -1,21 +0,0 @@
1
- MIT License
2
-
3
- Copyright (c) 2018 Nikita Skovoroda <chalkerx@gmail.com>
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining a copy
6
- of this software and associated documentation files (the "Software"), to deal
7
- in the Software without restriction, including without limitation the rights
8
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- copies of the Software, and to permit persons to whom the Software is
10
- furnished to do so, subject to the following conditions:
11
-
12
- The above copyright notice and this permission notice shall be included in all
13
- copies or substantial portions of the Software.
14
-
15
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- SOFTWARE.
@@ -1,268 +0,0 @@
1
- # Porting to the Buffer.from/Buffer.alloc API
2
-
3
- <a id="overview"></a>
4
- ## Overview
5
-
6
- - [Variant 1: Drop support for Node.js ≤ 4.4.x and 5.0.0 — 5.9.x.](#variant-1) (*recommended*)
7
- - [Variant 2: Use a polyfill](#variant-2)
8
- - [Variant 3: manual detection, with safeguards](#variant-3)
9
-
10
- ### Finding problematic bits of code using grep
11
-
12
- Just run `grep -nrE '[^a-zA-Z](Slow)?Buffer\s*\(' --exclude-dir node_modules`.
13
-
14
- It will find all the potentially unsafe places in your own code (with some considerably unlikely
15
- exceptions).
16
-
17
- ### Finding problematic bits of code using Node.js 8
18
-
19
- If you’re using Node.js ≥ 8.0.0 (which is recommended), Node.js exposes multiple options that help with finding the relevant pieces of code:
20
-
21
- - `--trace-warnings` will make Node.js show a stack trace for this warning and other warnings that are printed by Node.js.
22
- - `--trace-deprecation` does the same thing, but only for deprecation warnings.
23
- - `--pending-deprecation` will show more types of deprecation warnings. In particular, it will show the `Buffer()` deprecation warning, even on Node.js 8.
24
-
25
- You can set these flags using an environment variable:
26
-
27
- ```console
28
- $ export NODE_OPTIONS='--trace-warnings --pending-deprecation'
29
- $ cat example.js
30
- 'use strict';
31
- const foo = new Buffer('foo');
32
- $ node example.js
33
- (node:7147) [DEP0005] DeprecationWarning: The Buffer() and new Buffer() constructors are not recommended for use due to security and usability concerns. Please use the new Buffer.alloc(), Buffer.allocUnsafe(), or Buffer.from() construction methods instead.
34
- at showFlaggedDeprecation (buffer.js:127:13)
35
- at new Buffer (buffer.js:148:3)
36
- at Object.<anonymous> (/path/to/example.js:2:13)
37
- [... more stack trace lines ...]
38
- ```
39
-
40
- ### Finding problematic bits of code using linters
41
-
42
- Eslint rules [no-buffer-constructor](https://eslint.org/docs/rules/no-buffer-constructor)
43
- or
44
- [node/no-deprecated-api](https://github.com/mysticatea/eslint-plugin-node/blob/master/docs/rules/no-deprecated-api.md)
45
- also find calls to deprecated `Buffer()` API. Those rules are included in some pre-sets.
46
-
47
- There is a drawback, though, that it doesn't always
48
- [work correctly](https://github.com/chalker/safer-buffer#why-not-safe-buffer) when `Buffer` is
49
- overriden e.g. with a polyfill, so recommended is a combination of this and some other method
50
- described above.
51
-
52
- <a id="variant-1"></a>
53
- ## Variant 1: Drop support for Node.js ≤ 4.4.x and 5.0.0 — 5.9.x.
54
-
55
- This is the recommended solution nowadays that would imply only minimal overhead.
56
-
57
- The Node.js 5.x release line has been unsupported since July 2016, and the Node.js 4.x release line reaches its End of Life in April 2018 (→ [Schedule](https://github.com/nodejs/Release#release-schedule)). This means that these versions of Node.js will *not* receive any updates, even in case of security issues, so using these release lines should be avoided, if at all possible.
58
-
59
- What you would do in this case is to convert all `new Buffer()` or `Buffer()` calls to use `Buffer.alloc()` or `Buffer.from()`, in the following way:
60
-
61
- - For `new Buffer(number)`, replace it with `Buffer.alloc(number)`.
62
- - For `new Buffer(string)` (or `new Buffer(string, encoding)`), replace it with `Buffer.from(string)` (or `Buffer.from(string, encoding)`).
63
- - For all other combinations of arguments (these are much rarer), also replace `new Buffer(...arguments)` with `Buffer.from(...arguments)`.
64
-
65
- Note that `Buffer.alloc()` is also _faster_ on the current Node.js versions than
66
- `new Buffer(size).fill(0)`, which is what you would otherwise need to ensure zero-filling.
67
-
68
- Enabling eslint rule [no-buffer-constructor](https://eslint.org/docs/rules/no-buffer-constructor)
69
- or
70
- [node/no-deprecated-api](https://github.com/mysticatea/eslint-plugin-node/blob/master/docs/rules/no-deprecated-api.md)
71
- is recommended to avoid accidential unsafe Buffer API usage.
72
-
73
- There is also a [JSCodeshift codemod](https://github.com/joyeecheung/node-dep-codemod#dep005)
74
- for automatically migrating Buffer constructors to `Buffer.alloc()` or `Buffer.from()`.
75
- Note that it currently only works with cases where the arguments are literals or where the
76
- constructor is invoked with two arguments.
77
-
78
- _If you currently support those older Node.js versions and dropping them would be a semver-major change
79
- for you, or if you support older branches of your packages, consider using [Variant 2](#variant-2)
80
- or [Variant 3](#variant-3) on older branches, so people using those older branches will also receive
81
- the fix. That way, you will eradicate potential issues caused by unguarded Buffer API usage and
82
- your users will not observe a runtime deprecation warning when running your code on Node.js 10._
83
-
84
- <a id="variant-2"></a>
85
- ## Variant 2: Use a polyfill
86
-
87
- Utilize [safer-buffer](https://www.npmjs.com/package/safer-buffer) as a polyfill to support older
88
- Node.js versions.
89
-
90
- You would take exacly the same steps as in [Variant 1](#variant-1), but with a polyfill
91
- `const Buffer = require('safer-buffer').Buffer` in all files where you use the new `Buffer` api.
92
-
93
- Make sure that you do not use old `new Buffer` API — in any files where the line above is added,
94
- using old `new Buffer()` API will _throw_. It will be easy to notice that in CI, though.
95
-
96
- Alternatively, you could use [buffer-from](https://www.npmjs.com/package/buffer-from) and/or
97
- [buffer-alloc](https://www.npmjs.com/package/buffer-alloc) [ponyfills](https://ponyfill.com/) —
98
- those are great, the only downsides being 4 deps in the tree and slightly more code changes to
99
- migrate off them (as you would be using e.g. `Buffer.from` under a different name). If you need only
100
- `Buffer.from` polyfilled — `buffer-from` alone which comes with no extra dependencies.
101
-
102
- _Alternatively, you could use [safe-buffer](https://www.npmjs.com/package/safe-buffer) — it also
103
- provides a polyfill, but takes a different approach which has
104
- [it's drawbacks](https://github.com/chalker/safer-buffer#why-not-safe-buffer). It will allow you
105
- to also use the older `new Buffer()` API in your code, though — but that's arguably a benefit, as
106
- it is problematic, can cause issues in your code, and will start emitting runtime deprecation
107
- warnings starting with Node.js 10._
108
-
109
- Note that in either case, it is important that you also remove all calls to the old Buffer
110
- API manually — just throwing in `safe-buffer` doesn't fix the problem by itself, it just provides
111
- a polyfill for the new API. I have seen people doing that mistake.
112
-
113
- Enabling eslint rule [no-buffer-constructor](https://eslint.org/docs/rules/no-buffer-constructor)
114
- or
115
- [node/no-deprecated-api](https://github.com/mysticatea/eslint-plugin-node/blob/master/docs/rules/no-deprecated-api.md)
116
- is recommended.
117
-
118
- _Don't forget to drop the polyfill usage once you drop support for Node.js < 4.5.0._
119
-
120
- <a id="variant-3"></a>
121
- ## Variant 3 — manual detection, with safeguards
122
-
123
- This is useful if you create Buffer instances in only a few places (e.g. one), or you have your own
124
- wrapper around them.
125
-
126
- ### Buffer(0)
127
-
128
- This special case for creating empty buffers can be safely replaced with `Buffer.concat([])`, which
129
- returns the same result all the way down to Node.js 0.8.x.
130
-
131
- ### Buffer(notNumber)
132
-
133
- Before:
134
-
135
- ```js
136
- var buf = new Buffer(notNumber, encoding);
137
- ```
138
-
139
- After:
140
-
141
- ```js
142
- var buf;
143
- if (Buffer.from && Buffer.from !== Uint8Array.from) {
144
- buf = Buffer.from(notNumber, encoding);
145
- } else {
146
- if (typeof notNumber === 'number')
147
- throw new Error('The "size" argument must be of type number.');
148
- buf = new Buffer(notNumber, encoding);
149
- }
150
- ```
151
-
152
- `encoding` is optional.
153
-
154
- Note that the `typeof notNumber` before `new Buffer` is required (for cases when `notNumber` argument is not
155
- hard-coded) and _is not caused by the deprecation of Buffer constructor_ — it's exactly _why_ the
156
- Buffer constructor is deprecated. Ecosystem packages lacking this type-check caused numereous
157
- security issues — situations when unsanitized user input could end up in the `Buffer(arg)` create
158
- problems ranging from DoS to leaking sensitive information to the attacker from the process memory.
159
-
160
- When `notNumber` argument is hardcoded (e.g. literal `"abc"` or `[0,1,2]`), the `typeof` check can
161
- be omitted.
162
-
163
- Also note that using TypeScript does not fix this problem for you — when libs written in
164
- `TypeScript` are used from JS, or when user input ends up there — it behaves exactly as pure JS, as
165
- all type checks are translation-time only and are not present in the actual JS code which TS
166
- compiles to.
167
-
168
- ### Buffer(number)
169
-
170
- For Node.js 0.10.x (and below) support:
171
-
172
- ```js
173
- var buf;
174
- if (Buffer.alloc) {
175
- buf = Buffer.alloc(number);
176
- } else {
177
- buf = new Buffer(number);
178
- buf.fill(0);
179
- }
180
- ```
181
-
182
- Otherwise (Node.js ≥ 0.12.x):
183
-
184
- ```js
185
- const buf = Buffer.alloc ? Buffer.alloc(number) : new Buffer(number).fill(0);
186
- ```
187
-
188
- ## Regarding Buffer.allocUnsafe
189
-
190
- Be extra cautious when using `Buffer.allocUnsafe`:
191
- * Don't use it if you don't have a good reason to
192
- * e.g. you probably won't ever see a performance difference for small buffers, in fact, those
193
- might be even faster with `Buffer.alloc()`,
194
- * if your code is not in the hot code path — you also probably won't notice a difference,
195
- * keep in mind that zero-filling minimizes the potential risks.
196
- * If you use it, make sure that you never return the buffer in a partially-filled state,
197
- * if you are writing to it sequentially — always truncate it to the actuall written length
198
-
199
- Errors in handling buffers allocated with `Buffer.allocUnsafe` could result in various issues,
200
- ranged from undefined behaviour of your code to sensitive data (user input, passwords, certs)
201
- leaking to the remote attacker.
202
-
203
- _Note that the same applies to `new Buffer` usage without zero-filling, depending on the Node.js
204
- version (and lacking type checks also adds DoS to the list of potential problems)._
205
-
206
- <a id="faq"></a>
207
- ## FAQ
208
-
209
- <a id="design-flaws"></a>
210
- ### What is wrong with the `Buffer` constructor?
211
-
212
- The `Buffer` constructor could be used to create a buffer in many different ways:
213
-
214
- - `new Buffer(42)` creates a `Buffer` of 42 bytes. Before Node.js 8, this buffer contained
215
- *arbitrary memory* for performance reasons, which could include anything ranging from
216
- program source code to passwords and encryption keys.
217
- - `new Buffer('abc')` creates a `Buffer` that contains the UTF-8-encoded version of
218
- the string `'abc'`. A second argument could specify another encoding: For example,
219
- `new Buffer(string, 'base64')` could be used to convert a Base64 string into the original
220
- sequence of bytes that it represents.
221
- - There are several other combinations of arguments.
222
-
223
- This meant that, in code like `var buffer = new Buffer(foo);`, *it is not possible to tell
224
- what exactly the contents of the generated buffer are* without knowing the type of `foo`.
225
-
226
- Sometimes, the value of `foo` comes from an external source. For example, this function
227
- could be exposed as a service on a web server, converting a UTF-8 string into its Base64 form:
228
-
229
- ```
230
- function stringToBase64(req, res) {
231
- // The request body should have the format of `{ string: 'foobar' }`
232
- const rawBytes = new Buffer(req.body.string)
233
- const encoded = rawBytes.toString('base64')
234
- res.end({ encoded: encoded })
235
- }
236
- ```
237
-
238
- Note that this code does *not* validate the type of `req.body.string`:
239
-
240
- - `req.body.string` is expected to be a string. If this is the case, all goes well.
241
- - `req.body.string` is controlled by the client that sends the request.
242
- - If `req.body.string` is the *number* `50`, the `rawBytes` would be 50 bytes:
243
- - Before Node.js 8, the content would be uninitialized
244
- - After Node.js 8, the content would be `50` bytes with the value `0`
245
-
246
- Because of the missing type check, an attacker could intentionally send a number
247
- as part of the request. Using this, they can either:
248
-
249
- - Read uninitialized memory. This **will** leak passwords, encryption keys and other
250
- kinds of sensitive information. (Information leak)
251
- - Force the program to allocate a large amount of memory. For example, when specifying
252
- `500000000` as the input value, each request will allocate 500MB of memory.
253
- This can be used to either exhaust the memory available of a program completely
254
- and make it crash, or slow it down significantly. (Denial of Service)
255
-
256
- Both of these scenarios are considered serious security issues in a real-world
257
- web server context.
258
-
259
- when using `Buffer.from(req.body.string)` instead, passing a number will always
260
- throw an exception instead, giving a controlled behaviour that can always be
261
- handled by the program.
262
-
263
- <a id="ecosystem-usage"></a>
264
- ### The `Buffer()` constructor has been deprecated for a while. Is this really an issue?
265
-
266
- Surveys of code in the `npm` ecosystem have shown that the `Buffer()` constructor is still
267
- widely used. This includes new code, and overall usage of such code has actually been
268
- *increasing*.
@@ -1,156 +0,0 @@
1
- # safer-buffer [![travis][travis-image]][travis-url] [![npm][npm-image]][npm-url] [![javascript style guide][standard-image]][standard-url] [![Security Responsible Disclosure][secuirty-image]][secuirty-url]
2
-
3
- [travis-image]: https://travis-ci.org/ChALkeR/safer-buffer.svg?branch=master
4
- [travis-url]: https://travis-ci.org/ChALkeR/safer-buffer
5
- [npm-image]: https://img.shields.io/npm/v/safer-buffer.svg
6
- [npm-url]: https://npmjs.org/package/safer-buffer
7
- [standard-image]: https://img.shields.io/badge/code_style-standard-brightgreen.svg
8
- [standard-url]: https://standardjs.com
9
- [secuirty-image]: https://img.shields.io/badge/Security-Responsible%20Disclosure-green.svg
10
- [secuirty-url]: https://github.com/nodejs/security-wg/blob/master/processes/responsible_disclosure_template.md
11
-
12
- Modern Buffer API polyfill without footguns, working on Node.js from 0.8 to current.
13
-
14
- ## How to use?
15
-
16
- First, port all `Buffer()` and `new Buffer()` calls to `Buffer.alloc()` and `Buffer.from()` API.
17
-
18
- Then, to achieve compatibility with outdated Node.js versions (`<4.5.0` and 5.x `<5.9.0`), use
19
- `const Buffer = require('safer-buffer').Buffer` in all files where you make calls to the new
20
- Buffer API. _Use `var` instead of `const` if you need that for your Node.js version range support._
21
-
22
- Also, see the
23
- [porting Buffer](https://github.com/ChALkeR/safer-buffer/blob/master/Porting-Buffer.md) guide.
24
-
25
- ## Do I need it?
26
-
27
- Hopefully, not — dropping support for outdated Node.js versions should be fine nowdays, and that
28
- is the recommended path forward. You _do_ need to port to the `Buffer.alloc()` and `Buffer.from()`
29
- though.
30
-
31
- See the [porting guide](https://github.com/ChALkeR/safer-buffer/blob/master/Porting-Buffer.md)
32
- for a better description.
33
-
34
- ## Why not [safe-buffer](https://npmjs.com/safe-buffer)?
35
-
36
- _In short: while `safe-buffer` serves as a polyfill for the new API, it allows old API usage and
37
- itself contains footguns._
38
-
39
- `safe-buffer` could be used safely to get the new API while still keeping support for older
40
- Node.js versions (like this module), but while analyzing ecosystem usage of the old Buffer API
41
- I found out that `safe-buffer` is itself causing problems in some cases.
42
-
43
- For example, consider the following snippet:
44
-
45
- ```console
46
- $ cat example.unsafe.js
47
- console.log(Buffer(20))
48
- $ ./node-v6.13.0-linux-x64/bin/node example.unsafe.js
49
- <Buffer 0a 00 00 00 00 00 00 00 28 13 de 02 00 00 00 00 05 00 00 00>
50
- $ standard example.unsafe.js
51
- standard: Use JavaScript Standard Style (https://standardjs.com)
52
- /home/chalker/repo/safer-buffer/example.unsafe.js:2:13: 'Buffer()' was deprecated since v6. Use 'Buffer.alloc()' or 'Buffer.from()' (use 'https://www.npmjs.com/package/safe-buffer' for '<4.5.0') instead.
53
- ```
54
-
55
- This is allocates and writes to console an uninitialized chunk of memory.
56
- [standard](https://www.npmjs.com/package/standard) linter (among others) catch that and warn people
57
- to avoid using unsafe API.
58
-
59
- Let's now throw in `safe-buffer`!
60
-
61
- ```console
62
- $ cat example.safe-buffer.js
63
- const Buffer = require('safe-buffer').Buffer
64
- console.log(Buffer(20))
65
- $ standard example.safe-buffer.js
66
- $ ./node-v6.13.0-linux-x64/bin/node example.safe-buffer.js
67
- <Buffer 08 00 00 00 00 00 00 00 28 58 01 82 fe 7f 00 00 00 00 00 00>
68
- ```
69
-
70
- See the problem? Adding in `safe-buffer` _magically removes the lint warning_, but the behavior
71
- remains identiсal to what we had before, and when launched on Node.js 6.x LTS — this dumps out
72
- chunks of uninitialized memory.
73
- _And this code will still emit runtime warnings on Node.js 10.x and above._
74
-
75
- That was done by design. I first considered changing `safe-buffer`, prohibiting old API usage or
76
- emitting warnings on it, but that significantly diverges from `safe-buffer` design. After some
77
- discussion, it was decided to move my approach into a separate package, and _this is that separate
78
- package_.
79
-
80
- This footgun is not imaginary — I observed top-downloaded packages doing that kind of thing,
81
- «fixing» the lint warning by blindly including `safe-buffer` without any actual changes.
82
-
83
- Also in some cases, even if the API _was_ migrated to use of safe Buffer API — a random pull request
84
- can bring unsafe Buffer API usage back to the codebase by adding new calls — and that could go
85
- unnoticed even if you have a linter prohibiting that (becase of the reason stated above), and even
86
- pass CI. _I also observed that being done in popular packages._
87
-
88
- Some examples:
89
- * [webdriverio](https://github.com/webdriverio/webdriverio/commit/05cbd3167c12e4930f09ef7cf93b127ba4effae4#diff-124380949022817b90b622871837d56cR31)
90
- (a module with 548 759 downloads/month),
91
- * [websocket-stream](https://github.com/maxogden/websocket-stream/commit/c9312bd24d08271687d76da0fe3c83493871cf61)
92
- (218 288 d/m, fix in [maxogden/websocket-stream#142](https://github.com/maxogden/websocket-stream/pull/142)),
93
- * [node-serialport](https://github.com/node-serialport/node-serialport/commit/e8d9d2b16c664224920ce1c895199b1ce2def48c)
94
- (113 138 d/m, fix in [node-serialport/node-serialport#1510](https://github.com/node-serialport/node-serialport/pull/1510)),
95
- * [karma](https://github.com/karma-runner/karma/commit/3d94b8cf18c695104ca195334dc75ff054c74eec)
96
- (3 973 193 d/m, fix in [karma-runner/karma#2947](https://github.com/karma-runner/karma/pull/2947)),
97
- * [spdy-transport](https://github.com/spdy-http2/spdy-transport/commit/5375ac33f4a62a4f65bcfc2827447d42a5dbe8b1)
98
- (5 970 727 d/m, fix in [spdy-http2/spdy-transport#53](https://github.com/spdy-http2/spdy-transport/pull/53)).
99
- * And there are a lot more over the ecosystem.
100
-
101
- I filed a PR at
102
- [mysticatea/eslint-plugin-node#110](https://github.com/mysticatea/eslint-plugin-node/pull/110) to
103
- partially fix that (for cases when that lint rule is used), but it is a semver-major change for
104
- linter rules and presets, so it would take significant time for that to reach actual setups.
105
- _It also hasn't been released yet (2018-03-20)._
106
-
107
- Also, `safer-buffer` discourages the usage of `.allocUnsafe()`, which is often done by a mistake.
108
- It still supports it with an explicit concern barier, by placing it under
109
- `require('safer-buffer/dangereous')`.
110
-
111
- ## But isn't throwing bad?
112
-
113
- Not really. It's an error that could be noticed and fixed early, instead of causing havoc later like
114
- unguarded `new Buffer()` calls that end up receiving user input can do.
115
-
116
- This package affects only the files where `var Buffer = require('safer-buffer').Buffer` was done, so
117
- it is really simple to keep track of things and make sure that you don't mix old API usage with that.
118
- Also, CI should hint anything that you might have missed.
119
-
120
- New commits, if tested, won't land new usage of unsafe Buffer API this way.
121
- _Node.js 10.x also deals with that by printing a runtime depecation warning._
122
-
123
- ### Would it affect third-party modules?
124
-
125
- No, unless you explicitly do an awful thing like monkey-patching or overriding the built-in `Buffer`.
126
- Don't do that.
127
-
128
- ### But I don't want throwing…
129
-
130
- That is also fine!
131
-
132
- Also, it could be better in some cases when you don't comprehensive enough test coverage.
133
-
134
- In that case — just don't override `Buffer` and use
135
- `var SaferBuffer = require('safer-buffer').Buffer` instead.
136
-
137
- That way, everything using `Buffer` natively would still work, but there would be two drawbacks:
138
-
139
- * `Buffer.from`/`Buffer.alloc` won't be polyfilled — use `SaferBuffer.from` and
140
- `SaferBuffer.alloc` instead.
141
- * You are still open to accidentally using the insecure deprecated API — use a linter to catch that.
142
-
143
- Note that using a linter to catch accidential `Buffer` constructor usage in this case is strongly
144
- recommended. `Buffer` is not overriden in this usecase, so linters won't get confused.
145
-
146
- ## «Without footguns»?
147
-
148
- Well, it is still possible to do _some_ things with `Buffer` API, e.g. accessing `.buffer` property
149
- on older versions and duping things from there. You shouldn't do that in your code, probabably.
150
-
151
- The intention is to remove the most significant footguns that affect lots of packages in the
152
- ecosystem, and to do it in the proper way.
153
-
154
- Also, this package doesn't protect against security issues affecting some Node.js versions, so for
155
- usage in your own production code, it is still recommended to update to a Node.js version
156
- [supported by upstream](https://github.com/nodejs/release#release-schedule).
@@ -1,58 +0,0 @@
1
- /* eslint-disable node/no-deprecated-api */
2
-
3
- 'use strict'
4
-
5
- var buffer = require('buffer')
6
- var Buffer = buffer.Buffer
7
- var safer = require('./safer.js')
8
- var Safer = safer.Buffer
9
-
10
- var dangerous = {}
11
-
12
- var key
13
-
14
- for (key in safer) {
15
- if (!safer.hasOwnProperty(key)) continue
16
- dangerous[key] = safer[key]
17
- }
18
-
19
- var Dangereous = dangerous.Buffer = {}
20
-
21
- // Copy Safer API
22
- for (key in Safer) {
23
- if (!Safer.hasOwnProperty(key)) continue
24
- Dangereous[key] = Safer[key]
25
- }
26
-
27
- // Copy those missing unsafe methods, if they are present
28
- for (key in Buffer) {
29
- if (!Buffer.hasOwnProperty(key)) continue
30
- if (Dangereous.hasOwnProperty(key)) continue
31
- Dangereous[key] = Buffer[key]
32
- }
33
-
34
- if (!Dangereous.allocUnsafe) {
35
- Dangereous.allocUnsafe = function (size) {
36
- if (typeof size !== 'number') {
37
- throw new TypeError('The "size" argument must be of type number. Received type ' + typeof size)
38
- }
39
- if (size < 0 || size >= 2 * (1 << 30)) {
40
- throw new RangeError('The value "' + size + '" is invalid for option "size"')
41
- }
42
- return Buffer(size)
43
- }
44
- }
45
-
46
- if (!Dangereous.allocUnsafeSlow) {
47
- Dangereous.allocUnsafeSlow = function (size) {
48
- if (typeof size !== 'number') {
49
- throw new TypeError('The "size" argument must be of type number. Received type ' + typeof size)
50
- }
51
- if (size < 0 || size >= 2 * (1 << 30)) {
52
- throw new RangeError('The value "' + size + '" is invalid for option "size"')
53
- }
54
- return buffer.SlowBuffer(size)
55
- }
56
- }
57
-
58
- module.exports = dangerous