@cloudant/couchbackup 2.9.8-SNAPSHOT.94 → 2.9.9-SNAPSHOT.100

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 (379) 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/analysis.log +1 -1
  4. package/.scannerwork/scanner-report/changesets-10.pb +2 -0
  5. package/.scannerwork/scanner-report/changesets-36.pb +1 -0
  6. package/.scannerwork/scanner-report/changesets-37.pb +1 -0
  7. package/.scannerwork/scanner-report/changesets-38.pb +1 -0
  8. package/.scannerwork/scanner-report/changesets-39.pb +1 -0
  9. package/.scannerwork/scanner-report/changesets-40.pb +1 -0
  10. package/.scannerwork/scanner-report/changesets-41.pb +1 -0
  11. package/.scannerwork/scanner-report/changesets-42.pb +1 -0
  12. package/.scannerwork/scanner-report/changesets-48.pb +1 -0
  13. package/.scannerwork/scanner-report/changesets-51.pb +1 -0
  14. package/.scannerwork/scanner-report/changesets-52.pb +1 -0
  15. package/.scannerwork/scanner-report/changesets-67.pb +1 -0
  16. package/.scannerwork/scanner-report/changesets-7.pb +1 -0
  17. package/.scannerwork/scanner-report/component-1.pb +2 -1
  18. package/.scannerwork/scanner-report/component-10.pb +2 -0
  19. package/.scannerwork/scanner-report/component-2.pb +1 -1
  20. package/.scannerwork/scanner-report/component-22.pb +1 -1
  21. package/.scannerwork/scanner-report/component-23.pb +1 -1
  22. package/.scannerwork/scanner-report/component-24.pb +1 -1
  23. package/.scannerwork/scanner-report/component-25.pb +1 -1
  24. package/.scannerwork/scanner-report/component-26.pb +1 -1
  25. package/.scannerwork/scanner-report/component-27.pb +1 -1
  26. package/.scannerwork/scanner-report/component-28.pb +1 -1
  27. package/.scannerwork/scanner-report/component-29.pb +1 -1
  28. package/.scannerwork/scanner-report/component-30.pb +1 -1
  29. package/.scannerwork/scanner-report/component-31.pb +1 -1
  30. package/.scannerwork/scanner-report/component-32.pb +1 -1
  31. package/.scannerwork/scanner-report/component-33.pb +1 -1
  32. package/.scannerwork/scanner-report/component-34.pb +1 -1
  33. package/.scannerwork/scanner-report/component-35.pb +1 -1
  34. package/.scannerwork/scanner-report/component-36.pb +1 -0
  35. package/.scannerwork/scanner-report/component-37.pb +1 -1
  36. package/.scannerwork/scanner-report/component-38.pb +1 -1
  37. package/.scannerwork/scanner-report/component-39.pb +1 -0
  38. package/.scannerwork/scanner-report/component-40.pb +1 -1
  39. package/.scannerwork/scanner-report/component-41.pb +1 -0
  40. package/.scannerwork/scanner-report/component-42.pb +1 -0
  41. package/.scannerwork/scanner-report/component-48.pb +1 -0
  42. package/.scannerwork/scanner-report/component-49.pb +1 -1
  43. package/.scannerwork/scanner-report/component-5.pb +1 -1
  44. package/.scannerwork/scanner-report/component-50.pb +1 -1
  45. package/.scannerwork/scanner-report/component-51.pb +1 -1
  46. package/.scannerwork/scanner-report/component-52.pb +1 -0
  47. package/.scannerwork/scanner-report/component-53.pb +1 -1
  48. package/.scannerwork/scanner-report/component-54.pb +1 -1
  49. package/.scannerwork/scanner-report/component-55.pb +1 -1
  50. package/.scannerwork/scanner-report/component-56.pb +1 -1
  51. package/.scannerwork/scanner-report/component-57.pb +1 -1
  52. package/.scannerwork/scanner-report/component-58.pb +1 -1
  53. package/.scannerwork/scanner-report/component-59.pb +1 -1
  54. package/.scannerwork/scanner-report/component-6.pb +1 -1
  55. package/.scannerwork/scanner-report/component-61.pb +1 -1
  56. package/.scannerwork/scanner-report/component-62.pb +1 -1
  57. package/.scannerwork/scanner-report/component-63.pb +1 -1
  58. package/.scannerwork/scanner-report/component-64.pb +1 -1
  59. package/.scannerwork/scanner-report/component-66.pb +1 -1
  60. package/.scannerwork/scanner-report/component-67.pb +1 -1
  61. package/.scannerwork/scanner-report/component-7.pb +1 -0
  62. package/.scannerwork/scanner-report/component-9.pb +1 -0
  63. package/.scannerwork/scanner-report/coverages-10.pb +0 -0
  64. package/.scannerwork/scanner-report/coverages-22.pb +0 -0
  65. package/.scannerwork/scanner-report/coverages-23.pb +0 -0
  66. package/.scannerwork/scanner-report/coverages-24.pb +0 -0
  67. package/.scannerwork/scanner-report/coverages-25.pb +0 -0
  68. package/.scannerwork/scanner-report/coverages-26.pb +0 -0
  69. package/.scannerwork/scanner-report/coverages-27.pb +0 -0
  70. package/.scannerwork/scanner-report/coverages-28.pb +0 -0
  71. package/.scannerwork/scanner-report/coverages-29.pb +0 -0
  72. package/.scannerwork/scanner-report/coverages-30.pb +0 -0
  73. package/.scannerwork/scanner-report/coverages-31.pb +0 -0
  74. package/.scannerwork/scanner-report/coverages-32.pb +0 -0
  75. package/.scannerwork/scanner-report/coverages-33.pb +0 -0
  76. package/.scannerwork/scanner-report/coverages-34.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-38.pb +0 -0
  80. package/.scannerwork/scanner-report/coverages-39.pb +0 -0
  81. package/.scannerwork/scanner-report/coverages-40.pb +0 -0
  82. package/.scannerwork/scanner-report/coverages-42.pb +0 -0
  83. package/.scannerwork/scanner-report/coverages-48.pb +0 -0
  84. package/.scannerwork/scanner-report/coverages-49.pb +0 -0
  85. package/.scannerwork/scanner-report/coverages-50.pb +0 -0
  86. package/.scannerwork/scanner-report/coverages-52.pb +0 -0
  87. package/.scannerwork/scanner-report/coverages-53.pb +0 -0
  88. package/.scannerwork/scanner-report/coverages-54.pb +0 -0
  89. package/.scannerwork/scanner-report/coverages-55.pb +0 -0
  90. package/.scannerwork/scanner-report/coverages-56.pb +0 -0
  91. package/.scannerwork/scanner-report/coverages-57.pb +0 -0
  92. package/.scannerwork/scanner-report/coverages-58.pb +0 -0
  93. package/.scannerwork/scanner-report/coverages-59.pb +0 -0
  94. package/.scannerwork/scanner-report/coverages-61.pb +0 -0
  95. package/.scannerwork/scanner-report/coverages-62.pb +0 -0
  96. package/.scannerwork/scanner-report/coverages-63.pb +0 -0
  97. package/.scannerwork/scanner-report/coverages-64.pb +0 -0
  98. package/.scannerwork/scanner-report/coverages-7.pb +0 -0
  99. package/.scannerwork/scanner-report/duplications-22.pb +3 -0
  100. package/.scannerwork/scanner-report/duplications-25.pb +0 -2
  101. package/.scannerwork/scanner-report/duplications-26.pb +2 -0
  102. package/.scannerwork/scanner-report/duplications-28.pb +3 -0
  103. package/.scannerwork/scanner-report/duplications-29.pb +2 -0
  104. package/.scannerwork/scanner-report/duplications-32.pb +0 -3
  105. package/.scannerwork/scanner-report/duplications-34.pb +0 -2
  106. package/.scannerwork/scanner-report/duplications-42.pb +2 -0
  107. package/.scannerwork/scanner-report/duplications-48.pb +2 -0
  108. package/.scannerwork/scanner-report/duplications-49.pb +1 -1
  109. package/.scannerwork/scanner-report/duplications-50.pb +0 -2
  110. package/.scannerwork/scanner-report/duplications-55.pb +2 -0
  111. package/.scannerwork/scanner-report/duplications-60.pb +1 -1
  112. package/.scannerwork/scanner-report/duplications-62.pb +0 -2
  113. package/.scannerwork/scanner-report/measures-10.pb +0 -0
  114. package/.scannerwork/scanner-report/measures-2.pb +0 -0
  115. package/.scannerwork/scanner-report/measures-22.pb +0 -0
  116. package/.scannerwork/scanner-report/measures-23.pb +0 -0
  117. package/.scannerwork/scanner-report/measures-24.pb +0 -0
  118. package/.scannerwork/scanner-report/measures-25.pb +0 -0
  119. package/.scannerwork/scanner-report/measures-26.pb +0 -0
  120. package/.scannerwork/scanner-report/measures-27.pb +0 -0
  121. package/.scannerwork/scanner-report/measures-28.pb +0 -0
  122. package/.scannerwork/scanner-report/measures-29.pb +0 -0
  123. package/.scannerwork/scanner-report/measures-30.pb +0 -0
  124. package/.scannerwork/scanner-report/measures-31.pb +0 -0
  125. package/.scannerwork/scanner-report/measures-32.pb +0 -0
  126. package/.scannerwork/scanner-report/measures-33.pb +0 -0
  127. package/.scannerwork/scanner-report/measures-34.pb +0 -0
  128. package/.scannerwork/scanner-report/measures-35.pb +0 -0
  129. package/.scannerwork/scanner-report/measures-36.pb +0 -0
  130. package/.scannerwork/scanner-report/measures-37.pb +0 -0
  131. package/.scannerwork/scanner-report/measures-38.pb +0 -0
  132. package/.scannerwork/scanner-report/measures-39.pb +0 -0
  133. package/.scannerwork/scanner-report/measures-40.pb +0 -0
  134. package/.scannerwork/scanner-report/measures-42.pb +0 -0
  135. package/.scannerwork/scanner-report/measures-48.pb +0 -0
  136. package/.scannerwork/scanner-report/measures-49.pb +0 -0
  137. package/.scannerwork/scanner-report/measures-5.pb +0 -0
  138. package/.scannerwork/scanner-report/measures-50.pb +0 -0
  139. package/.scannerwork/scanner-report/measures-51.pb +0 -0
  140. package/.scannerwork/scanner-report/measures-52.pb +0 -0
  141. package/.scannerwork/scanner-report/measures-53.pb +0 -0
  142. package/.scannerwork/scanner-report/measures-54.pb +0 -0
  143. package/.scannerwork/scanner-report/measures-55.pb +0 -0
  144. package/.scannerwork/scanner-report/measures-56.pb +0 -0
  145. package/.scannerwork/scanner-report/measures-57.pb +0 -0
  146. package/.scannerwork/scanner-report/measures-58.pb +0 -0
  147. package/.scannerwork/scanner-report/measures-59.pb +0 -0
  148. package/.scannerwork/scanner-report/measures-6.pb +0 -0
  149. package/.scannerwork/scanner-report/measures-61.pb +0 -0
  150. package/.scannerwork/scanner-report/measures-62.pb +0 -0
  151. package/.scannerwork/scanner-report/measures-63.pb +0 -0
  152. package/.scannerwork/scanner-report/measures-64.pb +0 -0
  153. package/.scannerwork/scanner-report/measures-66.pb +0 -0
  154. package/.scannerwork/scanner-report/measures-67.pb +0 -0
  155. package/.scannerwork/scanner-report/measures-7.pb +0 -0
  156. package/.scannerwork/scanner-report/measures-9.pb +0 -0
  157. package/.scannerwork/scanner-report/metadata.pb +0 -0
  158. package/.scannerwork/scanner-report/{source-19.txt → source-10.txt} +6 -13
  159. package/.scannerwork/scanner-report/source-2.txt +167 -147
  160. package/.scannerwork/scanner-report/source-22.txt +86 -123
  161. package/.scannerwork/scanner-report/source-23.txt +73 -15
  162. package/.scannerwork/scanner-report/source-24.txt +14 -15
  163. package/.scannerwork/scanner-report/source-25.txt +19 -128
  164. package/.scannerwork/scanner-report/source-26.txt +262 -37
  165. package/.scannerwork/scanner-report/source-27.txt +124 -17
  166. package/.scannerwork/scanner-report/source-28.txt +112 -81
  167. package/.scannerwork/scanner-report/source-29.txt +121 -118
  168. package/.scannerwork/scanner-report/source-30.txt +44 -49
  169. package/.scannerwork/scanner-report/source-31.txt +60 -585
  170. package/.scannerwork/scanner-report/source-32.txt +13 -98
  171. package/.scannerwork/scanner-report/source-33.txt +129 -11
  172. package/.scannerwork/scanner-report/source-34.txt +344 -203
  173. package/.scannerwork/scanner-report/source-35.txt +29 -96
  174. package/.scannerwork/scanner-report/source-36.txt +68 -0
  175. package/.scannerwork/scanner-report/source-37.txt +36 -509
  176. package/.scannerwork/scanner-report/source-38.txt +68 -167
  177. package/.scannerwork/scanner-report/source-39.txt +156 -0
  178. package/.scannerwork/scanner-report/source-40.txt +625 -509
  179. package/.scannerwork/scanner-report/source-42.txt +225 -0
  180. package/.scannerwork/scanner-report/source-48.txt +175 -0
  181. package/.scannerwork/scanner-report/source-49.txt +64 -49
  182. package/.scannerwork/scanner-report/source-5.txt +509 -131
  183. package/.scannerwork/scanner-report/source-50.txt +59 -172
  184. package/.scannerwork/scanner-report/source-51.txt +56 -509
  185. package/.scannerwork/scanner-report/source-52.txt +54 -0
  186. package/.scannerwork/scanner-report/source-53.txt +20 -138
  187. package/.scannerwork/scanner-report/source-54.txt +258 -23
  188. package/.scannerwork/scanner-report/source-55.txt +48 -151
  189. package/.scannerwork/scanner-report/source-56.txt +21 -109
  190. package/.scannerwork/scanner-report/source-57.txt +98 -21
  191. package/.scannerwork/scanner-report/source-58.txt +61 -35
  192. package/.scannerwork/scanner-report/source-59.txt +81 -88
  193. package/.scannerwork/scanner-report/source-6.txt +509 -293
  194. package/.scannerwork/scanner-report/source-61.txt +140 -56
  195. package/.scannerwork/scanner-report/source-62.txt +113 -59
  196. package/.scannerwork/scanner-report/source-63.txt +88 -81
  197. package/.scannerwork/scanner-report/source-64.txt +153 -93
  198. package/.scannerwork/scanner-report/source-66.txt +509 -281
  199. package/.scannerwork/scanner-report/source-67.txt +418 -509
  200. package/.scannerwork/scanner-report/source-7.txt +114 -0
  201. package/.scannerwork/scanner-report/source-9.txt +509 -0
  202. package/.scannerwork/scanner-report/symbols-10.pb +9 -0
  203. package/.scannerwork/scanner-report/symbols-22.pb +75 -110
  204. package/.scannerwork/scanner-report/symbols-23.pb +60 -10
  205. package/.scannerwork/scanner-report/symbols-24.pb +17 -14
  206. package/.scannerwork/scanner-report/symbols-25.pb +14 -102
  207. package/.scannerwork/scanner-report/symbols-26.pb +485 -35
  208. package/.scannerwork/scanner-report/symbols-27.pb +116 -17
  209. package/.scannerwork/scanner-report/symbols-28.pb +97 -69
  210. package/.scannerwork/scanner-report/symbols-29.pb +97 -111
  211. package/.scannerwork/scanner-report/symbols-30.pb +42 -44
  212. package/.scannerwork/scanner-report/symbols-31.pb +68 -1253
  213. package/.scannerwork/scanner-report/symbols-32.pb +9 -76
  214. package/.scannerwork/scanner-report/symbols-33.pb +85 -9
  215. package/.scannerwork/scanner-report/symbols-34.pb +441 -365
  216. package/.scannerwork/scanner-report/symbols-35.pb +26 -27
  217. package/.scannerwork/scanner-report/symbols-36.pb +36 -0
  218. package/.scannerwork/scanner-report/symbols-38.pb +45 -0
  219. package/.scannerwork/scanner-report/symbols-39.pb +112 -0
  220. package/.scannerwork/scanner-report/symbols-40.pb +1254 -0
  221. package/.scannerwork/scanner-report/symbols-42.pb +418 -0
  222. package/.scannerwork/scanner-report/symbols-48.pb +153 -0
  223. package/.scannerwork/scanner-report/symbols-49.pb +176 -149
  224. package/.scannerwork/scanner-report/symbols-50.pb +30 -180
  225. package/.scannerwork/scanner-report/symbols-52.pb +15 -0
  226. package/.scannerwork/scanner-report/symbols-53.pb +20 -126
  227. package/.scannerwork/scanner-report/symbols-54.pb +354 -20
  228. package/.scannerwork/scanner-report/symbols-55.pb +41 -143
  229. package/.scannerwork/scanner-report/symbols-56.pb +18 -33
  230. package/.scannerwork/scanner-report/symbols-57.pb +30 -18
  231. package/.scannerwork/scanner-report/symbols-58.pb +45 -14
  232. package/.scannerwork/scanner-report/symbols-59.pb +41 -58
  233. package/.scannerwork/scanner-report/symbols-61.pb +122 -42
  234. package/.scannerwork/scanner-report/symbols-62.pb +33 -42
  235. package/.scannerwork/scanner-report/symbols-63.pb +58 -41
  236. package/.scannerwork/scanner-report/symbols-64.pb +144 -30
  237. package/.scannerwork/scanner-report/symbols-7.pb +28 -0
  238. package/.scannerwork/scanner-report/syntax-highlightings-10.pb +48 -0
  239. package/.scannerwork/scanner-report/syntax-highlightings-2.pb +938 -180
  240. package/.scannerwork/scanner-report/syntax-highlightings-22.pb +118 -183
  241. package/.scannerwork/scanner-report/syntax-highlightings-23.pb +74 -14
  242. package/.scannerwork/scanner-report/syntax-highlightings-24.pb +28 -19
  243. package/.scannerwork/scanner-report/syntax-highlightings-25.pb +21 -194
  244. package/.scannerwork/scanner-report/syntax-highlightings-26.pb +622 -58
  245. package/.scannerwork/scanner-report/syntax-highlightings-27.pb +98 -27
  246. package/.scannerwork/scanner-report/syntax-highlightings-28.pb +147 -70
  247. package/.scannerwork/scanner-report/syntax-highlightings-29.pb +189 -96
  248. package/.scannerwork/scanner-report/syntax-highlightings-30.pb +47 -75
  249. package/.scannerwork/scanner-report/syntax-highlightings-31.pb +64 -846
  250. package/.scannerwork/scanner-report/syntax-highlightings-32.pb +11 -119
  251. package/.scannerwork/scanner-report/syntax-highlightings-33.pb +158 -15
  252. package/.scannerwork/scanner-report/syntax-highlightings-34.pb +510 -211
  253. package/.scannerwork/scanner-report/syntax-highlightings-35.pb +33 -103
  254. package/.scannerwork/scanner-report/syntax-highlightings-36.pb +95 -0
  255. package/.scannerwork/scanner-report/syntax-highlightings-37.pb +48 -3737
  256. package/.scannerwork/scanner-report/syntax-highlightings-38.pb +99 -938
  257. package/.scannerwork/scanner-report/syntax-highlightings-39.pb +223 -0
  258. package/.scannerwork/scanner-report/syntax-highlightings-40.pb +536 -3396
  259. package/.scannerwork/scanner-report/syntax-highlightings-42.pb +331 -0
  260. package/.scannerwork/scanner-report/syntax-highlightings-48.pb +214 -0
  261. package/.scannerwork/scanner-report/syntax-highlightings-49.pb +138 -127
  262. package/.scannerwork/scanner-report/syntax-highlightings-5.pb +3736 -171
  263. package/.scannerwork/scanner-report/syntax-highlightings-50.pb +78 -200
  264. package/.scannerwork/scanner-report/syntax-highlightings-51.pb +55 -3722
  265. package/.scannerwork/scanner-report/syntax-highlightings-52.pb +54 -0
  266. package/.scannerwork/scanner-report/syntax-highlightings-53.pb +29 -178
  267. package/.scannerwork/scanner-report/syntax-highlightings-54.pb +250 -29
  268. package/.scannerwork/scanner-report/syntax-highlightings-55.pb +39 -204
  269. package/.scannerwork/scanner-report/syntax-highlightings-56.pb +17 -96
  270. package/.scannerwork/scanner-report/syntax-highlightings-57.pb +80 -17
  271. package/.scannerwork/scanner-report/syntax-highlightings-58.pb +62 -21
  272. package/.scannerwork/scanner-report/syntax-highlightings-59.pb +79 -96
  273. package/.scannerwork/scanner-report/syntax-highlightings-6.pb +3487 -398
  274. package/.scannerwork/scanner-report/syntax-highlightings-61.pb +168 -50
  275. package/.scannerwork/scanner-report/syntax-highlightings-62.pb +90 -39
  276. package/.scannerwork/scanner-report/syntax-highlightings-63.pb +96 -79
  277. package/.scannerwork/scanner-report/syntax-highlightings-64.pb +208 -78
  278. package/.scannerwork/scanner-report/syntax-highlightings-66.pb +3661 -199
  279. package/.scannerwork/scanner-report/syntax-highlightings-67.pb +445 -3544
  280. package/.scannerwork/scanner-report/syntax-highlightings-7.pb +138 -0
  281. package/.scannerwork/scanner-report/syntax-highlightings-9.pb +3749 -0
  282. package/CHANGES.md +3 -0
  283. package/package.json +4 -4
  284. package/test-14-results.xml +153 -153
  285. package/test-16-results.xml +164 -164
  286. package/test-18-results.xml +147 -147
  287. package/test-19-results.xml +167 -167
  288. package/test-iam-18-results.xml +50 -50
  289. package/.scannerwork/scanner-report/changesets-18.pb +0 -1
  290. package/.scannerwork/scanner-report/changesets-19.pb +0 -1
  291. package/.scannerwork/scanner-report/changesets-2.pb +0 -1
  292. package/.scannerwork/scanner-report/changesets-20.pb +0 -1
  293. package/.scannerwork/scanner-report/changesets-21.pb +0 -1
  294. package/.scannerwork/scanner-report/changesets-3.pb +0 -1
  295. package/.scannerwork/scanner-report/changesets-4.pb +0 -1
  296. package/.scannerwork/scanner-report/changesets-5.pb +0 -1
  297. package/.scannerwork/scanner-report/changesets-6.pb +0 -0
  298. package/.scannerwork/scanner-report/changesets-66.pb +0 -1
  299. package/.scannerwork/scanner-report/changesets-68.pb +0 -1
  300. package/.scannerwork/scanner-report/changesets-69.pb +0 -1
  301. package/.scannerwork/scanner-report/changesets-70.pb +0 -1
  302. package/.scannerwork/scanner-report/component-18.pb +0 -1
  303. package/.scannerwork/scanner-report/component-19.pb +0 -1
  304. package/.scannerwork/scanner-report/component-20.pb +0 -1
  305. package/.scannerwork/scanner-report/component-21.pb +0 -1
  306. package/.scannerwork/scanner-report/component-3.pb +0 -1
  307. package/.scannerwork/scanner-report/component-4.pb +0 -1
  308. package/.scannerwork/scanner-report/component-68.pb +0 -1
  309. package/.scannerwork/scanner-report/component-69.pb +0 -1
  310. package/.scannerwork/scanner-report/component-70.pb +0 -1
  311. package/.scannerwork/scanner-report/coverages-18.pb +0 -0
  312. package/.scannerwork/scanner-report/coverages-2.pb +0 -0
  313. package/.scannerwork/scanner-report/coverages-20.pb +0 -0
  314. package/.scannerwork/scanner-report/coverages-21.pb +0 -0
  315. package/.scannerwork/scanner-report/coverages-4.pb +0 -0
  316. package/.scannerwork/scanner-report/coverages-5.pb +0 -0
  317. package/.scannerwork/scanner-report/coverages-6.pb +0 -0
  318. package/.scannerwork/scanner-report/coverages-66.pb +0 -0
  319. package/.scannerwork/scanner-report/coverages-68.pb +0 -0
  320. package/.scannerwork/scanner-report/duplications-5.pb +0 -3
  321. package/.scannerwork/scanner-report/duplications-6.pb +0 -2
  322. package/.scannerwork/scanner-report/measures-18.pb +0 -0
  323. package/.scannerwork/scanner-report/measures-19.pb +0 -0
  324. package/.scannerwork/scanner-report/measures-20.pb +0 -0
  325. package/.scannerwork/scanner-report/measures-21.pb +0 -0
  326. package/.scannerwork/scanner-report/measures-4.pb +0 -0
  327. package/.scannerwork/scanner-report/measures-68.pb +0 -0
  328. package/.scannerwork/scanner-report/measures-69.pb +0 -0
  329. package/.scannerwork/scanner-report/measures-70.pb +0 -0
  330. package/.scannerwork/scanner-report/source-18.txt +0 -63
  331. package/.scannerwork/scanner-report/source-20.txt +0 -92
  332. package/.scannerwork/scanner-report/source-21.txt +0 -47
  333. package/.scannerwork/scanner-report/source-4.txt +0 -366
  334. package/.scannerwork/scanner-report/source-68.txt +0 -77
  335. package/.scannerwork/scanner-report/source-69.txt +0 -56
  336. package/.scannerwork/scanner-report/source-70.txt +0 -418
  337. package/.scannerwork/scanner-report/symbols-18.pb +0 -43
  338. package/.scannerwork/scanner-report/symbols-2.pb +0 -85
  339. package/.scannerwork/scanner-report/symbols-20.pb +0 -60
  340. package/.scannerwork/scanner-report/symbols-21.pb +0 -27
  341. package/.scannerwork/scanner-report/symbols-4.pb +0 -494
  342. package/.scannerwork/scanner-report/symbols-5.pb +0 -97
  343. package/.scannerwork/scanner-report/symbols-6.pb +0 -486
  344. package/.scannerwork/scanner-report/symbols-66.pb +0 -354
  345. package/.scannerwork/scanner-report/symbols-68.pb +0 -30
  346. package/.scannerwork/scanner-report/syntax-highlightings-18.pb +0 -82
  347. package/.scannerwork/scanner-report/syntax-highlightings-19.pb +0 -59
  348. package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -110
  349. package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -68
  350. package/.scannerwork/scanner-report/syntax-highlightings-4.pb +0 -630
  351. package/.scannerwork/scanner-report/syntax-highlightings-68.pb +0 -103
  352. package/.scannerwork/scanner-report/syntax-highlightings-69.pb +0 -82
  353. package/.scannerwork/scanner-report/syntax-highlightings-70.pb +0 -648
  354. /package/.scannerwork/scanner-report/{coverages-19.pb → coverages-37.pb} +0 -0
  355. /package/.scannerwork/scanner-report/{coverages-3.pb → coverages-41.pb} +0 -0
  356. /package/.scannerwork/scanner-report/{coverages-69.pb → coverages-51.pb} +0 -0
  357. /package/.scannerwork/scanner-report/{coverages-70.pb → coverages-67.pb} +0 -0
  358. /package/.scannerwork/scanner-report/{duplications-18.pb → duplications-33.pb} +0 -0
  359. /package/.scannerwork/scanner-report/{duplications-19.pb → duplications-36.pb} +0 -0
  360. /package/.scannerwork/scanner-report/{duplications-2.pb → duplications-37.pb} +0 -0
  361. /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-38.pb} +0 -0
  362. /package/.scannerwork/scanner-report/{duplications-21.pb → duplications-39.pb} +0 -0
  363. /package/.scannerwork/scanner-report/{duplications-4.pb → duplications-40.pb} +0 -0
  364. /package/.scannerwork/scanner-report/{duplications-3.pb → duplications-41.pb} +0 -0
  365. /package/.scannerwork/scanner-report/{duplications-66.pb → duplications-51.pb} +0 -0
  366. /package/.scannerwork/scanner-report/{duplications-68.pb → duplications-52.pb} +0 -0
  367. /package/.scannerwork/scanner-report/{duplications-69.pb → duplications-67.pb} +0 -0
  368. /package/.scannerwork/scanner-report/{duplications-70.pb → duplications-7.pb} +0 -0
  369. /package/.scannerwork/scanner-report/{issues-29.pb → issues-27.pb} +0 -0
  370. /package/.scannerwork/scanner-report/{issues-4.pb → issues-34.pb} +0 -0
  371. /package/.scannerwork/scanner-report/{issues-21.pb → issues-35.pb} +0 -0
  372. /package/.scannerwork/scanner-report/{issues-3.pb → issues-41.pb} +0 -0
  373. /package/.scannerwork/scanner-report/{measures-3.pb → measures-41.pb} +0 -0
  374. /package/.scannerwork/scanner-report/{source-3.txt → source-41.txt} +0 -0
  375. /package/.scannerwork/scanner-report/{symbols-19.pb → symbols-37.pb} +0 -0
  376. /package/.scannerwork/scanner-report/{symbols-3.pb → symbols-41.pb} +0 -0
  377. /package/.scannerwork/scanner-report/{symbols-69.pb → symbols-51.pb} +0 -0
  378. /package/.scannerwork/scanner-report/{symbols-70.pb → symbols-67.pb} +0 -0
  379. /package/.scannerwork/scanner-report/{syntax-highlightings-3.pb → syntax-highlightings-41.pb} +0 -0
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2022 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2021 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,67 +14,151 @@
14
14
  'use strict';
