postdoc 0.2.0.beta4 → 0.2.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (370) hide show
  1. checksums.yaml +4 -4
  2. data/lib/postdoc.rb +50 -18
  3. metadata +24 -378
  4. data/lib/pdf.js +0 -27
  5. data/node_modules/agent-base/History.md +0 -113
  6. data/node_modules/agent-base/README.md +0 -145
  7. data/node_modules/agent-base/index.js +0 -160
  8. data/node_modules/agent-base/package.json +0 -35
  9. data/node_modules/agent-base/patch-core.js +0 -37
  10. data/node_modules/agent-base/test/ssl-cert-snakeoil.key +0 -15
  11. data/node_modules/agent-base/test/ssl-cert-snakeoil.pem +0 -12
  12. data/node_modules/agent-base/test/test.js +0 -673
  13. data/node_modules/async-limiter/LICENSE +0 -8
  14. data/node_modules/async-limiter/coverage/coverage.json +0 -1
  15. data/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.html +0 -73
  16. data/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.js.html +0 -246
  17. data/node_modules/async-limiter/coverage/lcov-report/base.css +0 -182
  18. data/node_modules/async-limiter/coverage/lcov-report/index.html +0 -73
  19. data/node_modules/async-limiter/coverage/lcov-report/prettify.css +0 -1
  20. data/node_modules/async-limiter/coverage/lcov-report/prettify.js +0 -1
  21. data/node_modules/async-limiter/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  22. data/node_modules/async-limiter/coverage/lcov-report/sorter.js +0 -156
  23. data/node_modules/async-limiter/coverage/lcov.info +0 -74
  24. data/node_modules/async-limiter/index.js +0 -67
  25. data/node_modules/async-limiter/package.json +0 -35
  26. data/node_modules/async-limiter/readme.md +0 -132
  27. data/node_modules/balanced-match/LICENSE.md +0 -21
  28. data/node_modules/balanced-match/README.md +0 -91
  29. data/node_modules/balanced-match/index.js +0 -59
  30. data/node_modules/balanced-match/package.json +0 -49
  31. data/node_modules/brace-expansion/LICENSE +0 -21
  32. data/node_modules/brace-expansion/README.md +0 -129
  33. data/node_modules/brace-expansion/index.js +0 -201
  34. data/node_modules/brace-expansion/package.json +0 -47
  35. data/node_modules/buffer-from/index.js +0 -69
  36. data/node_modules/buffer-from/package.json +0 -16
  37. data/node_modules/buffer-from/readme.md +0 -69
  38. data/node_modules/buffer-from/test.js +0 -12
  39. data/node_modules/concat-map/LICENSE +0 -18
  40. data/node_modules/concat-map/README.markdown +0 -62
  41. data/node_modules/concat-map/example/map.js +0 -6
  42. data/node_modules/concat-map/index.js +0 -13
  43. data/node_modules/concat-map/package.json +0 -43
  44. data/node_modules/concat-map/test/map.js +0 -39
  45. data/node_modules/concat-stream/LICENSE +0 -24
  46. data/node_modules/concat-stream/index.js +0 -144
  47. data/node_modules/concat-stream/package.json +0 -55
  48. data/node_modules/concat-stream/readme.md +0 -102
  49. data/node_modules/core-util-is/LICENSE +0 -19
  50. data/node_modules/core-util-is/README.md +0 -3
  51. data/node_modules/core-util-is/float.patch +0 -604
  52. data/node_modules/core-util-is/lib/util.js +0 -107
  53. data/node_modules/core-util-is/package.json +0 -32
  54. data/node_modules/core-util-is/test.js +0 -68
  55. data/node_modules/debug/CHANGELOG.md +0 -395
  56. data/node_modules/debug/LICENSE +0 -19
  57. data/node_modules/debug/Makefile +0 -58
  58. data/node_modules/debug/README.md +0 -368
  59. data/node_modules/debug/karma.conf.js +0 -70
  60. data/node_modules/debug/node.js +0 -1
  61. data/node_modules/debug/package.json +0 -43
  62. data/node_modules/debug/src/browser.js +0 -195
  63. data/node_modules/debug/src/debug.js +0 -225
  64. data/node_modules/debug/src/index.js +0 -10
  65. data/node_modules/debug/src/node.js +0 -186
  66. data/node_modules/es6-promise/CHANGELOG.md +0 -151
  67. data/node_modules/es6-promise/LICENSE +0 -19
  68. data/node_modules/es6-promise/README.md +0 -97
  69. data/node_modules/es6-promise/auto.js +0 -4
  70. data/node_modules/es6-promise/dist/es6-promise.auto.js +0 -1181
  71. data/node_modules/es6-promise/dist/es6-promise.auto.map +0 -1
  72. data/node_modules/es6-promise/dist/es6-promise.auto.min.js +0 -1
  73. data/node_modules/es6-promise/dist/es6-promise.auto.min.map +0 -1
  74. data/node_modules/es6-promise/dist/es6-promise.js +0 -1179
  75. data/node_modules/es6-promise/dist/es6-promise.map +0 -1
  76. data/node_modules/es6-promise/dist/es6-promise.min.js +0 -1
  77. data/node_modules/es6-promise/dist/es6-promise.min.map +0 -1
  78. data/node_modules/es6-promise/es6-promise.d.ts +0 -81
  79. data/node_modules/es6-promise/lib/es6-promise.auto.js +0 -3
  80. data/node_modules/es6-promise/lib/es6-promise.js +0 -7
  81. data/node_modules/es6-promise/lib/es6-promise/-internal.js +0 -266
  82. data/node_modules/es6-promise/lib/es6-promise/asap.js +0 -119
  83. data/node_modules/es6-promise/lib/es6-promise/enumerator.js +0 -113
  84. data/node_modules/es6-promise/lib/es6-promise/polyfill.js +0 -35
  85. data/node_modules/es6-promise/lib/es6-promise/promise.js +0 -427
  86. data/node_modules/es6-promise/lib/es6-promise/promise/all.js +0 -52
  87. data/node_modules/es6-promise/lib/es6-promise/promise/race.js +0 -84
  88. data/node_modules/es6-promise/lib/es6-promise/promise/reject.js +0 -46
  89. data/node_modules/es6-promise/lib/es6-promise/promise/resolve.js +0 -48
  90. data/node_modules/es6-promise/lib/es6-promise/then.js +0 -32
  91. data/node_modules/es6-promise/lib/es6-promise/utils.js +0 -21
  92. data/node_modules/es6-promise/package.json +0 -75
  93. data/node_modules/es6-promisify/README.md +0 -89
  94. data/node_modules/es6-promisify/dist/promise.js +0 -73
  95. data/node_modules/es6-promisify/dist/promisify.js +0 -85
  96. data/node_modules/es6-promisify/package.json +0 -41
  97. data/node_modules/extract-zip/CONTRIBUTING.md +0 -1
  98. data/node_modules/extract-zip/LICENSE +0 -23
  99. data/node_modules/extract-zip/cli.js +0 -20
  100. data/node_modules/extract-zip/index.js +0 -205
  101. data/node_modules/extract-zip/node_modules/debug/CHANGELOG.md +0 -362
  102. data/node_modules/extract-zip/node_modules/debug/LICENSE +0 -19
  103. data/node_modules/extract-zip/node_modules/debug/Makefile +0 -50
  104. data/node_modules/extract-zip/node_modules/debug/README.md +0 -312
  105. data/node_modules/extract-zip/node_modules/debug/component.json +0 -19
  106. data/node_modules/extract-zip/node_modules/debug/karma.conf.js +0 -70
  107. data/node_modules/extract-zip/node_modules/debug/node.js +0 -1
  108. data/node_modules/extract-zip/node_modules/debug/package.json +0 -49
  109. data/node_modules/extract-zip/node_modules/debug/src/browser.js +0 -185
  110. data/node_modules/extract-zip/node_modules/debug/src/debug.js +0 -202
  111. data/node_modules/extract-zip/node_modules/debug/src/index.js +0 -10
  112. data/node_modules/extract-zip/node_modules/debug/src/inspector-log.js +0 -15
  113. data/node_modules/extract-zip/node_modules/debug/src/node.js +0 -248
  114. data/node_modules/extract-zip/package.json +0 -35
  115. data/node_modules/extract-zip/readme.md +0 -49
  116. data/node_modules/fd-slicer/CHANGELOG.md +0 -49
  117. data/node_modules/fd-slicer/LICENSE +0 -21
  118. data/node_modules/fd-slicer/README.md +0 -189
  119. data/node_modules/fd-slicer/index.js +0 -277
  120. data/node_modules/fd-slicer/package.json +0 -36
  121. data/node_modules/fd-slicer/test/test.js +0 -350
  122. data/node_modules/fs.realpath/LICENSE +0 -43
  123. data/node_modules/fs.realpath/README.md +0 -33
  124. data/node_modules/fs.realpath/index.js +0 -66
  125. data/node_modules/fs.realpath/old.js +0 -303
  126. data/node_modules/fs.realpath/package.json +0 -26
  127. data/node_modules/glob/LICENSE +0 -15
  128. data/node_modules/glob/README.md +0 -368
  129. data/node_modules/glob/changelog.md +0 -67
  130. data/node_modules/glob/common.js +0 -240
  131. data/node_modules/glob/glob.js +0 -790
  132. data/node_modules/glob/package.json +0 -43
  133. data/node_modules/glob/sync.js +0 -486
  134. data/node_modules/https-proxy-agent/History.md +0 -124
  135. data/node_modules/https-proxy-agent/README.md +0 -137
  136. data/node_modules/https-proxy-agent/index.js +0 -229
  137. data/node_modules/https-proxy-agent/package.json +0 -35
  138. data/node_modules/https-proxy-agent/test/ssl-cert-snakeoil.key +0 -15
  139. data/node_modules/https-proxy-agent/test/ssl-cert-snakeoil.pem +0 -12
  140. data/node_modules/https-proxy-agent/test/test.js +0 -342
  141. data/node_modules/inflight/LICENSE +0 -15
  142. data/node_modules/inflight/README.md +0 -37
  143. data/node_modules/inflight/inflight.js +0 -54
  144. data/node_modules/inflight/package.json +0 -29
  145. data/node_modules/inherits/LICENSE +0 -16
  146. data/node_modules/inherits/README.md +0 -42
  147. data/node_modules/inherits/inherits.js +0 -7
  148. data/node_modules/inherits/inherits_browser.js +0 -23
  149. data/node_modules/inherits/package.json +0 -29
  150. data/node_modules/isarray/Makefile +0 -6
  151. data/node_modules/isarray/README.md +0 -60
  152. data/node_modules/isarray/component.json +0 -19
  153. data/node_modules/isarray/index.js +0 -5
  154. data/node_modules/isarray/package.json +0 -45
  155. data/node_modules/isarray/test.js +0 -20
  156. data/node_modules/mime/CHANGELOG.md +0 -225
  157. data/node_modules/mime/CONTRIBUTING.md +0 -5
  158. data/node_modules/mime/LICENSE +0 -21
  159. data/node_modules/mime/Mime.js +0 -89
  160. data/node_modules/mime/README.md +0 -188
  161. data/node_modules/mime/cli.js +0 -10
  162. data/node_modules/mime/index.js +0 -4
  163. data/node_modules/mime/lite.js +0 -4
  164. data/node_modules/mime/package.json +0 -43
  165. data/node_modules/mime/src/README_js.md +0 -179
  166. data/node_modules/mime/src/build.js +0 -71
  167. data/node_modules/mime/src/test.js +0 -257
  168. data/node_modules/mime/types/other.json +0 -1
  169. data/node_modules/mime/types/standard.json +0 -1
  170. data/node_modules/minimatch/LICENSE +0 -15
  171. data/node_modules/minimatch/README.md +0 -209
  172. data/node_modules/minimatch/minimatch.js +0 -923
  173. data/node_modules/minimatch/package.json +0 -30
  174. data/node_modules/minimist/LICENSE +0 -18
  175. data/node_modules/minimist/example/parse.js +0 -2
  176. data/node_modules/minimist/index.js +0 -187
  177. data/node_modules/minimist/package.json +0 -40
  178. data/node_modules/minimist/readme.markdown +0 -73
  179. data/node_modules/minimist/test/dash.js +0 -24
  180. data/node_modules/minimist/test/default_bool.js +0 -20
  181. data/node_modules/minimist/test/dotted.js +0 -16
  182. data/node_modules/minimist/test/long.js +0 -31
  183. data/node_modules/minimist/test/parse.js +0 -318
  184. data/node_modules/minimist/test/parse_modified.js +0 -9
  185. data/node_modules/minimist/test/short.js +0 -67
  186. data/node_modules/minimist/test/whitespace.js +0 -8
  187. data/node_modules/mkdirp/LICENSE +0 -21
  188. data/node_modules/mkdirp/bin/cmd.js +0 -33
  189. data/node_modules/mkdirp/bin/usage.txt +0 -12
  190. data/node_modules/mkdirp/examples/pow.js +0 -6
  191. data/node_modules/mkdirp/index.js +0 -98
  192. data/node_modules/mkdirp/package.json +0 -27
  193. data/node_modules/mkdirp/readme.markdown +0 -100
  194. data/node_modules/mkdirp/test/chmod.js +0 -41
  195. data/node_modules/mkdirp/test/clobber.js +0 -38
  196. data/node_modules/mkdirp/test/mkdirp.js +0 -28
  197. data/node_modules/mkdirp/test/opts_fs.js +0 -29
  198. data/node_modules/mkdirp/test/opts_fs_sync.js +0 -27
  199. data/node_modules/mkdirp/test/perm.js +0 -32
  200. data/node_modules/mkdirp/test/perm_sync.js +0 -36
  201. data/node_modules/mkdirp/test/race.js +0 -37
  202. data/node_modules/mkdirp/test/rel.js +0 -32
  203. data/node_modules/mkdirp/test/return.js +0 -25
  204. data/node_modules/mkdirp/test/return_sync.js +0 -24
  205. data/node_modules/mkdirp/test/root.js +0 -19
  206. data/node_modules/mkdirp/test/sync.js +0 -32
  207. data/node_modules/mkdirp/test/umask.js +0 -28
  208. data/node_modules/mkdirp/test/umask_sync.js +0 -32
  209. data/node_modules/ms/index.js +0 -152
  210. data/node_modules/ms/license.md +0 -21
  211. data/node_modules/ms/package.json +0 -37
  212. data/node_modules/ms/readme.md +0 -51
  213. data/node_modules/once/LICENSE +0 -15
  214. data/node_modules/once/README.md +0 -79
  215. data/node_modules/once/once.js +0 -42
  216. data/node_modules/once/package.json +0 -33
  217. data/node_modules/path-is-absolute/index.js +0 -20
  218. data/node_modules/path-is-absolute/license +0 -21
  219. data/node_modules/path-is-absolute/package.json +0 -43
  220. data/node_modules/path-is-absolute/readme.md +0 -59
  221. data/node_modules/pend/LICENSE +0 -23
  222. data/node_modules/pend/README.md +0 -41
  223. data/node_modules/pend/index.js +0 -55
  224. data/node_modules/pend/package.json +0 -18
  225. data/node_modules/pend/test.js +0 -137
  226. data/node_modules/process-nextick-args/index.js +0 -44
  227. data/node_modules/process-nextick-args/license.md +0 -19
  228. data/node_modules/process-nextick-args/package.json +0 -25
  229. data/node_modules/process-nextick-args/readme.md +0 -18
  230. data/node_modules/progress/CHANGELOG.md +0 -115
  231. data/node_modules/progress/LICENSE +0 -22
  232. data/node_modules/progress/Makefile +0 -8
  233. data/node_modules/progress/README.md +0 -146
  234. data/node_modules/progress/index.js +0 -1
  235. data/node_modules/progress/lib/node-progress.js +0 -231
  236. data/node_modules/progress/package.json +0 -25
  237. data/node_modules/proxy-from-env/README.md +0 -131
  238. data/node_modules/proxy-from-env/index.js +0 -103
  239. data/node_modules/proxy-from-env/package.json +0 -35
  240. data/node_modules/proxy-from-env/test.js +0 -393
  241. data/node_modules/puppeteer/CONTRIBUTING.md +0 -206
  242. data/node_modules/puppeteer/DeviceDescriptors.js +0 -704
  243. data/node_modules/puppeteer/LICENSE +0 -202
  244. data/node_modules/puppeteer/README.md +0 -306
  245. data/node_modules/puppeteer/index.js +0 -28
  246. data/node_modules/puppeteer/install.js +0 -122
  247. data/node_modules/puppeteer/lib/Browser.js +0 -186
  248. data/node_modules/puppeteer/lib/BrowserFetcher.js +0 -279
  249. data/node_modules/puppeteer/lib/Connection.js +0 -246
  250. data/node_modules/puppeteer/lib/Coverage.js +0 -301
  251. data/node_modules/puppeteer/lib/Dialog.js +0 -84
  252. data/node_modules/puppeteer/lib/ElementHandle.js +0 -328
  253. data/node_modules/puppeteer/lib/EmulationManager.js +0 -89
  254. data/node_modules/puppeteer/lib/ExecutionContext.js +0 -232
  255. data/node_modules/puppeteer/lib/FrameManager.js +0 -997
  256. data/node_modules/puppeteer/lib/Input.js +0 -309
  257. data/node_modules/puppeteer/lib/Launcher.js +0 -310
  258. data/node_modules/puppeteer/lib/Multimap.js +0 -95
  259. data/node_modules/puppeteer/lib/NavigatorWatcher.js +0 -137
  260. data/node_modules/puppeteer/lib/NetworkManager.js +0 -796
  261. data/node_modules/puppeteer/lib/Page.js +0 -1098
  262. data/node_modules/puppeteer/lib/Pipe.js +0 -69
  263. data/node_modules/puppeteer/lib/Puppeteer.js +0 -60
  264. data/node_modules/puppeteer/lib/Target.js +0 -88
  265. data/node_modules/puppeteer/lib/TaskQueue.js +0 -17
  266. data/node_modules/puppeteer/lib/Tracing.js +0 -99
  267. data/node_modules/puppeteer/lib/USKeyboardLayout.js +0 -281
  268. data/node_modules/puppeteer/lib/helper.js +0 -248
  269. data/node_modules/puppeteer/node6/lib/Browser.js +0 -394
  270. data/node_modules/puppeteer/node6/lib/BrowserFetcher.js +0 -357
  271. data/node_modules/puppeteer/node6/lib/Connection.js +0 -350
  272. data/node_modules/puppeteer/node6/lib/Coverage.js +0 -561
  273. data/node_modules/puppeteer/node6/lib/Dialog.js +0 -136
  274. data/node_modules/puppeteer/node6/lib/ElementHandle.js +0 -796
  275. data/node_modules/puppeteer/node6/lib/EmulationManager.js +0 -115
  276. data/node_modules/puppeteer/node6/lib/ExecutionContext.js +0 -414
  277. data/node_modules/puppeteer/node6/lib/FrameManager.js +0 -1621
  278. data/node_modules/puppeteer/node6/lib/Input.js +0 -569
  279. data/node_modules/puppeteer/node6/lib/Launcher.js +0 -362
  280. data/node_modules/puppeteer/node6/lib/Multimap.js +0 -95
  281. data/node_modules/puppeteer/node6/lib/NavigatorWatcher.js +0 -163
  282. data/node_modules/puppeteer/node6/lib/NetworkManager.js +0 -1108
  283. data/node_modules/puppeteer/node6/lib/Page.js +0 -2242
  284. data/node_modules/puppeteer/node6/lib/Pipe.js +0 -69
  285. data/node_modules/puppeteer/node6/lib/Puppeteer.js +0 -60
  286. data/node_modules/puppeteer/node6/lib/Target.js +0 -114
  287. data/node_modules/puppeteer/node6/lib/TaskQueue.js +0 -17
  288. data/node_modules/puppeteer/node6/lib/Tracing.js +0 -177
  289. data/node_modules/puppeteer/node6/lib/USKeyboardLayout.js +0 -281
  290. data/node_modules/puppeteer/node6/lib/helper.js +0 -274
  291. data/node_modules/puppeteer/package.json +0 -61
  292. data/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  293. data/node_modules/readable-stream/GOVERNANCE.md +0 -136
  294. data/node_modules/readable-stream/LICENSE +0 -47
  295. data/node_modules/readable-stream/README.md +0 -58
  296. data/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +0 -60
  297. data/node_modules/readable-stream/duplex-browser.js +0 -1
  298. data/node_modules/readable-stream/duplex.js +0 -1
  299. data/node_modules/readable-stream/lib/_stream_duplex.js +0 -131
  300. data/node_modules/readable-stream/lib/_stream_passthrough.js +0 -47
  301. data/node_modules/readable-stream/lib/_stream_readable.js +0 -1019
  302. data/node_modules/readable-stream/lib/_stream_transform.js +0 -214
  303. data/node_modules/readable-stream/lib/_stream_writable.js +0 -687
  304. data/node_modules/readable-stream/lib/internal/streams/BufferList.js +0 -79
  305. data/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -74
  306. data/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  307. data/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  308. data/node_modules/readable-stream/package.json +0 -52
  309. data/node_modules/readable-stream/passthrough.js +0 -1
  310. data/node_modules/readable-stream/readable-browser.js +0 -7
  311. data/node_modules/readable-stream/readable.js +0 -19
  312. data/node_modules/readable-stream/transform.js +0 -1
  313. data/node_modules/readable-stream/writable-browser.js +0 -1
  314. data/node_modules/readable-stream/writable.js +0 -8
  315. data/node_modules/rimraf/LICENSE +0 -15
  316. data/node_modules/rimraf/README.md +0 -101
  317. data/node_modules/rimraf/bin.js +0 -50
  318. data/node_modules/rimraf/package.json +0 -26
  319. data/node_modules/rimraf/rimraf.js +0 -364
  320. data/node_modules/safe-buffer/LICENSE +0 -21
  321. data/node_modules/safe-buffer/README.md +0 -584
  322. data/node_modules/safe-buffer/index.d.ts +0 -187
  323. data/node_modules/safe-buffer/index.js +0 -62
  324. data/node_modules/safe-buffer/package.json +0 -37
  325. data/node_modules/string_decoder/LICENSE +0 -48
  326. data/node_modules/string_decoder/README.md +0 -47
  327. data/node_modules/string_decoder/lib/string_decoder.js +0 -296
  328. data/node_modules/string_decoder/package.json +0 -31
  329. data/node_modules/typedarray/LICENSE +0 -35
  330. data/node_modules/typedarray/example/tarray.js +0 -4
  331. data/node_modules/typedarray/index.js +0 -630
  332. data/node_modules/typedarray/package.json +0 -55
  333. data/node_modules/typedarray/readme.markdown +0 -61
  334. data/node_modules/typedarray/test/server/undef_globals.js +0 -19
  335. data/node_modules/typedarray/test/tarray.js +0 -10
  336. data/node_modules/ultron/LICENSE +0 -22
  337. data/node_modules/ultron/README.md +0 -113
  338. data/node_modules/ultron/index.js +0 -136
  339. data/node_modules/ultron/package.json +0 -41
  340. data/node_modules/util-deprecate/History.md +0 -16
  341. data/node_modules/util-deprecate/LICENSE +0 -24
  342. data/node_modules/util-deprecate/README.md +0 -53
  343. data/node_modules/util-deprecate/browser.js +0 -67
  344. data/node_modules/util-deprecate/node.js +0 -6
  345. data/node_modules/util-deprecate/package.json +0 -27
  346. data/node_modules/wrappy/LICENSE +0 -15
  347. data/node_modules/wrappy/README.md +0 -36
  348. data/node_modules/wrappy/package.json +0 -29
  349. data/node_modules/wrappy/wrappy.js +0 -33
  350. data/node_modules/ws/LICENSE +0 -21
  351. data/node_modules/ws/README.md +0 -341
  352. data/node_modules/ws/index.js +0 -15
  353. data/node_modules/ws/lib/BufferUtil.js +0 -71
  354. data/node_modules/ws/lib/Constants.js +0 -10
  355. data/node_modules/ws/lib/ErrorCodes.js +0 -28
  356. data/node_modules/ws/lib/EventTarget.js +0 -151
  357. data/node_modules/ws/lib/Extensions.js +0 -203
  358. data/node_modules/ws/lib/PerMessageDeflate.js +0 -507
  359. data/node_modules/ws/lib/Receiver.js +0 -553
  360. data/node_modules/ws/lib/Sender.js +0 -412
  361. data/node_modules/ws/lib/Validation.js +0 -17
  362. data/node_modules/ws/lib/WebSocket.js +0 -717
  363. data/node_modules/ws/lib/WebSocketServer.js +0 -326
  364. data/node_modules/ws/package.json +0 -46
  365. data/node_modules/yauzl/LICENSE +0 -21
  366. data/node_modules/yauzl/README.md +0 -467
  367. data/node_modules/yauzl/index.js +0 -626
  368. data/node_modules/yauzl/package.json +0 -36
  369. data/package.json +0 -5
  370. data/yarn.lock +0 -240
