@cloudant/couchbackup 2.9.11 → 2.9.12-SNAPSHOT.124

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.
Files changed (392) hide show
  1. package/.scannerwork/report-task.txt +2 -2
  2. package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
  3. package/.scannerwork/scanner-report/changesets-16.pb +1 -0
  4. package/.scannerwork/scanner-report/changesets-17.pb +1 -0
  5. package/.scannerwork/scanner-report/changesets-18.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-20.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-22.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-26.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-27.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-32.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-33.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-34.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-35.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-36.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-57.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-60.pb +1 -0
  17. package/.scannerwork/scanner-report/changesets-61.pb +1 -0
  18. package/.scannerwork/scanner-report/changesets-63.pb +1 -0
  19. package/.scannerwork/scanner-report/changesets-64.pb +1 -0
  20. package/.scannerwork/scanner-report/component-1.pb +2 -2
  21. package/.scannerwork/scanner-report/component-10.pb +1 -1
  22. package/.scannerwork/scanner-report/component-11.pb +1 -1
  23. package/.scannerwork/scanner-report/component-12.pb +1 -1
  24. package/.scannerwork/scanner-report/component-13.pb +1 -1
  25. package/.scannerwork/scanner-report/component-15.pb +1 -1
  26. package/.scannerwork/scanner-report/component-16.pb +1 -1
  27. package/.scannerwork/scanner-report/component-17.pb +1 -0
  28. package/.scannerwork/scanner-report/component-18.pb +1 -1
  29. package/.scannerwork/scanner-report/component-19.pb +1 -1
  30. package/.scannerwork/scanner-report/component-2.pb +1 -1
  31. package/.scannerwork/scanner-report/component-20.pb +1 -0
  32. package/.scannerwork/scanner-report/component-22.pb +1 -0
  33. package/.scannerwork/scanner-report/component-24.pb +1 -1
  34. package/.scannerwork/scanner-report/component-26.pb +1 -0
  35. package/.scannerwork/scanner-report/component-27.pb +1 -0
  36. package/.scannerwork/scanner-report/component-3.pb +1 -1
  37. package/.scannerwork/scanner-report/component-32.pb +1 -0
  38. package/.scannerwork/scanner-report/component-33.pb +1 -0
  39. package/.scannerwork/scanner-report/component-34.pb +1 -0
  40. package/.scannerwork/scanner-report/component-35.pb +1 -0
  41. package/.scannerwork/scanner-report/component-36.pb +1 -0
  42. package/.scannerwork/scanner-report/component-37.pb +1 -1
  43. package/.scannerwork/scanner-report/component-38.pb +1 -1
  44. package/.scannerwork/scanner-report/component-39.pb +1 -1
  45. package/.scannerwork/scanner-report/component-40.pb +1 -1
  46. package/.scannerwork/scanner-report/component-5.pb +1 -1
  47. package/.scannerwork/scanner-report/component-52.pb +1 -1
  48. package/.scannerwork/scanner-report/component-53.pb +1 -1
  49. package/.scannerwork/scanner-report/component-54.pb +1 -1
  50. package/.scannerwork/scanner-report/component-55.pb +1 -1
  51. package/.scannerwork/scanner-report/component-56.pb +1 -1
  52. package/.scannerwork/scanner-report/component-57.pb +1 -0
  53. package/.scannerwork/scanner-report/component-58.pb +1 -1
  54. package/.scannerwork/scanner-report/component-59.pb +1 -1
  55. package/.scannerwork/scanner-report/component-6.pb +1 -1
  56. package/.scannerwork/scanner-report/component-60.pb +1 -0
  57. package/.scannerwork/scanner-report/component-61.pb +1 -0
  58. package/.scannerwork/scanner-report/component-62.pb +1 -1
  59. package/.scannerwork/scanner-report/component-63.pb +1 -1
  60. package/.scannerwork/scanner-report/component-64.pb +1 -0
  61. package/.scannerwork/scanner-report/component-67.pb +1 -1
  62. package/.scannerwork/scanner-report/component-7.pb +1 -1
  63. package/.scannerwork/scanner-report/component-9.pb +1 -1
  64. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  65. package/.scannerwork/scanner-report/coverages-11.pb +0 -0
  66. package/.scannerwork/scanner-report/coverages-12.pb +0 -0
  67. package/.scannerwork/scanner-report/coverages-13.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-15.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-16.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-19.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-3.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  77. package/.scannerwork/scanner-report/coverages-35.pb +0 -0
  78. package/.scannerwork/scanner-report/coverages-36.pb +0 -0
  79. package/.scannerwork/scanner-report/coverages-37.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-38.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-39.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-40.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-60.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-67.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-9.pb +0 -0
  97. package/.scannerwork/scanner-report/duplications-12.pb +0 -2
  98. package/.scannerwork/scanner-report/duplications-13.pb +0 -2
  99. package/.scannerwork/scanner-report/duplications-19.pb +2 -0
  100. package/.scannerwork/scanner-report/duplications-22.pb +2 -0
  101. package/.scannerwork/scanner-report/duplications-24.pb +2 -3
  102. package/.scannerwork/scanner-report/duplications-33.pb +2 -0
  103. package/.scannerwork/scanner-report/duplications-37.pb +3 -0
  104. package/.scannerwork/scanner-report/duplications-38.pb +0 -2
  105. package/.scannerwork/scanner-report/duplications-52.pb +3 -0
  106. package/.scannerwork/scanner-report/duplications-53.pb +2 -0
  107. package/.scannerwork/scanner-report/duplications-56.pb +0 -2
  108. package/.scannerwork/scanner-report/duplications-59.pb +0 -2
  109. package/.scannerwork/scanner-report/duplications-60.pb +3 -0
  110. package/.scannerwork/scanner-report/duplications-62.pb +2 -0
  111. package/.scannerwork/scanner-report/duplications-7.pb +2 -0
  112. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  113. package/.scannerwork/scanner-report/measures-11.pb +0 -0
  114. package/.scannerwork/scanner-report/measures-12.pb +0 -0
  115. package/.scannerwork/scanner-report/measures-13.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-15.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-16.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-17.pb +16 -0
  119. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-3.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-33.pb +15 -0
  127. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-60.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-63.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  150. package/.scannerwork/scanner-report/metadata.pb +0 -0
  151. package/.scannerwork/scanner-report/source-10.txt +37 -147
  152. package/.scannerwork/scanner-report/source-11.txt +25 -59
  153. package/.scannerwork/scanner-report/source-12.txt +86 -50
  154. package/.scannerwork/scanner-report/source-13.txt +59 -71
  155. package/.scannerwork/scanner-report/source-15.txt +98 -34
  156. package/.scannerwork/scanner-report/source-16.txt +164 -167
  157. package/.scannerwork/scanner-report/source-17.txt +178 -0
  158. package/.scannerwork/scanner-report/source-18.txt +281 -509
  159. package/.scannerwork/scanner-report/source-19.txt +52 -395
  160. package/.scannerwork/scanner-report/source-2.txt +167 -178
  161. package/.scannerwork/scanner-report/source-22.txt +190 -0
  162. package/.scannerwork/scanner-report/source-24.txt +156 -225
  163. package/.scannerwork/scanner-report/source-27.txt +77 -0
  164. package/.scannerwork/scanner-report/source-3.txt +96 -100
  165. package/.scannerwork/scanner-report/source-33.txt +293 -0
  166. package/.scannerwork/scanner-report/source-35.txt +68 -0
  167. package/.scannerwork/scanner-report/source-36.txt +36 -0
  168. package/.scannerwork/scanner-report/source-37.txt +96 -6
  169. package/.scannerwork/scanner-report/source-38.txt +120 -189
  170. package/.scannerwork/scanner-report/source-39.txt +606 -17
  171. package/.scannerwork/scanner-report/source-40.txt +11 -38
  172. package/.scannerwork/scanner-report/source-5.txt +509 -46
  173. package/.scannerwork/scanner-report/source-52.txt +101 -62
  174. package/.scannerwork/scanner-report/source-53.txt +126 -28
  175. package/.scannerwork/scanner-report/source-54.txt +41 -598
  176. package/.scannerwork/scanner-report/source-55.txt +125 -51
  177. package/.scannerwork/scanner-report/source-56.txt +108 -254
  178. package/.scannerwork/scanner-report/source-57.txt +92 -0
  179. package/.scannerwork/scanner-report/source-58.txt +11 -172
  180. package/.scannerwork/scanner-report/source-59.txt +40 -152
  181. package/.scannerwork/scanner-report/source-6.txt +509 -104
  182. package/.scannerwork/scanner-report/source-60.txt +244 -0
  183. package/.scannerwork/scanner-report/source-62.txt +200 -89
  184. package/.scannerwork/scanner-report/source-63.txt +100 -509
  185. package/.scannerwork/scanner-report/source-64.txt +47 -0
  186. package/.scannerwork/scanner-report/source-67.txt +395 -54
  187. package/.scannerwork/scanner-report/source-7.txt +65 -254
  188. package/.scannerwork/scanner-report/source-9.txt +81 -88
  189. package/.scannerwork/scanner-report/symbols-10.pb +15 -126
  190. package/.scannerwork/scanner-report/symbols-11.pb +19 -45
  191. package/.scannerwork/scanner-report/symbols-12.pb +58 -41
  192. package/.scannerwork/scanner-report/symbols-13.pb +45 -43
  193. package/.scannerwork/scanner-report/symbols-15.pb +30 -15
  194. package/.scannerwork/scanner-report/symbols-16.pb +126 -0
  195. package/.scannerwork/scanner-report/symbols-18.pb +354 -0
  196. package/.scannerwork/scanner-report/symbols-19.pb +42 -610
  197. package/.scannerwork/scanner-report/symbols-22.pb +180 -0
  198. package/.scannerwork/scanner-report/symbols-24.pb +145 -386
  199. package/.scannerwork/scanner-report/symbols-27.pb +30 -0
  200. package/.scannerwork/scanner-report/symbols-3.pb +27 -29
  201. package/.scannerwork/scanner-report/symbols-33.pb +486 -0
  202. package/.scannerwork/scanner-report/symbols-35.pb +36 -0
  203. package/.scannerwork/scanner-report/symbols-36.pb +11 -0
  204. package/.scannerwork/scanner-report/symbols-37.pb +77 -9
  205. package/.scannerwork/scanner-report/symbols-38.pb +104 -410
  206. package/.scannerwork/scanner-report/symbols-39.pb +1254 -11
  207. package/.scannerwork/scanner-report/symbols-40.pb +14 -43
  208. package/.scannerwork/scanner-report/symbols-52.pb +97 -60
  209. package/.scannerwork/scanner-report/symbols-53.pb +102 -27
  210. package/.scannerwork/scanner-report/symbols-54.pb +44 -1253
  211. package/.scannerwork/scanner-report/symbols-55.pb +116 -36
  212. package/.scannerwork/scanner-report/symbols-56.pb +85 -486
  213. package/.scannerwork/scanner-report/symbols-57.pb +60 -0
  214. package/.scannerwork/scanner-report/symbols-58.pb +9 -180
  215. package/.scannerwork/scanner-report/symbols-59.pb +42 -152
  216. package/.scannerwork/scanner-report/symbols-60.pb +394 -0
  217. package/.scannerwork/scanner-report/symbols-62.pb +417 -27
  218. package/.scannerwork/scanner-report/symbols-64.pb +27 -0
  219. package/.scannerwork/scanner-report/symbols-67.pb +610 -30
  220. package/.scannerwork/scanner-report/symbols-7.pb +44 -354
  221. package/.scannerwork/scanner-report/symbols-9.pb +41 -58
  222. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +20 -179
  223. package/.scannerwork/scanner-report/syntax-highlightings-11.pb +30 -61
  224. package/.scannerwork/scanner-report/syntax-highlightings-12.pb +94 -39
  225. package/.scannerwork/scanner-report/syntax-highlightings-13.pb +57 -52
  226. package/.scannerwork/scanner-report/syntax-highlightings-15.pb +81 -22
  227. package/.scannerwork/scanner-report/syntax-highlightings-16.pb +192 -927
  228. package/.scannerwork/scanner-report/syntax-highlightings-17.pb +243 -0
  229. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +199 -3662
  230. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +47 -617
  231. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +915 -209
  232. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +225 -0
  233. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +169 -284
  234. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +103 -0
  235. package/.scannerwork/scanner-report/syntax-highlightings-3.pb +104 -79
  236. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +659 -0
  237. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +95 -0
  238. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +59 -0
  239. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +123 -13
  240. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +162 -270
  241. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +853 -25
  242. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +19 -47
  243. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +3737 -53
  244. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +144 -72
  245. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +188 -29
  246. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +66 -843
  247. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +98 -59
  248. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +142 -610
  249. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +110 -0
  250. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +19 -196
  251. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +52 -184
  252. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +3737 -105
  253. package/.scannerwork/scanner-report/syntax-highlightings-60.pb +329 -0
  254. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +296 -103
  255. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +94 -3738
  256. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +68 -0
  257. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +623 -78
  258. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +48 -243
  259. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +79 -96
  260. package/package.json +2 -2
  261. package/test-16-results.xml +160 -160
  262. package/test-18-results.xml +160 -160
  263. package/test-iam-18-results.xml +50 -50
  264. package/.scannerwork/scanner-report/changesets-2.pb +0 -1
  265. package/.scannerwork/scanner-report/changesets-25.pb +0 -1
  266. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  267. package/.scannerwork/scanner-report/changesets-41.pb +0 -1
  268. package/.scannerwork/scanner-report/changesets-42.pb +0 -1
  269. package/.scannerwork/scanner-report/changesets-43.pb +0 -1
  270. package/.scannerwork/scanner-report/changesets-44.pb +0 -1
  271. package/.scannerwork/scanner-report/changesets-45.pb +0 -1
  272. package/.scannerwork/scanner-report/changesets-46.pb +0 -1
  273. package/.scannerwork/scanner-report/changesets-47.pb +0 -1
  274. package/.scannerwork/scanner-report/changesets-48.pb +0 -1
  275. package/.scannerwork/scanner-report/changesets-49.pb +0 -1
  276. package/.scannerwork/scanner-report/changesets-5.pb +0 -1
  277. package/.scannerwork/scanner-report/changesets-50.pb +0 -1
  278. package/.scannerwork/scanner-report/changesets-51.pb +0 -1
  279. package/.scannerwork/scanner-report/changesets-6.pb +0 -1
  280. package/.scannerwork/scanner-report/changesets-68.pb +0 -1
  281. package/.scannerwork/scanner-report/component-25.pb +0 -1
  282. package/.scannerwork/scanner-report/component-4.pb +0 -1
  283. package/.scannerwork/scanner-report/component-41.pb +0 -1
  284. package/.scannerwork/scanner-report/component-42.pb +0 -1
  285. package/.scannerwork/scanner-report/component-43.pb +0 -1
  286. package/.scannerwork/scanner-report/component-44.pb +0 -1
  287. package/.scannerwork/scanner-report/component-45.pb +0 -1
  288. package/.scannerwork/scanner-report/component-46.pb +0 -1
  289. package/.scannerwork/scanner-report/component-47.pb +0 -1
  290. package/.scannerwork/scanner-report/component-48.pb +0 -1
  291. package/.scannerwork/scanner-report/component-49.pb +0 -1
  292. package/.scannerwork/scanner-report/component-50.pb +0 -1
  293. package/.scannerwork/scanner-report/component-51.pb +0 -1
  294. package/.scannerwork/scanner-report/component-68.pb +0 -1
  295. package/.scannerwork/scanner-report/coverages-25.pb +0 -0
  296. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  297. package/.scannerwork/scanner-report/coverages-43.pb +0 -0
  298. package/.scannerwork/scanner-report/coverages-44.pb +0 -0
  299. package/.scannerwork/scanner-report/coverages-45.pb +0 -0
  300. package/.scannerwork/scanner-report/coverages-46.pb +0 -0
  301. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  302. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  303. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  304. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  305. package/.scannerwork/scanner-report/duplications-45.pb +0 -2
  306. package/.scannerwork/scanner-report/duplications-46.pb +0 -3
  307. package/.scannerwork/scanner-report/duplications-48.pb +0 -3
  308. package/.scannerwork/scanner-report/duplications-58.pb +0 -2
  309. package/.scannerwork/scanner-report/measures-25.pb +0 -0
  310. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  311. package/.scannerwork/scanner-report/measures-43.pb +0 -0
  312. package/.scannerwork/scanner-report/measures-44.pb +0 -0
  313. package/.scannerwork/scanner-report/measures-45.pb +0 -0
  314. package/.scannerwork/scanner-report/measures-46.pb +0 -0
  315. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  316. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  317. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  318. package/.scannerwork/scanner-report/source-25.txt +0 -142
  319. package/.scannerwork/scanner-report/source-42.txt +0 -68
  320. package/.scannerwork/scanner-report/source-43.txt +0 -156
  321. package/.scannerwork/scanner-report/source-44.txt +0 -147
  322. package/.scannerwork/scanner-report/source-45.txt +0 -145
  323. package/.scannerwork/scanner-report/source-46.txt +0 -131
  324. package/.scannerwork/scanner-report/source-48.txt +0 -119
  325. package/.scannerwork/scanner-report/source-49.txt +0 -100
  326. package/.scannerwork/scanner-report/source-50.txt +0 -36
  327. package/.scannerwork/scanner-report/symbols-25.pb +0 -116
  328. package/.scannerwork/scanner-report/symbols-42.pb +0 -45
  329. package/.scannerwork/scanner-report/symbols-43.pb +0 -112
  330. package/.scannerwork/scanner-report/symbols-44.pb +0 -85
  331. package/.scannerwork/scanner-report/symbols-45.pb +0 -102
  332. package/.scannerwork/scanner-report/symbols-46.pb +0 -97
  333. package/.scannerwork/scanner-report/symbols-48.pb +0 -77
  334. package/.scannerwork/scanner-report/symbols-5.pb +0 -20
  335. package/.scannerwork/scanner-report/symbols-50.pb +0 -14
  336. package/.scannerwork/scanner-report/symbols-6.pb +0 -42
  337. package/.scannerwork/scanner-report/syntax-highlightings-25.pb +0 -134
  338. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +0 -110
  339. package/.scannerwork/scanner-report/syntax-highlightings-43.pb +0 -223
  340. package/.scannerwork/scanner-report/syntax-highlightings-44.pb +0 -191
  341. package/.scannerwork/scanner-report/syntax-highlightings-45.pb +0 -227
  342. package/.scannerwork/scanner-report/syntax-highlightings-46.pb +0 -182
  343. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +0 -158
  344. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +0 -105
  345. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +0 -54
  346. /package/.scannerwork/scanner-report/{coverages-2.pb → coverages-17.pb} +0 -0
  347. /package/.scannerwork/scanner-report/{coverages-4.pb → coverages-20.pb} +0 -0
  348. /package/.scannerwork/scanner-report/{coverages-68.pb → coverages-26.pb} +0 -0
  349. /package/.scannerwork/scanner-report/{coverages-51.pb → coverages-32.pb} +0 -0
  350. /package/.scannerwork/scanner-report/{coverages-41.pb → coverages-34.pb} +0 -0
  351. /package/.scannerwork/scanner-report/{coverages-47.pb → coverages-61.pb} +0 -0
  352. /package/.scannerwork/scanner-report/{coverages-49.pb → coverages-63.pb} +0 -0
  353. /package/.scannerwork/scanner-report/{duplications-2.pb → duplications-16.pb} +0 -0
  354. /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-17.pb} +0 -0
  355. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-18.pb} +0 -0
  356. /package/.scannerwork/scanner-report/{duplications-41.pb → duplications-20.pb} +0 -0
  357. /package/.scannerwork/scanner-report/{duplications-42.pb → duplications-26.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{duplications-43.pb → duplications-27.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{duplications-44.pb → duplications-32.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{duplications-47.pb → duplications-34.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{duplications-49.pb → duplications-35.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{duplications-5.pb → duplications-36.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{duplications-50.pb → duplications-57.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{duplications-51.pb → duplications-61.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{duplications-6.pb → duplications-63.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{duplications-68.pb → duplications-64.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{issues-41.pb → issues-34.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{issues-25.pb → issues-55.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{issues-24.pb → issues-60.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{issues-53.pb → issues-64.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{measures-4.pb → measures-20.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{measures-68.pb → measures-26.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{measures-51.pb → measures-32.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{measures-41.pb → measures-34.pb} +0 -0
  375. /package/.scannerwork/scanner-report/{measures-47.pb → measures-61.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{source-4.txt → source-20.txt} +0 -0
  377. /package/.scannerwork/scanner-report/{source-68.txt → source-26.txt} +0 -0
  378. /package/.scannerwork/scanner-report/{source-51.txt → source-32.txt} +0 -0
  379. /package/.scannerwork/scanner-report/{source-41.txt → source-34.txt} +0 -0
  380. /package/.scannerwork/scanner-report/{source-47.txt → source-61.txt} +0 -0
  381. /package/.scannerwork/scanner-report/{symbols-2.pb → symbols-17.pb} +0 -0
  382. /package/.scannerwork/scanner-report/{symbols-4.pb → symbols-20.pb} +0 -0
  383. /package/.scannerwork/scanner-report/{symbols-68.pb → symbols-26.pb} +0 -0
  384. /package/.scannerwork/scanner-report/{symbols-51.pb → symbols-32.pb} +0 -0
  385. /package/.scannerwork/scanner-report/{symbols-41.pb → symbols-34.pb} +0 -0
  386. /package/.scannerwork/scanner-report/{symbols-47.pb → symbols-61.pb} +0 -0
  387. /package/.scannerwork/scanner-report/{symbols-49.pb → symbols-63.pb} +0 -0
  388. /package/.scannerwork/scanner-report/{syntax-highlightings-4.pb → syntax-highlightings-20.pb} +0 -0
  389. /package/.scannerwork/scanner-report/{syntax-highlightings-68.pb → syntax-highlightings-26.pb} +0 -0
  390. /package/.scannerwork/scanner-report/{syntax-highlightings-51.pb → syntax-highlightings-32.pb} +0 -0
  391. /package/.scannerwork/scanner-report/{syntax-highlightings-41.pb → syntax-highlightings-34.pb} +0 -0
  392. /package/.scannerwork/scanner-report/{syntax-highlightings-47.pb → syntax-highlightings-61.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2021 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2018 IBM Corp. All rights reserved.
2
2
  //
3
3
  // Licensed under the Apache License, Version 2.0 (the "License");
4
4
  // you may not use this file except in compliance with the License.
@@ -13,152 +13,42 @@
13
13
  // limitations under the License.
14
14
  'use strict';
15
15
 
16
- const async = require('async');
17
- const stream = require('stream');
18
- const error = require('./error.js');
19
- const debug = require('debug')('couchbackup:writer');
20
-
21
- module.exports = function(db, bufferSize, parallelism, ee) {
22
- const writer = new stream.Transform({ objectMode: true });
23
- let buffer = [];
24
- let written = 0;
25
- let linenumber = 0;
26
-
27
- // this is the queue of chunks that are written to the database
28
- // the queue's payload will be an array of documents to be written,
29
- // the size of the array will be bufferSize. The variable parallelism
30
- // determines how many HTTP requests will occur at any one time.
31
- const q = async.queue(function(payload, cb) {
32
- // if we are restoring known revisions, we need to supply new_edits=false
33
- if (payload.docs && payload.docs[0] && payload.docs[0]._rev) {
34
- payload.new_edits = false;
35
- debug('Using new_edits false mode.');
36
- }
37
-
38
- if (!didError) {
39
- db.service.postBulkDocs({
40
- db: db.db,
41
- bulkDocs: payload
42
- }).then(response => {
43
- if (!response.result || (payload.new_edits === false && response.result.length > 0)) {
44
- throw new Error(`Error writing batch with new_edits:${payload.new_edits !== false}` +
45
- ` and ${response.result ? response.result.length : 'unavailable'} items`);
46
- }
47
- written += payload.docs.length;
48
- writer.emit('restored', { documents: payload.docs.length, total: written });
49
- cb();
50
- }).catch(err => {
51
- err = error.convertResponseError(err);
52
- debug(`Error writing docs ${err.name} ${err.message}`);
53
- cb(err, payload);
54
- });
55
- }
56
- }, parallelism);
57
-
58
- let didError = false;
59
-
60
- // write the contents of the buffer to CouchDB in blocks of bufferSize
61
- function processBuffer(flush, callback) {
62
- function taskCallback(err, payload) {
63
- if (err && !didError) {
64
- debug(`Queue task failed with error ${err.name}`);
65
- didError = true;
66
- q.kill();
67
- writer.emit('error', err);
68
- }
69
- }
70
-
71
- if (flush || buffer.length >= bufferSize) {
72
- // work through the buffer to break off bufferSize chunks
73
- // and feed the chunks to the queue
74
- do {
75
- // split the buffer into bufferSize chunks
76
- const toSend = buffer.splice(0, bufferSize);
77
-
78
- // and add the chunk to the queue
79
- debug(`Adding ${toSend.length} to the write queue.`);
80
- q.push({ docs: toSend }, taskCallback);
81
- } while (buffer.length >= bufferSize);
82
-
83
- // send any leftover documents to the queue
84
- if (flush && buffer.length > 0) {
85
- debug(`Adding remaining ${buffer.length} to the write queue.`);
86
- q.push({ docs: buffer }, taskCallback);
87
- }
88
-
89
- // wait until the queue size falls to a reasonable level
90
- async.until(
91
- // wait until the queue length drops to twice the paralellism
92
- // or until empty on the last write
93
- function(callback) {
94
- // if we encountered an error, stop this until loop
95
- if (didError) {
96
- return callback(null, true);
97
- }
98
- if (flush) {
99
- callback(null, q.idle() && q.length() === 0);
100
- } else {
101
- callback(null, q.length() <= parallelism * 2);
102
- }
103
- },
104
- function(cb) {
105
- setTimeout(cb, 20);
106
- },
107
-
108
- function() {
109
- if (flush && !didError) {
110
- writer.emit('finished', { total: written });
111
- }
112
- // callback when we're happy with the queue size
113
- callback();
114
- });
115
- } else {
116
- callback();
16
+ /**
17
+ * Utility methods for the command line interface.
18
+ * @module cliutils
19
+ * @see module:cliutils
20
+ */
21
+
22
+ const url = require('url');
23
+
24
+ module.exports = {
25
+
26
+ /**
27
+ * Combine a base URL and a database name, ensuring at least single slash
28
+ * between root and database name. This allows users to have Couch behind
29
+ * proxies that mount Couch's / endpoint at some other mount point.
30
+ * @param {string} root - root URL
31
+ * @param {string} databaseName - database name
32
+ * @return concatenated URL.
33
+ *
34
+ * @private
35
+ */
36
+ databaseUrl: function databaseUrl(root, databaseName) {
37
+ if (!root.endsWith('/')) {
38
+ root = root + '/';
117
39
  }
40
+ return new url.URL(encodeURIComponent(databaseName), root).toString();
41
+ },
42
+
43
+ /**
44
+ * Generate CLI argument usage text.
45
+ *
46
+ * @param {string} description - argument description.
47
+ * @param {string} defaultValue - default argument value.
48
+ *
49
+ * @private
50
+ */
51
+ getUsage: function getUsage(description, defaultValue) {
52
+ return `${description} ${defaultValue !== undefined ? ` (default: ${defaultValue})` : ''}`;
118
53
  }
119
-
120
- // take an object
121
- writer._transform = function(obj, encoding, done) {
122
- // each obj that arrives here is a line from the backup file
123
- // it should contain an array of objects. The length of the array
124
- // depends on the bufferSize at backup time.
125
- linenumber++;
126
- if (!didError && obj !== '') {
127
- // see if it parses as JSON
128
- try {
129
- const arr = JSON.parse(obj);
130
-
131
- // if it's an array with a length
132
- if (typeof arr === 'object' && arr.length > 0) {
133
- // push each document into a buffer
134
- buffer = buffer.concat(arr);
135
-
136
- // pause the stream
137
- // it's likely that the speed with which data can be read from disk
138
- // may exceed the rate it can be written to CouchDB. To prevent
139
- // the whole file being buffered in memory, we pause the stream here.
140
- // it is resumed, when processBuffer calls back and we call done()
141
- this.pause();
142
-
143
- // break the buffer in to bufferSize chunks to be written to the database
144
- processBuffer(false, done);
145
- } else {
146
- ee.emit('error', new error.BackupError('BackupFileJsonError', `Error on line ${linenumber} of backup file - not an array`));
147
- done();
148
- }
149
- } catch (e) {
150
- ee.emit('error', new error.BackupError('BackupFileJsonError', `Error on line ${linenumber} of backup file - cannot parse as JSON`));
151
- // Could be an incomplete write that was subsequently resumed
152
- done();
153
- }
154
- } else {
155
- done();
156
- }
157
- };
158
-
159
- // called when we need to flush everything
160
- writer._flush = function(done) {
161
- processBuffer(true, done);
162
- };
163
- return writer;
164
54
  };
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2022 IBM Corp. All rights reserved.
1
+ // Copyright © 2017 IBM Corp. All rights reserved.
2
2
  //
3
3
  // Licensed under the Apache License, Version 2.0 (the "License");
4
4
  // you may not use this file except in compliance with the License.
@@ -13,68 +13,34 @@
13
13
  // limitations under the License.
14
14
  'use strict';
15
15
 
16
- const async = require('async');
17
- const error = require('./error.js');
18
- const events = require('events');
16
+ // stolen from http://strongloop.com/strongblog/practical-examples-of-the-new-node-js-streams-api/
17
+ const stream = require('stream');
19
18
 
20
- module.exports = function(db, options) {
21
- const ee = new events.EventEmitter();
22
- const start = new Date().getTime();
23
- let batch = 0;
24
- let hasErrored = false;
25
- let startKey = null;
26
- let total = 0;
19
+ module.exports = function() {
20
+ const liner = new stream.Transform({ objectMode: true });
27
21
 
28
- async.doUntil(
29
- function(callback) {
30
- // Note, include_docs: true is set automatically when using the
31
- // fetch function.
32
- const opts = { db: db.db, limit: options.bufferSize, includeDocs: true };
22
+ liner._transform = function(chunk, encoding, done) {
23
+ let data = chunk.toString();
24
+ if (this._lastLineData) {
25
+ data = this._lastLineData + data;
26
+ }
33
27
 
34
- // To avoid double fetching a document solely for the purposes of getting
35
- // the next ID to use as a startKey for the next page we instead use the
36
- // last ID of the current page and append the lowest unicode sort
37
- // character.
38
- if (startKey) opts.startKey = `${startKey}\0`;
39
- db.service.postAllDocs(opts).then(response => {
40
- const body = response.result;
41
- if (!body.rows) {
42
- ee.emit('error', new error.BackupError(
43
- 'AllDocsError', 'ERROR: Invalid all docs response'));
44
- callback();
45
- } else {
46
- if (body.rows.length < opts.limit) {
47
- startKey = null; // last batch
48
- } else {
49
- startKey = body.rows[opts.limit - 1].id;
50
- }
28
+ const lines = data.split('\n');
29
+ this._lastLineData = lines.splice(lines.length - 1, 1)[0];
51
30
 
52
- const docs = [];
53
- body.rows.forEach(function(doc) {
54
- docs.push(doc.doc);
55
- });
31
+ for (const i in lines) {
32
+ this.push(lines[i]);
33
+ }
34
+ done();
35
+ };
56
36
 
57
- if (docs.length > 0) {
58
- ee.emit('received', {
59
- batch: batch++,
60
- data: docs,
61
- length: docs.length,
62
- time: (new Date().getTime() - start) / 1000,
63
- total: total += docs.length
64
- });
65
- }
66
- callback();
67
- }
68
- }).catch(err => {
69
- err = error.convertResponseError(err);
70
- ee.emit('error', err);
71
- hasErrored = true;
72
- callback();
73
- });
74
- },
75
- function(callback) { callback(null, hasErrored || startKey == null); },
76
- function() { ee.emit('finished', { total: total }); }
77
- );
37
+ liner._flush = function(done) {
38
+ if (this._lastLineData) {
39
+ this.push(this._lastLineData);
40
+ }
41
+ this._lastLineData = null;
42
+ done();
43
+ };
78
44
 
79
- return ee;
45
+ return liner;
80
46
  };
@@ -1,4 +1,4 @@
1
- // Copyright © 2017 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2022 IBM Corp. All rights reserved.
2
2
  //
3
3
  // Licensed under the Apache License, Version 2.0 (the "License");
4
4
  // you may not use this file except in compliance with the License.
@@ -14,62 +14,98 @@
14
14
  'use strict';
15
15
 
16
16
  const fs = require('fs');
17
- const stream = require('stream');
18
17
  const liner = require('./liner.js');
18
+ const change = require('./change.js');
19
+ const error = require('./error.js');
20
+ const debug = require('debug')('couchbackup:spoolchanges');
19
21
 
20
- const onLine = function(onCommand, batches) {
21
- const change = new stream.Transform({ objectMode: true });
22
- change._transform = function(line, encoding, done) {
23
- if (line && line[0] === ':') {
24
- const obj = {
25
- command: null,
26
- batch: null,
27
- docs: []
28
- };
22
+ /**
23
+ * Write log file for all changes from a database, ready for downloading
24
+ * in batches.
25
+ *
26
+ * @param {string} dbUrl - URL of database
27
+ * @param {string} log - path to log file to use
28
+ * @param {number} bufferSize - the number of changes per batch/log line
29
+ * @param {function(err)} callback - a callback to run on completion
30
+ */
31
+ module.exports = function(db, log, bufferSize, ee, callback) {
32
+ // list of document ids to process
33
+ const buffer = [];
34
+ let batch = 0;
35
+ let lastSeq = null;
36
+ const logStream = fs.createWriteStream(log);
37
+ let pending = 0;
38
+ // The number of changes to fetch per request
39
+ const limit = 100000;
29
40
 
30
- let matches;
31
-
32
- // extract command
33
- matches = line.match(/^:([a-z_]+) ?/);
34
- if (matches) {
35
- obj.command = matches[1];
36
- }
37
-
38
- // extract batch
39
- matches = line.match(/ batch([0-9]+)/);
40
- if (matches) {
41
- obj.batch = parseInt(matches[1]);
42
- }
41
+ // send documents ids to the queue in batches of bufferSize + the last batch
42
+ const processBuffer = function(lastOne) {
43
+ if (buffer.length >= bufferSize || (lastOne && buffer.length > 0)) {
44
+ debug('writing', buffer.length, 'changes to the backup file');
45
+ const b = { docs: buffer.splice(0, bufferSize), batch: batch };
46
+ logStream.write(':t batch' + batch + ' ' + JSON.stringify(b.docs) + '\n');
47
+ ee.emit('changes', batch);
48
+ batch++;
49
+ }
50
+ };
43
51
 
44
- // if this is one we want
45
- if (obj.command === 't' && batches.indexOf(obj.batch) > -1) {
46
- const json = line.replace(/^.* batch[0-9]+ /, '').trim();
47
- obj.docs = JSON.parse(json);
48
- onCommand(obj);
52
+ // called once per received change
53
+ const onChange = function(c) {
54
+ if (c) {
55
+ if (c.error) {
56
+ ee.emit('error', new error.BackupError('InvalidChange', `Received invalid change: ${c}`));
57
+ } else if (c.changes) {
58
+ const obj = { id: c.id };
59
+ buffer.push(obj);
60
+ processBuffer(false);
61
+ } else if (c.last_seq) {
62
+ lastSeq = c.last_seq;
63
+ pending = c.pending;
49
64
  }
50
65
  }
51
- done();
52
66
  };
53
- return change;
54
- };
55
67
 
56
- module.exports = function(log, batches, callback) {
57
- // our sense of state
58
- const retval = { };
59
-
60
- // called with each line from the log file
61
- const onCommand = function(obj) {
62
- retval[obj.batch] = obj;
63
- };
68
+ function getChanges(since = 0) {
69
+ debug('making changes request since ' + since);
70
+ return db.service.postChangesAsStream({ db: db.db, since: since, limit: limit, seqInterval: limit })
71
+ .then(response => {
72
+ response.result.pipe(liner())
73
+ .on('error', function(err) {
74
+ logStream.end();
75
+ callback(err);
76
+ })
77
+ .pipe(change(onChange))
78
+ .on('error', function(err) {
79
+ logStream.end();
80
+ callback(err);
81
+ })
82
+ .on('finish', function() {
83
+ processBuffer(true);
84
+ if (!lastSeq) {
85
+ logStream.end();
86
+ debug('changes request terminated before last_seq was sent');
87
+ callback(new error.BackupError('SpoolChangesError', 'Changes request terminated before last_seq was sent'));
88
+ } else {
89
+ debug(`changes request completed with last_seq: ${lastSeq} and ${pending} changes pending.`);
90
+ if (pending > 0) {
91
+ // Return the next promise
92
+ return getChanges(lastSeq);
93
+ } else {
94
+ debug('finished streaming database changes');
95
+ logStream.end(':changes_complete ' + lastSeq + '\n', 'utf8', callback);
96
+ }
97
+ }
98
+ });
99
+ })
100
+ .catch(err => {
101
+ logStream.end();
102
+ if (err.status && err.status >= 400) {
103
+ callback(error.convertResponseError(err));
104
+ } else if (err.name !== 'SpoolChangesError') {
105
+ callback(new error.BackupError('SpoolChangesError', `Failed changes request - ${err.message}`));
106
+ }
107
+ });
108
+ }
64
109
 
65
- // stream through the previous log file
66
- fs.createReadStream(log)
67
- .pipe(liner())
68
- .pipe(onLine(onCommand, batches))
69
- .on('error', function(err) {
70
- callback(err);
71
- })
72
- .on('finish', function() {
73
- callback(null, retval);
74
- });
110
+ getChanges();
75
111
  };
@@ -1,4 +1,4 @@
1
- // Copyright © 2017 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2022 IBM Corp. All rights reserved.
2
2
  //
3
3
  // Licensed under the Apache License, Version 2.0 (the "License");
4
4
  // you may not use this file except in compliance with the License.
@@ -13,80 +13,68 @@
13
13
  // limitations under the License.
14
14
  'use strict';
15
15
 
16
- const fs = require('fs');
17
- const stream = require('stream');
18
- const liner = require('./liner.js');
16
+ const async = require('async');
17
+ const error = require('./error.js');
18
+ const events = require('events');
19
19
 
20
- const onLine = function(onCommand, getDocs) {
21
- const change = new stream.Transform({ objectMode: true });
20
+ module.exports = function(db, options) {
21
+ const ee = new events.EventEmitter();
22
+ const start = new Date().getTime();
23
+ let batch = 0;
24
+ let hasErrored = false;
25
+ let startKey = null;
26
+ let total = 0;
22
27
 
23
- change._transform = function(line, encoding, done) {
24
- if (line && line[0] === ':') {
25
- const obj = {
26
- command: null,
27
- batch: null,
28
- docs: []
29
- };
28
+ async.doUntil(
29
+ function(callback) {
30
+ // Note, include_docs: true is set automatically when using the
31
+ // fetch function.
32
+ const opts = { db: db.db, limit: options.bufferSize, includeDocs: true };
30
33
 
31
- let matches;
34
+ // To avoid double fetching a document solely for the purposes of getting
35
+ // the next ID to use as a startKey for the next page we instead use the
36
+ // last ID of the current page and append the lowest unicode sort
37
+ // character.
38
+ if (startKey) opts.startKey = `${startKey}\0`;
39
+ db.service.postAllDocs(opts).then(response => {
40
+ const body = response.result;
41
+ if (!body.rows) {
42
+ ee.emit('error', new error.BackupError(
43
+ 'AllDocsError', 'ERROR: Invalid all docs response'));
44
+ callback();
45
+ } else {
46
+ if (body.rows.length < opts.limit) {
47
+ startKey = null; // last batch
48
+ } else {
49
+ startKey = body.rows[opts.limit - 1].id;
50
+ }
32
51
 
33
- // extract command
34
- matches = line.match(/^:([a-z_]+) ?/);
35
- if (matches) {
36
- obj.command = matches[1];
37
- }
52
+ const docs = [];
53
+ body.rows.forEach(function(doc) {
54
+ docs.push(doc.doc);
55
+ });
38
56
 
39
- // extract batch
40
- matches = line.match(/ batch([0-9]+)/);
41
- if (matches) {
42
- obj.batch = parseInt(matches[1]);
43
- }
57
+ if (docs.length > 0) {
58
+ ee.emit('received', {
59
+ batch: batch++,
60
+ data: docs,
61
+ length: docs.length,
62
+ time: (new Date().getTime() - start) / 1000,
63
+ total: total += docs.length
64
+ });
65
+ }
66
+ callback();
67
+ }
68
+ }).catch(err => {
69
+ err = error.convertResponseError(err);
70
+ ee.emit('error', err);
71
+ hasErrored = true;
72
+ callback();
73
+ });
74
+ },
75
+ function(callback) { callback(null, hasErrored || startKey == null); },
76
+ function() { ee.emit('finished', { total: total }); }
77
+ );
44
78
 
45
- // extract doc ids
46
- if (getDocs && obj.command === 't') {
47
- const json = line.replace(/^.* batch[0-9]+ /, '').trim();
48
- obj.docs = JSON.parse(json);
49
- }
50
- onCommand(obj);
51
- }
52
- done();
53
- };
54
- return change;
55
- };
56
-
57
- /**
58
- * Generate a list of remaining batches from a download file.
59
- *
60
- * @param {string} log - log file name
61
- * @param {function} callback - callback with err, {changesComplete: N, batches: N}.
62
- * changesComplete signifies whether the log file appeared to
63
- * have completed reading the changes feed (contains :changes_complete).
64
- * batches are remaining batch IDs for download.
65
- */
66
- module.exports = function(log, callback) {
67
- // our sense of state
68
- const state = {
69
-
70
- };
71
- let changesComplete = false;
72
-
73
- // called with each line from the log file
74
- const onCommand = function(obj) {
75
- if (obj.command === 't') {
76
- state[obj.batch] = true;
77
- } else if (obj.command === 'd') {
78
- delete state[obj.batch];
79
- } else if (obj.command === 'changes_complete') {
80
- changesComplete = true;
81
- }
82
- };
83
-
84
- // stream through the previous log file
85
- fs.createReadStream(log)
86
- .pipe(liner())
87
- .pipe(onLine(onCommand, false))
88
- .on('finish', function() {
89
- const obj = { changesComplete: changesComplete, batches: state };
90
- callback(null, obj);
91
- });
79
+ return ee;
92
80
  };