15
15
 
16
16
  const async = require('async');
17
+ const stream = require('stream');
17
18
  const error = require('./error.js');
18
- const events = require('events');
19
-
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;
27
-
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 };
33
-
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
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);
48
100
  } else {
49
- startKey = body.rows[opts.limit - 1].id;
101
+ callback(null, q.length() <= parallelism * 2);
50
102
  }
103
+ },
104
+ function(cb) {
105
+ setTimeout(cb, 20);
106
+ },
51
107
 
52
- const docs = [];
53
- body.rows.forEach(function(doc) {
54
- docs.push(doc.doc);
55
- });
56
-
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
- });
108
+ function() {
109
+ if (flush && !didError) {
110
+ writer.emit('finished', { total: written });
65
111
  }
112
+ // callback when we're happy with the queue size
66
113
  callback();
114
+ });
115
+ } else {
116
+ callback();
117
+ }
118
+ }
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();
67
148
  }
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
- );
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
+ };
78
158
 
79
- return ee;
159
+ // called when we need to flush everything
160
+ writer._flush = function(done) {
161
+ processBuffer(true, done);
162
+ };
163
+ return writer;
80
164
  };
@@ -1,4 +1,4 @@
1
- // Copyright © 2017 IBM Corp. All rights reserved.
1
+ // Copyright © 2017, 2021 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,63 +13,117 @@
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');
19
-
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
- };
29
-
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
- }
43
-
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);
49
- }
50
- }
51
- done();
52
- };
53
- return change;
54
- };
16
+ const cliutils = require('./cliutils.js');
17
+ const config = require('./config.js');
18
+ const error = require('./error.js');
19
+ const path = require('path');
20
+ const pkg = require('../package.json');
21
+
22
+ function parseBackupArgs() {
23
+ const program = require('commander');
24
+
25
+ // Option CLI defaults
26
+ const defaults = config.cliDefaults();
27
+
28
+ // Options set by environment variables
29
+ const envVarOptions = {};
30
+ config.applyEnvironmentVariables(envVarOptions);
31
+
32
+ program
33
+ .version(pkg.version)
34
+ .description('Backup a CouchDB/Cloudant database to a backup text file.')
35
+ .usage('[options...]')
36
+ .option('-b, --buffer-size <n>',
37
+ cliutils.getUsage('number of documents fetched at once', defaults.bufferSize),
38
+ Number)
39
+ .option('-d, --db <db>',
40
+ cliutils.getUsage('name of the database to backup', defaults.db))
41
+ .option('-k, --iam-api-key <API key>',
42
+ cliutils.getUsage('IAM API key to access the Cloudant server'))
43
+ .option('-l, --log <file>',
44
+ cliutils.getUsage('file to store logging information during backup; invalid in "shallow" mode', 'a temporary file'),
45
+ path.normalize)
46
+ .option('-m, --mode <mode>',
47
+ cliutils.getUsage('"shallow" if only a superficial backup is done (ignoring conflicts and revision tokens), else "full" for complete backup', defaults.mode),
48
+ (mode) => { return mode.toLowerCase(); })
49
+ .option('-o, --output <file>',
50
+ cliutils.getUsage('file name to store the backup data', 'stdout'),
51
+ path.normalize)
52
+ .option('-p, --parallelism <n>',
53
+ cliutils.getUsage('number of HTTP requests to perform in parallel when performing a backup; ignored in "shallow" mode', defaults.parallelism),
54
+ Number)
55
+ .option('-q, --quiet',
56
+ cliutils.getUsage('suppress batch messages', defaults.quiet))
57
+ .option('-r, --resume',
58
+ cliutils.getUsage('continue a previous backup from its last known position; invalid in "shallow" mode', defaults.resume))
59
+ .option('-t, --request-timeout <n>',
60
+ cliutils.getUsage('milliseconds to wait for a response to a HTTP request before retrying the request', defaults.requestTimeout),
61
+ Number)
62
+ .option('-u, --url <url>',
63
+ cliutils.getUsage('URL of the CouchDB/Cloudant server', defaults.url))
64
+ .parse(process.argv);
65
+
66
+ // Remove defaults that don't apply when using shallow mode
67
+ if (program.opts().mode === 'shallow' || envVarOptions.mode === 'shallow') {
68
+ delete defaults.parallelism;
69
+ delete defaults.log;
70
+ delete defaults.resume;
71
+ }
72
+
73
+ // Apply the options in order so that the CLI overrides env vars and env variables
74
+ // override defaults.
75
+ const opts = Object.assign({}, defaults, envVarOptions, program.opts());
76
+
77
+ if (opts.resume && (opts.log === defaults.log)) {
78
+ // If resuming and the log file arg is the newly generated tmp name from defaults then we know that --log wasn't specified.
79
+ // We have to do this check here for the CLI case because of the default.
80
+ error.terminationCallback(new error.BackupError('NoLogFileName', 'To resume a backup, a log file must be specified'));
81
+ }
82
+
83
+ return opts;
84
+ }
85
+
86
+ function parseRestoreArgs() {
87
+ const program = require('commander');
88
+
89
+ // Option CLI defaults
90
+ const defaults = config.cliDefaults();
91
+
92
+ // Options set by environment variables
93
+ const envVarOptions = {};
94
+ config.applyEnvironmentVariables(envVarOptions);
95
+
96
+ program
97
+ .version(pkg.version)
98
+ .description('Restore a CouchDB/Cloudant database from a backup text file.')
99
+ .usage('[options...]')
100
+ .option('-b, --buffer-size <n>',
101
+ cliutils.getUsage('number of documents restored at once', defaults.bufferSize),
102
+ Number)
103
+ .option('-d, --db <db>',
104
+ cliutils.getUsage('name of the new, existing database to restore to', defaults.db))
105
+ .option('-k, --iam-api-key <API key>',
106
+ cliutils.getUsage('IAM API key to access the Cloudant server'))
107
+ .option('-p, --parallelism <n>',
108
+ cliutils.getUsage('number of HTTP requests to perform in parallel when restoring a backup', defaults.parallelism),
109
+ Number)
110
+ .option('-q, --quiet',
111
+ cliutils.getUsage('suppress batch messages', defaults.quiet))
112
+ .option('-t, --request-timeout <n>',
113
+ cliutils.getUsage('milliseconds to wait for a response to a HTTP request before retrying the request', defaults.requestTimeout),
114
+ Number)
115
+ .option('-u, --url <url>',
116
+ cliutils.getUsage('URL of the CouchDB/Cloudant server', defaults.url))
117
+ .parse(process.argv);
118
+
119
+ // Apply the options in order so that the CLI overrides env vars and env variables
120
+ // override defaults.
121
+ const opts = Object.assign({}, defaults, envVarOptions, program.opts());
122
+
123
+ return opts;
124
+ }
55
125
 
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
- };
64
-
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
- });
126
+ module.exports = {
127
+ parseBackupArgs: parseBackupArgs,
128
+ parseRestoreArgs: parseRestoreArgs
75
129
  };