@@ -1,364 +0,0 @@
1
- module.exports = rimraf
2
- rimraf.sync = rimrafSync
3
-
4
- var assert = require("assert")
5
- var path = require("path")
6
- var fs = require("fs")
7
- var glob = require("glob")
8
- var _0666 = parseInt('666', 8)
9
-
10
- var defaultGlobOpts = {
11
- nosort: true,
12
- silent: true
13
- }
14
-
15
- // for EMFILE handling
16
- var timeout = 0
17
-
18
- var isWindows = (process.platform === "win32")
19
-
20
- function defaults (options) {
21
- var methods = [
22
- 'unlink',
23
- 'chmod',
24
- 'stat',
25
- 'lstat',
26
- 'rmdir',
27
- 'readdir'
28
- ]
29
- methods.forEach(function(m) {
30
- options[m] = options[m] || fs[m]
31
- m = m + 'Sync'
32
- options[m] = options[m] || fs[m]
33
- })
34
-
35
- options.maxBusyTries = options.maxBusyTries || 3
36
- options.emfileWait = options.emfileWait || 1000
37
- if (options.glob === false) {
38
- options.disableGlob = true
39
- }
40
- options.disableGlob = options.disableGlob || false
41
- options.glob = options.glob || defaultGlobOpts
42
- }
43
-
44
- function rimraf (p, options, cb) {
45
- if (typeof options === 'function') {
46
- cb = options
47
- options = {}
48
- }
49
-
50
- assert(p, 'rimraf: missing path')
51
- assert.equal(typeof p, 'string', 'rimraf: path should be a string')
52
- assert.equal(typeof cb, 'function', 'rimraf: callback function required')
53
- assert(options, 'rimraf: invalid options argument provided')
54
- assert.equal(typeof options, 'object', 'rimraf: options should be object')
55
-
56
- defaults(options)
57
-
58
- var busyTries = 0
59
- var errState = null
60
- var n = 0
61
-
62
- if (options.disableGlob || !glob.hasMagic(p))
63
- return afterGlob(null, [p])
64
-
65
- options.lstat(p, function (er, stat) {
66
- if (!er)
67
- return afterGlob(null, [p])
68
-
69
- glob(p, options.glob, afterGlob)
70
- })
71
-
72
- function next (er) {
73
- errState = errState || er
74
- if (--n === 0)
75
- cb(errState)
76
- }
77
-
78
- function afterGlob (er, results) {
79
- if (er)
80
- return cb(er)
81
-
82
- n = results.length
83
- if (n === 0)
84
- return cb()
85
-
86
- results.forEach(function (p) {
87
- rimraf_(p, options, function CB (er) {
88
- if (er) {
89
- if ((er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") &&
90
- busyTries < options.maxBusyTries) {
91
- busyTries ++
92
- var time = busyTries * 100
93
- // try again, with the same exact callback as this one.
94
- return setTimeout(function () {
95
- rimraf_(p, options, CB)
96
- }, time)
97
- }
98
-
99
- // this one won't happen if graceful-fs is used.
100
- if (er.code === "EMFILE" && timeout < options.emfileWait) {
101
- return setTimeout(function () {
102
- rimraf_(p, options, CB)
103
- }, timeout ++)
104
- }
105
-
106
- // already gone
107
- if (er.code === "ENOENT") er = null
108
- }
109
-
110
- timeout = 0
111
- next(er)
112
- })
113
- })
114
- }
115
- }
116
-
117
- // Two possible strategies.
118
- // 1. Assume it's a file. unlink it, then do the dir stuff on EPERM or EISDIR
119
- // 2. Assume it's a directory. readdir, then do the file stuff on ENOTDIR
120
- //
121
- // Both result in an extra syscall when you guess wrong. However, there
122
- // are likely far more normal files in the world than directories. This
123
- // is based on the assumption that a the average number of files per
124
- // directory is >= 1.
125
- //
126
- // If anyone ever complains about this, then I guess the strategy could
127
- // be made configurable somehow. But until then, YAGNI.
128
- function rimraf_ (p, options, cb) {
129
- assert(p)
130
- assert(options)
131
- assert(typeof cb === 'function')
132
-
133
- // sunos lets the root user unlink directories, which is... weird.
134
- // so we have to lstat here and make sure it's not a dir.
135
- options.lstat(p, function (er, st) {
136
- if (er && er.code === "ENOENT")
137
- return cb(null)
138
-
139
- // Windows can EPERM on stat. Life is suffering.
140
- if (er && er.code === "EPERM" && isWindows)
141
- fixWinEPERM(p, options, er, cb)
142
-
143
- if (st && st.isDirectory())
144
- return rmdir(p, options, er, cb)
145
-
146
- options.unlink(p, function (er) {
147
- if (er) {
148
- if (er.code === "ENOENT")
149
- return cb(null)
150
- if (er.code === "EPERM")
151
- return (isWindows)
152
- ? fixWinEPERM(p, options, er, cb)
153
- : rmdir(p, options, er, cb)
154
- if (er.code === "EISDIR")
155
- return rmdir(p, options, er, cb)
156
- }
157
- return cb(er)
158
- })
159
- })
160
- }
161
-
162
- function fixWinEPERM (p, options, er, cb) {
163
- assert(p)
164
- assert(options)
165
- assert(typeof cb === 'function')
166
- if (er)
167
- assert(er instanceof Error)
168
-
169
- options.chmod(p, _0666, function (er2) {
170
- if (er2)
171
- cb(er2.code === "ENOENT" ? null : er)
172
- else
173
- options.stat(p, function(er3, stats) {
174
- if (er3)
175
- cb(er3.code === "ENOENT" ? null : er)
176
- else if (stats.isDirectory())
177
- rmdir(p, options, er, cb)
178
- else
179
- options.unlink(p, cb)
180
- })
181
- })
182
- }
183
-
184
- function fixWinEPERMSync (p, options, er) {
185
- assert(p)
186
- assert(options)
187
- if (er)
188
- assert(er instanceof Error)
189
-
190
- try {
191
- options.chmodSync(p, _0666)
192
- } catch (er2) {
193
- if (er2.code === "ENOENT")
194
- return
195
- else
196
- throw er
197
- }
198
-
199
- try {
200
- var stats = options.statSync(p)
201
- } catch (er3) {
202
- if (er3.code === "ENOENT")
203
- return
204
- else
205
- throw er
206
- }
207
-
208
- if (stats.isDirectory())
209
- rmdirSync(p, options, er)
210
- else
211
- options.unlinkSync(p)
212
- }
213
-
214
- function rmdir (p, options, originalEr, cb) {
215
- assert(p)
216
- assert(options)
217
- if (originalEr)
218
- assert(originalEr instanceof Error)
219
- assert(typeof cb === 'function')
220
-
221
- // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS)
222
- // if we guessed wrong, and it's not a directory, then
223
- // raise the original error.
224
- options.rmdir(p, function (er) {
225
- if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM"))
226
- rmkids(p, options, cb)
227
- else if (er && er.code === "ENOTDIR")
228
- cb(originalEr)
229
- else
230
- cb(er)
231
- })
232
- }
233
-
234
- function rmkids(p, options, cb) {
235
- assert(p)
236
- assert(options)
237
- assert(typeof cb === 'function')
238
-
239
- options.readdir(p, function (er, files) {
240
- if (er)
241
- return cb(er)
242
- var n = files.length
243
- if (n === 0)
244
- return options.rmdir(p, cb)
245
- var errState
246
- files.forEach(function (f) {
247
- rimraf(path.join(p, f), options, function (er) {
248
- if (errState)
249
- return
250
- if (er)
251
- return cb(errState = er)
252
- if (--n === 0)
253
- options.rmdir(p, cb)
254
- })
255
- })
256
- })
257
- }
258
-
259
- // this looks simpler, and is strictly *faster*, but will
260
- // tie up the JavaScript thread and fail on excessively
261
- // deep directory trees.
262
- function rimrafSync (p, options) {
263
- options = options || {}
264
- defaults(options)
265
-
266
- assert(p, 'rimraf: missing path')
267
- assert.equal(typeof p, 'string', 'rimraf: path should be a string')
268
- assert(options, 'rimraf: missing options')
269
- assert.equal(typeof options, 'object', 'rimraf: options should be object')
270
-
271
- var results
272
-
273
- if (options.disableGlob || !glob.hasMagic(p)) {
274
- results = [p]
275
- } else {
276
- try {
277
- options.lstatSync(p)
278
- results = [p]
279
- } catch (er) {
280
- results = glob.sync(p, options.glob)
281
- }
282
- }
283
-
284
- if (!results.length)
285
- return
286
-
287
- for (var i = 0; i < results.length; i++) {
288
- var p = results[i]
289
-
290
- try {
291
- var st = options.lstatSync(p)
292
- } catch (er) {
293
- if (er.code === "ENOENT")
294
- return
295
-
296
- // Windows can EPERM on stat. Life is suffering.
297
- if (er.code === "EPERM" && isWindows)
298
- fixWinEPERMSync(p, options, er)
299
- }
300
-
301
- try {
302
- // sunos lets the root user unlink directories, which is... weird.
303
- if (st && st.isDirectory())
304
- rmdirSync(p, options, null)
305
- else
306
- options.unlinkSync(p)
307
- } catch (er) {
308
- if (er.code === "ENOENT")
309
- return
310
- if (er.code === "EPERM")
311
- return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er)
312
- if (er.code !== "EISDIR")
313
- throw er
314
-
315
- rmdirSync(p, options, er)
316
- }
317
- }
318
- }
319
-
320
- function rmdirSync (p, options, originalEr) {
321
- assert(p)
322
- assert(options)
323
- if (originalEr)
324
- assert(originalEr instanceof Error)
325
-
326
- try {
327
- options.rmdirSync(p)
328
- } catch (er) {
329
- if (er.code === "ENOENT")
330
- return
331
- if (er.code === "ENOTDIR")
332
- throw originalEr
333
- if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")
334
- rmkidsSync(p, options)
335
- }
336
- }
337
-
338
- function rmkidsSync (p, options) {
339
- assert(p)
340
- assert(options)
341
- options.readdirSync(p).forEach(function (f) {
342
- rimrafSync(path.join(p, f), options)
343
- })
344
-
345
- // We only end up here once we got ENOTEMPTY at least once, and
346
- // at this point, we are guaranteed to have removed all the kids.
347
- // So, we know that it won't be ENOENT or ENOTDIR or anything else.
348
- // try really hard to delete stuff on windows, because it has a
349
- // PROFOUNDLY annoying habit of not closing handles promptly when
350
- // files are deleted, resulting in spurious ENOTEMPTY errors.
351
- var retries = isWindows ? 100 : 1
352
- var i = 0
353
- do {
354
- var threw = true
355
- try {
356
- var ret = options.rmdirSync(p, options)
357
- threw = false
358
- return ret
359
- } finally {
360
- if (++i < retries && threw)
361
- continue
362
- }
363
- } while (true)
364
- }
@@ -1,21 +0,0 @@
1
- The MIT License (MIT)
2
-
3
- Copyright (c) Feross Aboukhadijeh
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
13
- all 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
21
- THE SOFTWARE.
@@ -1,584 +0,0 @@
1
- # safe-buffer [![travis][travis-image]][travis-url] [![npm][npm-image]][npm-url] [![downloads][downloads-image]][downloads-url] [![javascript style guide][standard-image]][standard-url]
2
-
3
- [travis-image]: https://img.shields.io/travis/feross/safe-buffer/master.svg
4
- [travis-url]: https://travis-ci.org/feross/safe-buffer
5
- [npm-image]: https://img.shields.io/npm/v/safe-buffer.svg
6
- [npm-url]: https://npmjs.org/package/safe-buffer
7
- [downloads-image]: https://img.shields.io/npm/dm/safe-buffer.svg
8
- [downloads-url]: https://npmjs.org/package/safe-buffer
9
- [standard-image]: https://img.shields.io/badge/code_style-standard-brightgreen.svg
10
- [standard-url]: https://standardjs.com
11
-
12
- #### Safer Node.js Buffer API
13
-
14
- **Use the new Node.js Buffer APIs (`Buffer.from`, `Buffer.alloc`,
15
- `Buffer.allocUnsafe`, `Buffer.allocUnsafeSlow`) in all versions of Node.js.**
16
-
17
- **Uses the built-in implementation when available.**
18
-
19
- ## install
20
-
21
- ```
22
- npm install safe-buffer
23
- ```
24
-
25
- ## usage
26
-
27
- The goal of this package is to provide a safe replacement for the node.js `Buffer`.
28
-
29
- It's a drop-in replacement for `Buffer`. You can use it by adding one `require` line to
30
- the top of your node.js modules:
31
-
32
- ```js
33
- var Buffer = require('safe-buffer').Buffer
34
-
35
- // Existing buffer code will continue to work without issues:
36
-
37
- new Buffer('hey', 'utf8')
38
- new Buffer([1, 2, 3], 'utf8')
39
- new Buffer(obj)
40
- new Buffer(16) // create an uninitialized buffer (potentially unsafe)
41
-
42
- // But you can use these new explicit APIs to make clear what you want:
43
-
44
- Buffer.from('hey', 'utf8') // convert from many types to a Buffer
45
- Buffer.alloc(16) // create a zero-filled buffer (safe)
46
- Buffer.allocUnsafe(16) // create an uninitialized buffer (potentially unsafe)
47
- ```
48
-
49
- ## api
50
-
51
- ### Class Method: Buffer.from(array)
52
- <!-- YAML
53
- added: v3.0.0
54
- -->
55
-
56
- * `array` {Array}
57
-
58
- Allocates a new `Buffer` using an `array` of octets.
59
-
60
- ```js
61
- const buf = Buffer.from([0x62,0x75,0x66,0x66,0x65,0x72]);
62
- // creates a new Buffer containing ASCII bytes
63
- // ['b','u','f','f','e','r']
64
- ```
65
-
66
- A `TypeError` will be thrown if `array` is not an `Array`.
67
-
68
- ### Class Method: Buffer.from(arrayBuffer[, byteOffset[, length]])
69
- <!-- YAML
70
- added: v5.10.0
71
- -->
72
-
73
- * `arrayBuffer` {ArrayBuffer} The `.buffer` property of a `TypedArray` or
74
- a `new ArrayBuffer()`
75
- * `byteOffset` {Number} Default: `0`
76
- * `length` {Number} Default: `arrayBuffer.length - byteOffset`
77
-
78
- When passed a reference to the `.buffer` property of a `TypedArray` instance,
79
- the newly created `Buffer` will share the same allocated memory as the
80
- TypedArray.
81
-
82
- ```js
83
- const arr = new Uint16Array(2);
84
- arr[0] = 5000;
85
- arr[1] = 4000;
86
-
87
- const buf = Buffer.from(arr.buffer); // shares the memory with arr;
88
-
89
- console.log(buf);
90
- // Prints: <Buffer 88 13 a0 0f>
91
-
92
- // changing the TypedArray changes the Buffer also
93
- arr[1] = 6000;
94
-
95
- console.log(buf);
96
- // Prints: <Buffer 88 13 70 17>
97
- ```
98
-
99
- The optional `byteOffset` and `length` arguments specify a memory range within
100
- the `arrayBuffer` that will be shared by the `Buffer`.
101
-
102
- ```js
103
- const ab = new ArrayBuffer(10);
104
- const buf = Buffer.from(ab, 0, 2);
105
- console.log(buf.length);
106
- // Prints: 2
107
- ```
108
-
109
- A `TypeError` will be thrown if `arrayBuffer` is not an `ArrayBuffer`.
110
-
111
- ### Class Method: Buffer.from(buffer)
112
- <!-- YAML
113
- added: v3.0.0
114
- -->
115
-
116
- * `buffer` {Buffer}
117
-
118
- Copies the passed `buffer` data onto a new `Buffer` instance.
119
-
120
- ```js
121
- const buf1 = Buffer.from('buffer');
122
- const buf2 = Buffer.from(buf1);
123
-
124
- buf1[0] = 0x61;
125
- console.log(buf1.toString());
126
- // 'auffer'
127
- console.log(buf2.toString());
128
- // 'buffer' (copy is not changed)
129
- ```
130
-
131
- A `TypeError` will be thrown if `buffer` is not a `Buffer`.
132
-
133
- ### Class Method: Buffer.from(str[, encoding])
134
- <!-- YAML
135
- added: v5.10.0
136
- -->
137
-
138
- * `str` {String} String to encode.
139
- * `encoding` {String} Encoding to use, Default: `'utf8'`
140
-
141
- Creates a new `Buffer` containing the given JavaScript string `str`. If
142
- provided, the `encoding` parameter identifies the character encoding.
143
- If not provided, `encoding` defaults to `'utf8'`.
144
-
145
- ```js
146
- const buf1 = Buffer.from('this is a tést');
147
- console.log(buf1.toString());
148
- // prints: this is a tést
149
- console.log(buf1.toString('ascii'));
150
- // prints: this is a tC)st
151
-
152
- const buf2 = Buffer.from('7468697320697320612074c3a97374', 'hex');
153
- console.log(buf2.toString());
154
- // prints: this is a tést
155
- ```
156
-
157
- A `TypeError` will be thrown if `str` is not a string.
158
-
159
- ### Class Method: Buffer.alloc(size[, fill[, encoding]])
160
- <!-- YAML
161
- added: v5.10.0
162
- -->
163
-
164
- * `size` {Number}
165
- * `fill` {Value} Default: `undefined`
166
- * `encoding` {String} Default: `utf8`
167
-
168
- Allocates a new `Buffer` of `size` bytes. If `fill` is `undefined`, the
169
- `Buffer` will be *zero-filled*.
170
-
171
- ```js
172
- const buf = Buffer.alloc(5);
173
- console.log(buf);
174
- // <Buffer 00 00 00 00 00>
175
- ```
176
-
177
- The `size` must be less than or equal to the value of
178
- `require('buffer').kMaxLength` (on 64-bit architectures, `kMaxLength` is
179
- `(2^31)-1`). Otherwise, a [`RangeError`][] is thrown. A zero-length Buffer will
180
- be created if a `size` less than or equal to 0 is specified.
181
-
182
- If `fill` is specified, the allocated `Buffer` will be initialized by calling
183
- `buf.fill(fill)`. See [`buf.fill()`][] for more information.
184
-
185
- ```js
186
- const buf = Buffer.alloc(5, 'a');
187
- console.log(buf);
188
- // <Buffer 61 61 61 61 61>
189
- ```
190
-
191
- If both `fill` and `encoding` are specified, the allocated `Buffer` will be
192
- initialized by calling `buf.fill(fill, encoding)`. For example:
193
-
194
- ```js
195
- const buf = Buffer.alloc(11, 'aGVsbG8gd29ybGQ=', 'base64');
196
- console.log(buf);
197
- // <Buffer 68 65 6c 6c 6f 20 77 6f 72 6c 64>
198
- ```
199
-
200
- Calling `Buffer.alloc(size)` can be significantly slower than the alternative
201
- `Buffer.allocUnsafe(size)` but ensures that the newly created `Buffer` instance
202
- contents will *never contain sensitive data*.
203
-
204
- A `TypeError` will be thrown if `size` is not a number.
205
-
206
- ### Class Method: Buffer.allocUnsafe(size)
207
- <!-- YAML
208
- added: v5.10.0
209
- -->
210
-
211
- * `size` {Number}
212
-
213
- Allocates a new *non-zero-filled* `Buffer` of `size` bytes. The `size` must
214
- be less than or equal to the value of `require('buffer').kMaxLength` (on 64-bit
215
- architectures, `kMaxLength` is `(2^31)-1`). Otherwise, a [`RangeError`][] is
216
- thrown. A zero-length Buffer will be created if a `size` less than or equal to
217
- 0 is specified.
218
-
219
- The underlying memory for `Buffer` instances created in this way is *not
220
- initialized*. The contents of the newly created `Buffer` are unknown and
221
- *may contain sensitive data*. Use [`buf.fill(0)`][] to initialize such
222
- `Buffer` instances to zeroes.
223
-
224
- ```js
225
- const buf = Buffer.allocUnsafe(5);
226
- console.log(buf);
227
- // <Buffer 78 e0 82 02 01>
228
- // (octets will be different, every time)
229
- buf.fill(0);
230
- console.log(buf);
231
- // <Buffer 00 00 00 00 00>
232
- ```
233
-
234
- A `TypeError` will be thrown if `size` is not a number.
235
-
236
- Note that the `Buffer` module pre-allocates an internal `Buffer` instance of
237
- size `Buffer.poolSize` that is used as a pool for the fast allocation of new
238
- `Buffer` instances created using `Buffer.allocUnsafe(size)` (and the deprecated
239
- `new Buffer(size)` constructor) only when `size` is less than or equal to
240
- `Buffer.poolSize >> 1` (floor of `Buffer.poolSize` divided by two). The default
241
- value of `Buffer.poolSize` is `8192` but can be modified.
242
-
243
- Use of this pre-allocated internal memory pool is a key difference between
244
- calling `Buffer.alloc(size, fill)` vs. `Buffer.allocUnsafe(size).fill(fill)`.
245
- Specifically, `Buffer.alloc(size, fill)` will *never* use the internal Buffer
246
- pool, while `Buffer.allocUnsafe(size).fill(fill)` *will* use the internal
247
- Buffer pool if `size` is less than or equal to half `Buffer.poolSize`. The
248
- difference is subtle but can be important when an application requires the
249
- additional performance that `Buffer.allocUnsafe(size)` provides.
250
-
251
- ### Class Method: Buffer.allocUnsafeSlow(size)
252
- <!-- YAML
253
- added: v5.10.0
254
- -->
255
-
256
- * `size` {Number}
257
-
258
- Allocates a new *non-zero-filled* and non-pooled `Buffer` of `size` bytes. The
259
- `size` must be less than or equal to the value of
260
- `require('buffer').kMaxLength` (on 64-bit architectures, `kMaxLength` is
261
- `(2^31)-1`). Otherwise, a [`RangeError`][] is thrown. A zero-length Buffer will
262
- be created if a `size` less than or equal to 0 is specified.
263
-
264
- The underlying memory for `Buffer` instances created in this way is *not
265
- initialized*. The contents of the newly created `Buffer` are unknown and
266
- *may contain sensitive data*. Use [`buf.fill(0)`][] to initialize such
267
- `Buffer` instances to zeroes.
268
-
269
- When using `Buffer.allocUnsafe()` to allocate new `Buffer` instances,
270
- allocations under 4KB are, by default, sliced from a single pre-allocated
271
- `Buffer`. This allows applications to avoid the garbage collection overhead of
272
- creating many individually allocated Buffers. This approach improves both
273
- performance and memory usage by eliminating the need to track and cleanup as
274
- many `Persistent` objects.
275
-
276
- However, in the case where a developer may need to retain a small chunk of
277
- memory from a pool for an indeterminate amount of time, it may be appropriate
278
- to create an un-pooled Buffer instance using `Buffer.allocUnsafeSlow()` then
279
- copy out the relevant bits.
280
-
281
- ```js
282
- // need to keep around a few small chunks of memory
283
- const store = [];
284
-
285
- socket.on('readable', () => {
286
- const data = socket.read();
287
- // allocate for retained data
288
- const sb = Buffer.allocUnsafeSlow(10);
289
- // copy the data into the new allocation
290
- data.copy(sb, 0, 0, 10);
291
- store.push(sb);
292
- });
293
- ```
294
-
295
- Use of `Buffer.allocUnsafeSlow()` should be used only as a last resort *after*
296
- a developer has observed undue memory retention in their applications.
297
-
298
- A `TypeError` will be thrown if `size` is not a number.
299
-
300
- ### All the Rest
301
-
302
- The rest of the `Buffer` API is exactly the same as in node.js.
303
- [See the docs](https://nodejs.org/api/buffer.html).
304
-
305
-
306
- ## Related links
307
-
308
- - [Node.js issue: Buffer(number) is unsafe](https://github.com/nodejs/node/issues/4660)
309
- - [Node.js Enhancement Proposal: Buffer.from/Buffer.alloc/Buffer.zalloc/Buffer() soft-deprecate](https://github.com/nodejs/node-eps/pull/4)
310
-
311
- ## Why is `Buffer` unsafe?
312
-
313
- Today, the node.js `Buffer` constructor is overloaded to handle many different argument
314
- types like `String`, `Array`, `Object`, `TypedArrayView` (`Uint8Array`, etc.),
315
- `ArrayBuffer`, and also `Number`.
316
-
317
- The API is optimized for convenience: you can throw any type at it, and it will try to do
318
- what you want.
319
-
320
- Because the Buffer constructor is so powerful, you often see code like this:
321
-
322
- ```js
323
- // Convert UTF-8 strings to hex
324
- function toHex (str) {
325
- return new Buffer(str).toString('hex')
326
- }
327
- ```
328
-
329
- ***But what happens if `toHex` is called with a `Number` argument?***
330
-
331
- ### Remote Memory Disclosure
332
-
333
- If an attacker can make your program call the `Buffer` constructor with a `Number`
334
- argument, then they can make it allocate uninitialized memory from the node.js process.
335
- This could potentially disclose TLS private keys, user data, or database passwords.
336
-
337
- When the `Buffer` constructor is passed a `Number` argument, it returns an
338
- **UNINITIALIZED** block of memory of the specified `size`. When you create a `Buffer` like
339
- this, you **MUST** overwrite the contents before returning it to the user.
340
-
341
- From the [node.js docs](https://nodejs.org/api/buffer.html#buffer_new_buffer_size):
342
-
343
- > `new Buffer(size)`
344
- >
345
- > - `size` Number
346
- >
347
- > The underlying memory for `Buffer` instances created in this way is not initialized.
348
- > **The contents of a newly created `Buffer` are unknown and could contain sensitive
349
- > data.** Use `buf.fill(0)` to initialize a Buffer to zeroes.
350
-
351
- (Emphasis our own.)
352
-
353
- Whenever the programmer intended to create an uninitialized `Buffer` you often see code
354
- like this:
355
-
356
- ```js
357
- var buf = new Buffer(16)
358
-
359
- // Immediately overwrite the uninitialized buffer with data from another buffer
360
- for (var i = 0; i < buf.length; i++) {
361
- buf[i] = otherBuf[i]
362
- }
363
- ```
364
-
365
-
366
- ### Would this ever be a problem in real code?
367
-
368
- Yes. It's surprisingly common to forget to check the type of your variables in a
369
- dynamically-typed language like JavaScript.
370
-
371
- Usually the consequences of assuming the wrong type is that your program crashes with an
372
- uncaught exception. But the failure mode for forgetting to check the type of arguments to
373
- the `Buffer` constructor is more catastrophic.
374
-
375
- Here's an example of a vulnerable service that takes a JSON payload and converts it to
376
- hex:
377
-
378
- ```js
379
- // Take a JSON payload {str: "some string"} and convert it to hex
380
- var server = http.createServer(function (req, res) {
381
- var data = ''
382
- req.setEncoding('utf8')
383
- req.on('data', function (chunk) {
384
- data += chunk
385
- })
386
- req.on('end', function () {
387
- var body = JSON.parse(data)
388
- res.end(new Buffer(body.str).toString('hex'))
389
- })
390
- })
391
-
392
- server.listen(8080)
393
- ```
394
-
395
- In this example, an http client just has to send:
396
-
397
- ```json
398
- {
399
- "str": 1000
400
- }
401
- ```
402
-
403
- and it will get back 1,000 bytes of uninitialized memory from the server.
404
-
405
- This is a very serious bug. It's similar in severity to the
406
- [the Heartbleed bug](http://heartbleed.com/) that allowed disclosure of OpenSSL process
407
- memory by remote attackers.
408
-
409
-
410
- ### Which real-world packages were vulnerable?
411
-
412
- #### [`bittorrent-dht`](https://www.npmjs.com/package/bittorrent-dht)
413
-
414
- [Mathias Buus](https://github.com/mafintosh) and I
415
- ([Feross Aboukhadijeh](http://feross.org/)) found this issue in one of our own packages,
416
- [`bittorrent-dht`](https://www.npmjs.com/package/bittorrent-dht). The bug would allow
417
- anyone on the internet to send a series of messages to a user of `bittorrent-dht` and get
418
- them to reveal 20 bytes at a time of uninitialized memory from the node.js process.
419
-
420
- Here's
421
- [the commit](https://github.com/feross/bittorrent-dht/commit/6c7da04025d5633699800a99ec3fbadf70ad35b8)
422
- that fixed it. We released a new fixed version, created a
423
- [Node Security Project disclosure](https://nodesecurity.io/advisories/68), and deprecated all
424
- vulnerable versions on npm so users will get a warning to upgrade to a newer version.
425
-
426
- #### [`ws`](https://www.npmjs.com/package/ws)
427
-
428
- That got us wondering if there were other vulnerable packages. Sure enough, within a short
429
- period of time, we found the same issue in [`ws`](https://www.npmjs.com/package/ws), the
430
- most popular WebSocket implementation in node.js.
431
-
432
- If certain APIs were called with `Number` parameters instead of `String` or `Buffer` as
433
- expected, then uninitialized server memory would be disclosed to the remote peer.
434
-
435
- These were the vulnerable methods:
436
-
437
- ```js
438
- socket.send(number)
439
- socket.ping(number)
440
- socket.pong(number)
441
- ```
442
-
443
- Here's a vulnerable socket server with some echo functionality:
444
-
445
- ```js
446
- server.on('connection', function (socket) {
447
- socket.on('message', function (message) {
448
- message = JSON.parse(message)
449
- if (message.type === 'echo') {
450
- socket.send(message.data) // send back the user's message
451
- }
452
- })
453
- })
454
- ```
455
-
456
- `socket.send(number)` called on the server, will disclose server memory.
457
-
458
- Here's [the release](https://github.com/websockets/ws/releases/tag/1.0.1) where the issue
459
- was fixed, with a more detailed explanation. Props to
460
- [Arnout Kazemier](https://github.com/3rd-Eden) for the quick fix. Here's the
461
- [Node Security Project disclosure](https://nodesecurity.io/advisories/67).
462
-
463
-
464
- ### What's the solution?
465
-
466
- It's important that node.js offers a fast way to get memory otherwise performance-critical
467
- applications would needlessly get a lot slower.
468
-
469
- But we need a better way to *signal our intent* as programmers. **When we want
470
- uninitialized memory, we should request it explicitly.**
471
-
472
- Sensitive functionality should not be packed into a developer-friendly API that loosely
473
- accepts many different types. This type of API encourages the lazy practice of passing
474
- variables in without checking the type very carefully.
475
-
476
- #### A new API: `Buffer.allocUnsafe(number)`
477
-
478
- The functionality of creating buffers with uninitialized memory should be part of another
479
- API. We propose `Buffer.allocUnsafe(number)`. This way, it's not part of an API that
480
- frequently gets user input of all sorts of different types passed into it.
481
-
482
- ```js
483
- var buf = Buffer.allocUnsafe(16) // careful, uninitialized memory!
484
-
485
- // Immediately overwrite the uninitialized buffer with data from another buffer
486
- for (var i = 0; i < buf.length; i++) {
487
- buf[i] = otherBuf[i]
488
- }
489
- ```
490
-
491
-
492
- ### How do we fix node.js core?
493
-
494
- We sent [a PR to node.js core](https://github.com/nodejs/node/pull/4514) (merged as
495
- `semver-major`) which defends against one case:
496
-
497
- ```js
498
- var str = 16
499
- new Buffer(str, 'utf8')
500
- ```
501
-
502
- In this situation, it's implied that the programmer intended the first argument to be a
503
- string, since they passed an encoding as a second argument. Today, node.js will allocate
504
- uninitialized memory in the case of `new Buffer(number, encoding)`, which is probably not
505
- what the programmer intended.
506
-
507
- But this is only a partial solution, since if the programmer does `new Buffer(variable)`
508
- (without an `encoding` parameter) there's no way to know what they intended. If `variable`
509
- is sometimes a number, then uninitialized memory will sometimes be returned.
510
-
511
- ### What's the real long-term fix?
512
-
513
- We could deprecate and remove `new Buffer(number)` and use `Buffer.allocUnsafe(number)` when
514
- we need uninitialized memory. But that would break 1000s of packages.
515
-
516
- ~~We believe the best solution is to:~~
517
-
518
- ~~1. Change `new Buffer(number)` to return safe, zeroed-out memory~~
519
-
520
- ~~2. Create a new API for creating uninitialized Buffers. We propose: `Buffer.allocUnsafe(number)`~~
521
-
522
- #### Update
523
-
524
- We now support adding three new APIs:
525
-
526
- - `Buffer.from(value)` - convert from any type to a buffer
527
- - `Buffer.alloc(size)` - create a zero-filled buffer
528
- - `Buffer.allocUnsafe(size)` - create an uninitialized buffer with given size
529
-
530
- This solves the core problem that affected `ws` and `bittorrent-dht` which is
531
- `Buffer(variable)` getting tricked into taking a number argument.
532
-
533
- This way, existing code continues working and the impact on the npm ecosystem will be
534
- minimal. Over time, npm maintainers can migrate performance-critical code to use
535
- `Buffer.allocUnsafe(number)` instead of `new Buffer(number)`.
536
-
537
-
538
- ### Conclusion
539
-
540
- We think there's a serious design issue with the `Buffer` API as it exists today. It
541
- promotes insecure software by putting high-risk functionality into a convenient API
542
- with friendly "developer ergonomics".
543
-
544
- This wasn't merely a theoretical exercise because we found the issue in some of the
545
- most popular npm packages.
546
-
547
- Fortunately, there's an easy fix that can be applied today. Use `safe-buffer` in place of
548
- `buffer`.
549
-
550
- ```js
551
- var Buffer = require('safe-buffer').Buffer
552
- ```
553
-
554
- Eventually, we hope that node.js core can switch to this new, safer behavior. We believe
555
- the impact on the ecosystem would be minimal since it's not a breaking change.
556
- Well-maintained, popular packages would be updated to use `Buffer.alloc` quickly, while
557
- older, insecure packages would magically become safe from this attack vector.
558
-
559
-
560
- ## links
561
-
562
- - [Node.js PR: buffer: throw if both length and enc are passed](https://github.com/nodejs/node/pull/4514)
563
- - [Node Security Project disclosure for `ws`](https://nodesecurity.io/advisories/67)
564
- - [Node Security Project disclosure for`bittorrent-dht`](https://nodesecurity.io/advisories/68)
565
-
566
-
567
- ## credit
568
-
569
- The original issues in `bittorrent-dht`
570
- ([disclosure](https://nodesecurity.io/advisories/68)) and
571
- `ws` ([disclosure](https://nodesecurity.io/advisories/67)) were discovered by
572
- [Mathias Buus](https://github.com/mafintosh) and
573
- [Feross Aboukhadijeh](http://feross.org/).
574
-
575
- Thanks to [Adam Baldwin](https://github.com/evilpacket) for helping disclose these issues
576
- and for his work running the [Node Security Project](https://nodesecurity.io/).
577
-
578
- Thanks to [John Hiesey](https://github.com/jhiesey) for proofreading this README and
579
- auditing the code.
580
-
581
-
582
- ## license
583
-
584
- MIT. Copyright (C) [Feross Aboukhadijeh](http://feross.org)