@@ -1,4 +1,4 @@
1
- // Copyright © 2017, 2021 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,92 +13,99 @@
13
13
  // limitations under the License.
14
14
  'use strict';
15
15
 
16
- // fatal errors
17
- const codes = {
18
- Error: 1,
19
- InvalidOption: 2,
20
- DatabaseNotFound: 10,
21
- Unauthorized: 11,
22
- Forbidden: 12,
23
- DatabaseNotEmpty: 13,
24
- NoLogFileName: 20,
25
- LogDoesNotExist: 21,
26
- IncompleteChangesInLogFile: 22,
27
- SpoolChangesError: 30,
28
- HTTPFatalError: 40,
29
- BulkGetError: 50
30
- };
16
+ const fs = require('fs');
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');
31
21
 
32
- class BackupError extends Error {
33
- constructor(name, message) {
34
- super(message);
35
- this.name = name;
36
- }
37
- }
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;
38
40
 
39
- class HTTPError extends BackupError {
40
- constructor(responseError, name) {
41
- // Special case some names for more useful error messages
42
- switch (responseError.status) {
43
- case 401:
44
- name = 'Unauthorized';
45
- break;
46
- case 403:
47
- name = 'Forbidden';
48
- break;
49
- default:
50
- name = name || 'HTTPFatalError';
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++;
51
49
  }
52
- super(name, responseError.message);
53
- }
54
- }
50
+ };
55
51
 
56
- // Default function to return an error for HTTP status codes
57
- // < 400 -> OK
58
- // 4XX (except 429) -> Fatal
59
- // 429 & >=500 -> Transient
60
- function checkResponse(err) {
61
- if (err) {
62
- // Construct an HTTPError if there is request information on the error
63
- // Codes < 400 are considered OK
64
- if (err.status >= 400) {
65
- return new HTTPError(err);
66
- } else {
67
- // Send it back again if there was no status code, e.g. a cxn error
68
- return augmentMessage(err);
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;
64
+ }
69
65
  }
70
- }
71
- }
66
+ };
72
67
 
73
- function convertResponseError(responseError, errorFactory) {
74
- if (!errorFactory) {
75
- errorFactory = checkResponse;
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
+ });
76
108
  }
77
- return errorFactory(responseError);
78
- }
79
109
 
80
- function augmentMessage(err) {
81
- // For errors that don't have a status code, we are likely looking at a cxn
82
- // error.
83
- // Try to augment the message with more detail (core puts the code in statusText)
84
- if (err && err.statusText) {
85
- err.message = `${err.message} ${err.statusText}`;
86
- }
87
- if (err && err.description) {
88
- err.message = `${err.message} ${err.description}`;
89
- }
90
- return err;
91
- }
92
-
93
- module.exports = {
94
- BackupError: BackupError,
95
- HTTPError: HTTPError,
96
- convertResponseError: convertResponseError,
97
- terminationCallback: function terminationCallback(err, data) {
98
- if (err) {
99
- console.error(`ERROR: ${err.message}`);
100
- process.exitCode = codes[err.name] || 1;
101
- process.exit();
102
- }
103
- }
110
+ getChanges();
104
111
  };