@cloudant/couchbackup 2.9.10 → 2.9.11-SNAPSHOT.115
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.
- package/.scannerwork/report-task.txt +2 -2
- package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
- package/.scannerwork/scanner-report/changesets-36.pb +1 -0
- package/.scannerwork/scanner-report/changesets-39.pb +1 -0
- package/.scannerwork/scanner-report/changesets-42.pb +1 -0
- package/.scannerwork/scanner-report/changesets-45.pb +1 -0
- package/.scannerwork/scanner-report/changesets-53.pb +1 -0
- package/.scannerwork/scanner-report/changesets-54.pb +1 -0
- package/.scannerwork/scanner-report/changesets-55.pb +1 -0
- package/.scannerwork/scanner-report/changesets-57.pb +1 -0
- package/.scannerwork/scanner-report/changesets-58.pb +1 -0
- package/.scannerwork/scanner-report/changesets-61.pb +1 -0
- package/.scannerwork/scanner-report/changesets-62.pb +1 -0
- package/.scannerwork/scanner-report/changesets-63.pb +1 -0
- package/.scannerwork/scanner-report/changesets-64.pb +1 -0
- package/.scannerwork/scanner-report/changesets-65.pb +1 -0
- package/.scannerwork/scanner-report/component-1.pb +2 -2
- package/.scannerwork/scanner-report/component-10.pb +1 -1
- package/.scannerwork/scanner-report/component-11.pb +1 -1
- package/.scannerwork/scanner-report/component-12.pb +1 -1
- package/.scannerwork/scanner-report/component-13.pb +1 -1
- package/.scannerwork/scanner-report/component-14.pb +1 -1
- package/.scannerwork/scanner-report/component-2.pb +1 -1
- package/.scannerwork/scanner-report/component-26.pb +1 -1
- package/.scannerwork/scanner-report/component-27.pb +1 -1
- package/.scannerwork/scanner-report/component-28.pb +1 -1
- package/.scannerwork/scanner-report/component-29.pb +1 -1
- package/.scannerwork/scanner-report/component-3.pb +1 -1
- package/.scannerwork/scanner-report/component-30.pb +1 -1
- package/.scannerwork/scanner-report/component-31.pb +1 -1
- package/.scannerwork/scanner-report/component-32.pb +1 -1
- package/.scannerwork/scanner-report/component-33.pb +1 -1
- package/.scannerwork/scanner-report/component-34.pb +1 -1
- package/.scannerwork/scanner-report/component-35.pb +1 -1
- package/.scannerwork/scanner-report/component-36.pb +1 -0
- package/.scannerwork/scanner-report/component-37.pb +1 -0
- package/.scannerwork/scanner-report/component-38.pb +1 -0
- package/.scannerwork/scanner-report/component-39.pb +1 -0
- package/.scannerwork/scanner-report/component-4.pb +1 -1
- package/.scannerwork/scanner-report/component-42.pb +1 -0
- package/.scannerwork/scanner-report/component-45.pb +1 -0
- package/.scannerwork/scanner-report/component-49.pb +1 -1
- package/.scannerwork/scanner-report/component-5.pb +1 -1
- package/.scannerwork/scanner-report/component-52.pb +1 -1
- package/.scannerwork/scanner-report/component-53.pb +1 -0
- package/.scannerwork/scanner-report/component-54.pb +1 -1
- package/.scannerwork/scanner-report/component-55.pb +1 -0
- package/.scannerwork/scanner-report/component-56.pb +1 -1
- package/.scannerwork/scanner-report/component-57.pb +1 -0
- package/.scannerwork/scanner-report/component-58.pb +1 -0
- package/.scannerwork/scanner-report/component-59.pb +1 -1
- package/.scannerwork/scanner-report/component-6.pb +1 -1
- package/.scannerwork/scanner-report/component-60.pb +1 -1
- package/.scannerwork/scanner-report/component-61.pb +1 -0
- package/.scannerwork/scanner-report/component-62.pb +1 -0
- package/.scannerwork/scanner-report/component-63.pb +1 -0
- package/.scannerwork/scanner-report/component-64.pb +1 -0
- package/.scannerwork/scanner-report/component-65.pb +1 -1
- package/.scannerwork/scanner-report/component-67.pb +1 -1
- package/.scannerwork/scanner-report/component-7.pb +1 -1
- package/.scannerwork/scanner-report/component-8.pb +1 -1
- package/.scannerwork/scanner-report/component-9.pb +1 -1
- package/.scannerwork/scanner-report/coverages-10.pb +0 -0
- package/.scannerwork/scanner-report/coverages-11.pb +0 -0
- package/.scannerwork/scanner-report/coverages-12.pb +0 -0
- package/.scannerwork/scanner-report/coverages-13.pb +0 -0
- package/.scannerwork/scanner-report/coverages-14.pb +0 -0
- package/.scannerwork/scanner-report/coverages-2.pb +0 -0
- package/.scannerwork/scanner-report/coverages-26.pb +0 -0
- package/.scannerwork/scanner-report/coverages-27.pb +0 -0
- package/.scannerwork/scanner-report/coverages-28.pb +0 -0
- package/.scannerwork/scanner-report/coverages-29.pb +0 -0
- package/.scannerwork/scanner-report/coverages-3.pb +0 -0
- package/.scannerwork/scanner-report/coverages-30.pb +0 -0
- package/.scannerwork/scanner-report/coverages-31.pb +0 -0
- package/.scannerwork/scanner-report/coverages-32.pb +0 -0
- package/.scannerwork/scanner-report/coverages-33.pb +0 -0
- package/.scannerwork/scanner-report/coverages-34.pb +0 -0
- package/.scannerwork/scanner-report/coverages-35.pb +0 -0
- package/.scannerwork/scanner-report/coverages-39.pb +0 -0
- package/.scannerwork/scanner-report/coverages-4.pb +0 -0
- package/.scannerwork/scanner-report/coverages-42.pb +0 -0
- package/.scannerwork/scanner-report/coverages-45.pb +0 -0
- package/.scannerwork/scanner-report/coverages-49.pb +0 -0
- package/.scannerwork/scanner-report/coverages-5.pb +0 -0
- package/.scannerwork/scanner-report/coverages-52.pb +0 -0
- package/.scannerwork/scanner-report/coverages-53.pb +0 -0
- package/.scannerwork/scanner-report/coverages-54.pb +0 -0
- package/.scannerwork/scanner-report/coverages-55.pb +0 -0
- package/.scannerwork/scanner-report/coverages-56.pb +0 -0
- package/.scannerwork/scanner-report/coverages-57.pb +0 -0
- package/.scannerwork/scanner-report/coverages-58.pb +0 -0
- package/.scannerwork/scanner-report/coverages-59.pb +0 -0
- package/.scannerwork/scanner-report/coverages-6.pb +0 -0
- package/.scannerwork/scanner-report/coverages-60.pb +0 -0
- package/.scannerwork/scanner-report/coverages-61.pb +0 -0
- package/.scannerwork/scanner-report/coverages-63.pb +0 -0
- package/.scannerwork/scanner-report/coverages-64.pb +0 -0
- package/.scannerwork/scanner-report/coverages-65.pb +0 -0
- package/.scannerwork/scanner-report/coverages-7.pb +0 -0
- package/.scannerwork/scanner-report/coverages-8.pb +0 -0
- package/.scannerwork/scanner-report/coverages-9.pb +0 -0
- package/.scannerwork/scanner-report/duplications-14.pb +3 -0
- package/.scannerwork/scanner-report/duplications-2.pb +0 -2
- package/.scannerwork/scanner-report/duplications-26.pb +3 -0
- package/.scannerwork/scanner-report/duplications-27.pb +1 -1
- package/.scannerwork/scanner-report/duplications-28.pb +2 -0
- package/.scannerwork/scanner-report/duplications-29.pb +0 -2
- package/.scannerwork/scanner-report/duplications-32.pb +0 -3
- package/.scannerwork/scanner-report/duplications-34.pb +0 -2
- package/.scannerwork/scanner-report/duplications-4.pb +2 -1
- package/.scannerwork/scanner-report/duplications-42.pb +2 -0
- package/.scannerwork/scanner-report/duplications-45.pb +2 -0
- package/.scannerwork/scanner-report/duplications-52.pb +0 -3
- package/.scannerwork/scanner-report/duplications-55.pb +2 -0
- package/.scannerwork/scanner-report/duplications-59.pb +0 -2
- package/.scannerwork/scanner-report/duplications-60.pb +1 -1
- package/.scannerwork/scanner-report/duplications-9.pb +2 -0
- package/.scannerwork/scanner-report/measures-10.pb +0 -0
- package/.scannerwork/scanner-report/measures-11.pb +0 -0
- package/.scannerwork/scanner-report/measures-12.pb +0 -0
- package/.scannerwork/scanner-report/measures-13.pb +0 -0
- package/.scannerwork/scanner-report/measures-14.pb +0 -0
- package/.scannerwork/scanner-report/measures-2.pb +0 -0
- package/.scannerwork/scanner-report/measures-26.pb +0 -0
- package/.scannerwork/scanner-report/measures-27.pb +0 -0
- package/.scannerwork/scanner-report/measures-28.pb +0 -0
- package/.scannerwork/scanner-report/measures-29.pb +0 -0
- package/.scannerwork/scanner-report/measures-3.pb +0 -0
- package/.scannerwork/scanner-report/measures-30.pb +0 -0
- package/.scannerwork/scanner-report/measures-31.pb +0 -0
- package/.scannerwork/scanner-report/measures-32.pb +0 -0
- package/.scannerwork/scanner-report/measures-33.pb +0 -0
- package/.scannerwork/scanner-report/measures-34.pb +0 -0
- package/.scannerwork/scanner-report/measures-35.pb +0 -0
- package/.scannerwork/scanner-report/measures-38.pb +0 -0
- package/.scannerwork/scanner-report/measures-39.pb +0 -0
- package/.scannerwork/scanner-report/measures-4.pb +0 -0
- package/.scannerwork/scanner-report/measures-42.pb +0 -0
- package/.scannerwork/scanner-report/measures-45.pb +0 -0
- package/.scannerwork/scanner-report/measures-49.pb +0 -0
- package/.scannerwork/scanner-report/measures-5.pb +0 -0
- package/.scannerwork/scanner-report/measures-52.pb +0 -0
- package/.scannerwork/scanner-report/measures-53.pb +0 -0
- package/.scannerwork/scanner-report/measures-54.pb +0 -0
- package/.scannerwork/scanner-report/measures-55.pb +0 -0
- package/.scannerwork/scanner-report/measures-56.pb +0 -0
- package/.scannerwork/scanner-report/measures-57.pb +0 -0
- package/.scannerwork/scanner-report/measures-58.pb +16 -0
- package/.scannerwork/scanner-report/measures-59.pb +0 -0
- package/.scannerwork/scanner-report/measures-6.pb +0 -0
- package/.scannerwork/scanner-report/measures-60.pb +0 -0
- package/.scannerwork/scanner-report/measures-61.pb +0 -0
- package/.scannerwork/scanner-report/measures-63.pb +0 -0
- package/.scannerwork/scanner-report/measures-64.pb +15 -0
- package/.scannerwork/scanner-report/measures-65.pb +0 -0
- package/.scannerwork/scanner-report/measures-67.pb +0 -0
- package/.scannerwork/scanner-report/measures-7.pb +0 -0
- package/.scannerwork/scanner-report/measures-8.pb +0 -0
- package/.scannerwork/scanner-report/measures-9.pb +0 -0
- package/.scannerwork/scanner-report/metadata.pb +0 -0
- package/.scannerwork/scanner-report/source-10.txt +18 -263
- package/.scannerwork/scanner-report/source-11.txt +127 -103
- package/.scannerwork/scanner-report/source-12.txt +78 -32
- package/.scannerwork/scanner-report/source-13.txt +49 -115
- package/.scannerwork/scanner-report/source-14.txt +229 -89
- package/.scannerwork/scanner-report/source-2.txt +47 -54
- package/.scannerwork/scanner-report/source-26.txt +107 -123
- package/.scannerwork/scanner-report/source-27.txt +194 -114
- package/.scannerwork/scanner-report/source-28.txt +271 -14
- package/.scannerwork/scanner-report/source-29.txt +344 -271
- package/.scannerwork/scanner-report/source-3.txt +32 -163
- package/.scannerwork/scanner-report/source-30.txt +585 -52
- package/.scannerwork/scanner-report/source-31.txt +17 -124
- package/.scannerwork/scanner-report/source-32.txt +13 -108
- package/.scannerwork/scanner-report/source-33.txt +47 -47
- package/.scannerwork/scanner-report/source-34.txt +115 -193
- package/.scannerwork/scanner-report/source-35.txt +61 -31
- package/.scannerwork/scanner-report/{source-66.txt → source-37.txt} +146 -146
- package/.scannerwork/scanner-report/source-38.txt +509 -0
- package/.scannerwork/scanner-report/source-39.txt +418 -0
- package/.scannerwork/scanner-report/source-4.txt +94 -67
- package/.scannerwork/scanner-report/source-42.txt +175 -0
- package/.scannerwork/scanner-report/source-45.txt +190 -0
- package/.scannerwork/scanner-report/source-49.txt +93 -345
- package/.scannerwork/scanner-report/source-5.txt +82 -93
- package/.scannerwork/scanner-report/source-52.txt +17 -105
- package/.scannerwork/scanner-report/source-53.txt +111 -0
- package/.scannerwork/scanner-report/source-54.txt +46 -167
- package/.scannerwork/scanner-report/source-55.txt +92 -0
- package/.scannerwork/scanner-report/source-56.txt +57 -395
- package/.scannerwork/scanner-report/source-57.txt +118 -0
- package/.scannerwork/scanner-report/source-58.txt +178 -0
- package/.scannerwork/scanner-report/source-59.txt +107 -168
- package/.scannerwork/scanner-report/source-6.txt +138 -146
- package/.scannerwork/scanner-report/source-60.txt +52 -152
- package/.scannerwork/scanner-report/source-61.txt +281 -0
- package/.scannerwork/scanner-report/source-63.txt +164 -0
- package/.scannerwork/scanner-report/source-64.txt +104 -0
- package/.scannerwork/scanner-report/source-65.txt +54 -509
- package/.scannerwork/scanner-report/source-67.txt +167 -77
- package/.scannerwork/scanner-report/source-7.txt +19 -65
- package/.scannerwork/scanner-report/source-8.txt +14 -39
- package/.scannerwork/scanner-report/source-9.txt +131 -17
- package/.scannerwork/scanner-report/symbols-10.pb +10 -353
- package/.scannerwork/scanner-report/symbols-11.pb +116 -30
- package/.scannerwork/scanner-report/symbols-12.pb +60 -20
- package/.scannerwork/scanner-report/symbols-13.pb +42 -32
- package/.scannerwork/scanner-report/symbols-14.pb +393 -41
- package/.scannerwork/scanner-report/symbols-2.pb +35 -41
- package/.scannerwork/scanner-report/symbols-26.pb +97 -85
- package/.scannerwork/scanner-report/symbols-27.pb +418 -102
- package/.scannerwork/scanner-report/symbols-28.pb +486 -11
- package/.scannerwork/scanner-report/symbols-29.pb +458 -450
- package/.scannerwork/scanner-report/symbols-3.pb +27 -144
- package/.scannerwork/scanner-report/symbols-30.pb +1254 -60
- package/.scannerwork/scanner-report/symbols-31.pb +17 -116
- package/.scannerwork/scanner-report/symbols-32.pb +13 -96
- package/.scannerwork/scanner-report/symbols-33.pb +44 -35
- package/.scannerwork/scanner-report/symbols-34.pb +81 -414
- package/.scannerwork/scanner-report/symbols-35.pb +30 -27
- package/.scannerwork/scanner-report/symbols-39.pb +610 -0
- package/.scannerwork/scanner-report/symbols-4.pb +76 -43
- package/.scannerwork/scanner-report/symbols-42.pb +153 -0
- package/.scannerwork/scanner-report/symbols-45.pb +180 -0
- package/.scannerwork/scanner-report/symbols-49.pb +27 -493
- package/.scannerwork/scanner-report/symbols-5.pb +68 -58
- package/.scannerwork/scanner-report/symbols-52.pb +13 -76
- package/.scannerwork/scanner-report/symbols-53.pb +59 -0
- package/.scannerwork/scanner-report/symbols-54.pb +20 -0
- package/.scannerwork/scanner-report/symbols-55.pb +44 -0
- package/.scannerwork/scanner-report/symbols-56.pb +46 -610
- package/.scannerwork/scanner-report/symbols-57.pb +30 -0
- package/.scannerwork/scanner-report/symbols-58.pb +144 -0
- package/.scannerwork/scanner-report/symbols-59.pb +33 -180
- package/.scannerwork/scanner-report/symbols-6.pb +100 -114
- package/.scannerwork/scanner-report/symbols-60.pb +41 -152
- package/.scannerwork/scanner-report/symbols-61.pb +354 -0
- package/.scannerwork/scanner-report/symbols-63.pb +126 -0
- package/.scannerwork/scanner-report/symbols-64.pb +42 -0
- package/.scannerwork/scanner-report/symbols-65.pb +15 -0
- package/.scannerwork/scanner-report/symbols-7.pb +9 -45
- package/.scannerwork/scanner-report/symbols-8.pb +9 -15
- package/.scannerwork/scanner-report/symbols-9.pb +102 -14
- package/.scannerwork/scanner-report/syntax-highlightings-10.pb +26 -252
- package/.scannerwork/scanner-report/syntax-highlightings-11.pb +104 -83
- package/.scannerwork/scanner-report/syntax-highlightings-12.pb +78 -32
- package/.scannerwork/scanner-report/syntax-highlightings-13.pb +47 -94
- package/.scannerwork/scanner-report/syntax-highlightings-14.pb +298 -85
- package/.scannerwork/scanner-report/syntax-highlightings-2.pb +63 -46
- package/.scannerwork/scanner-report/syntax-highlightings-26.pb +147 -156
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +290 -186
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +625 -25
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +346 -375
- package/.scannerwork/scanner-report/syntax-highlightings-3.pb +30 -205
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +840 -63
- package/.scannerwork/scanner-report/syntax-highlightings-31.pb +27 -98
- package/.scannerwork/scanner-report/syntax-highlightings-32.pb +19 -147
- package/.scannerwork/scanner-report/syntax-highlightings-33.pb +74 -59
- package/.scannerwork/scanner-report/syntax-highlightings-34.pb +148 -288
- package/.scannerwork/scanner-report/syntax-highlightings-35.pb +80 -45
- package/.scannerwork/scanner-report/{syntax-highlightings-66.pb → syntax-highlightings-37.pb} +92 -91
- package/.scannerwork/scanner-report/syntax-highlightings-38.pb +3746 -0
- package/.scannerwork/scanner-report/syntax-highlightings-39.pb +648 -0
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +122 -54
- package/.scannerwork/scanner-report/syntax-highlightings-42.pb +214 -0
- package/.scannerwork/scanner-report/syntax-highlightings-45.pb +225 -0
- package/.scannerwork/scanner-report/syntax-highlightings-49.pb +102 -594
- package/.scannerwork/scanner-report/syntax-highlightings-5.pb +66 -94
- package/.scannerwork/scanner-report/syntax-highlightings-52.pb +16 -129
- package/.scannerwork/scanner-report/syntax-highlightings-53.pb +133 -0
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +53 -938
- package/.scannerwork/scanner-report/syntax-highlightings-55.pb +90 -0
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +63 -616
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +113 -0
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +243 -0
- package/.scannerwork/scanner-report/syntax-highlightings-59.pb +96 -192
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +178 -168
- package/.scannerwork/scanner-report/syntax-highlightings-60.pb +47 -183
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +285 -0
- package/.scannerwork/scanner-report/syntax-highlightings-63.pb +213 -0
- package/.scannerwork/scanner-report/syntax-highlightings-64.pb +116 -0
- package/.scannerwork/scanner-report/syntax-highlightings-65.pb +43 -3737
- package/.scannerwork/scanner-report/syntax-highlightings-67.pb +917 -71
- package/.scannerwork/scanner-report/syntax-highlightings-7.pb +18 -63
- package/.scannerwork/scanner-report/syntax-highlightings-8.pb +19 -25
- package/.scannerwork/scanner-report/syntax-highlightings-9.pb +197 -15
- package/package.json +1 -1
- package/test-16-results.xml +156 -156
- package/test-18-results.xml +153 -153
- package/test-iam-18-results.xml +50 -50
- package/.scannerwork/scanner-report/changesets-15.pb +0 -1
- package/.scannerwork/scanner-report/changesets-19.pb +0 -1
- package/.scannerwork/scanner-report/changesets-20.pb +0 -1
- package/.scannerwork/scanner-report/changesets-21.pb +0 -1
- package/.scannerwork/scanner-report/changesets-22.pb +0 -1
- package/.scannerwork/scanner-report/changesets-23.pb +0 -1
- package/.scannerwork/scanner-report/changesets-24.pb +0 -1
- package/.scannerwork/scanner-report/changesets-25.pb +0 -1
- package/.scannerwork/scanner-report/changesets-47.pb +0 -1
- package/.scannerwork/scanner-report/changesets-48.pb +0 -1
- package/.scannerwork/scanner-report/changesets-50.pb +0 -1
- package/.scannerwork/scanner-report/changesets-51.pb +0 -1
- package/.scannerwork/scanner-report/changesets-67.pb +0 -1
- package/.scannerwork/scanner-report/changesets-68.pb +0 -1
- package/.scannerwork/scanner-report/component-15.pb +0 -1
- package/.scannerwork/scanner-report/component-19.pb +0 -1
- package/.scannerwork/scanner-report/component-20.pb +0 -1
- package/.scannerwork/scanner-report/component-21.pb +0 -1
- package/.scannerwork/scanner-report/component-22.pb +0 -1
- package/.scannerwork/scanner-report/component-23.pb +0 -1
- package/.scannerwork/scanner-report/component-24.pb +0 -1
- package/.scannerwork/scanner-report/component-25.pb +0 -1
- package/.scannerwork/scanner-report/component-47.pb +0 -1
- package/.scannerwork/scanner-report/component-48.pb +0 -1
- package/.scannerwork/scanner-report/component-50.pb +0 -1
- package/.scannerwork/scanner-report/component-51.pb +0 -1
- package/.scannerwork/scanner-report/component-66.pb +0 -1
- package/.scannerwork/scanner-report/component-68.pb +0 -1
- package/.scannerwork/scanner-report/coverages-19.pb +0 -0
- package/.scannerwork/scanner-report/coverages-20.pb +0 -0
- package/.scannerwork/scanner-report/coverages-21.pb +0 -0
- package/.scannerwork/scanner-report/coverages-22.pb +0 -0
- package/.scannerwork/scanner-report/coverages-23.pb +0 -0
- package/.scannerwork/scanner-report/coverages-24.pb +0 -0
- package/.scannerwork/scanner-report/coverages-25.pb +0 -0
- package/.scannerwork/scanner-report/coverages-47.pb +0 -0
- package/.scannerwork/scanner-report/coverages-48.pb +0 -0
- package/.scannerwork/scanner-report/coverages-50.pb +0 -0
- package/.scannerwork/scanner-report/coverages-51.pb +0 -0
- package/.scannerwork/scanner-report/coverages-67.pb +0 -0
- package/.scannerwork/scanner-report/duplications-21.pb +0 -3
- package/.scannerwork/scanner-report/duplications-68.pb +0 -0
- package/.scannerwork/scanner-report/duplications-8.pb +0 -0
- package/.scannerwork/scanner-report/measures-19.pb +0 -0
- package/.scannerwork/scanner-report/measures-20.pb +0 -0
- package/.scannerwork/scanner-report/measures-21.pb +0 -0
- package/.scannerwork/scanner-report/measures-22.pb +0 -0
- package/.scannerwork/scanner-report/measures-23.pb +0 -0
- package/.scannerwork/scanner-report/measures-24.pb +0 -0
- package/.scannerwork/scanner-report/measures-25.pb +0 -0
- package/.scannerwork/scanner-report/measures-47.pb +0 -0
- package/.scannerwork/scanner-report/measures-48.pb +0 -0
- package/.scannerwork/scanner-report/measures-50.pb +0 -0
- package/.scannerwork/scanner-report/measures-51.pb +0 -0
- package/.scannerwork/scanner-report/source-19.txt +0 -114
- package/.scannerwork/scanner-report/source-20.txt +0 -35
- package/.scannerwork/scanner-report/source-21.txt +0 -244
- package/.scannerwork/scanner-report/source-22.txt +0 -36
- package/.scannerwork/scanner-report/source-23.txt +0 -625
- package/.scannerwork/scanner-report/source-24.txt +0 -34
- package/.scannerwork/scanner-report/source-25.txt +0 -156
- package/.scannerwork/scanner-report/source-47.txt +0 -63
- package/.scannerwork/scanner-report/source-48.txt +0 -68
- package/.scannerwork/scanner-report/source-50.txt +0 -29
- package/.scannerwork/scanner-report/source-51.txt +0 -100
- package/.scannerwork/scanner-report/symbols-19.pb +0 -28
- package/.scannerwork/scanner-report/symbols-20.pb +0 -17
- package/.scannerwork/scanner-report/symbols-21.pb +0 -394
- package/.scannerwork/scanner-report/symbols-22.pb +0 -14
- package/.scannerwork/scanner-report/symbols-23.pb +0 -1254
- package/.scannerwork/scanner-report/symbols-24.pb +0 -10
- package/.scannerwork/scanner-report/symbols-25.pb +0 -112
- package/.scannerwork/scanner-report/symbols-47.pb +0 -43
- package/.scannerwork/scanner-report/symbols-48.pb +0 -45
- package/.scannerwork/scanner-report/symbols-50.pb +0 -9
- package/.scannerwork/scanner-report/symbols-51.pb +0 -69
- package/.scannerwork/scanner-report/symbols-67.pb +0 -30
- package/.scannerwork/scanner-report/syntax-highlightings-19.pb +0 -138
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -63
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -329
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +0 -54
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +0 -887
- package/.scannerwork/scanner-report/syntax-highlightings-24.pb +0 -50
- package/.scannerwork/scanner-report/syntax-highlightings-25.pb +0 -223
- package/.scannerwork/scanner-report/syntax-highlightings-47.pb +0 -82
- package/.scannerwork/scanner-report/syntax-highlightings-48.pb +0 -110
- package/.scannerwork/scanner-report/syntax-highlightings-50.pb +0 -48
- package/.scannerwork/scanner-report/syntax-highlightings-51.pb +0 -105
- /package/.scannerwork/scanner-report/{coverages-68.pb → coverages-36.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-15.pb → coverages-62.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-15.pb → duplications-36.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-19.pb → duplications-39.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-53.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-22.pb → duplications-54.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-23.pb → duplications-57.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-24.pb → duplications-58.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-61.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-47.pb → duplications-62.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-48.pb → duplications-63.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-51.pb → duplications-64.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-67.pb → duplications-65.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-31.pb → issues-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-21.pb → issues-14.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-49.pb → issues-29.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-35.pb → issues-3.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-68.pb → measures-36.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-66.pb → measures-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-15.pb → measures-62.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-68.txt → source-36.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-15.txt → source-62.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-68.pb → symbols-36.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-15.pb → symbols-62.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-68.pb → syntax-highlightings-36.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-15.pb → syntax-highlightings-62.pb} +0 -0
|
@@ -11,154 +11,146 @@
|
|
|
11
11
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
12
|
// See the License for the specific language governing permissions and
|
|
13
13
|
// limitations under the License.
|
|
14
|
-
'use strict';
|
|
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
14
|
|
|
27
|
-
|
|
28
|
-
|
|
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
|
-
}
|
|
15
|
+
/* global describe it */
|
|
16
|
+
'use strict';
|
|
37
17
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
18
|
+
const assert = require('assert');
|
|
19
|
+
const nock = require('nock');
|
|
20
|
+
const request = require('../includes/request.js');
|
|
21
|
+
const changes = require('../includes/spoolchanges.js');
|
|
22
|
+
|
|
23
|
+
const url = 'http://localhost:7777';
|
|
24
|
+
const dbName = 'fakenockdb';
|
|
25
|
+
const longTestTimeout = 3000;
|
|
26
|
+
|
|
27
|
+
const db = request.client(`${url}/${dbName}`, { parallelism: 1 });
|
|
28
|
+
|
|
29
|
+
const seqSuffix = Buffer.alloc(124, 'abc123').toString('base64');
|
|
30
|
+
function provideChanges(batchSize, totalChanges, fullResponse = false) {
|
|
31
|
+
let pending = totalChanges;
|
|
32
|
+
const sparseResultsArray = Array(batchSize).fill({
|
|
33
|
+
seq: null,
|
|
34
|
+
id: 'doc',
|
|
35
|
+
changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
|
|
36
|
+
});
|
|
37
|
+
nock(url)
|
|
38
|
+
.post(`/${dbName}/_changes`)
|
|
39
|
+
.query(true)
|
|
40
|
+
.times(totalChanges / batchSize + (totalChanges % batchSize > 0 ? 1 : 0))
|
|
41
|
+
.reply(200, (uri, requestBody) => {
|
|
42
|
+
pending -= batchSize;
|
|
43
|
+
const lastSeq = (totalChanges - pending);
|
|
44
|
+
const seq = lastSeq - batchSize;
|
|
45
|
+
return {
|
|
46
|
+
results: fullResponse
|
|
47
|
+
? Array.from(Array(batchSize), (_, i) => {
|
|
48
|
+
return {
|
|
49
|
+
seq: `${seq + i}-${seqSuffix}`,
|
|
50
|
+
id: `doc${seq + i}`,
|
|
51
|
+
changes: [{ rev: '1-abcdef0123456789abcdef0123456789' }]
|
|
52
|
+
};
|
|
53
|
+
})
|
|
54
|
+
: sparseResultsArray,
|
|
55
|
+
pending: pending,
|
|
56
|
+
last_seq: `${lastSeq}-abc`
|
|
57
|
+
};
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
describe('#unit Check spool changes', function() {
|
|
62
|
+
it('should terminate on request error', function(done) {
|
|
63
|
+
nock(url)
|
|
64
|
+
.post(`/${dbName}/_changes`)
|
|
65
|
+
.query(true)
|
|
66
|
+
.times(3)
|
|
67
|
+
.replyWithError({ code: 'ECONNRESET', message: 'socket hang up' });
|
|
68
|
+
|
|
69
|
+
changes(db, '/dev/null', 500, null, function(err) {
|
|
70
|
+
assert.strictEqual(err.name, 'SpoolChangesError');
|
|
71
|
+
assert.strictEqual(err.message, `Failed changes request - socket hang up: post ${url}/${dbName}/_changes`);
|
|
72
|
+
assert.ok(nock.isDone());
|
|
73
|
+
done();
|
|
74
|
+
});
|
|
75
|
+
}).timeout(longTestTimeout);
|
|
76
|
+
|
|
77
|
+
it('should terminate on bad HTTP status code response', function(done) {
|
|
78
|
+
nock(url)
|
|
79
|
+
.post(`/${dbName}/_changes`)
|
|
80
|
+
.query(true)
|
|
81
|
+
.times(3)
|
|
82
|
+
.reply(500, function(uri, requestBody) {
|
|
83
|
+
this.req.response.statusMessage = 'Internal Server Error';
|
|
84
|
+
return { error: 'foo', reason: 'bar' };
|
|
54
85
|
});
|
|
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
86
|
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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();
|
|
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();
|
|
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 {
|
|
87
|
+
changes(db, '/dev/null', 500, null, function(err) {
|
|
88
|
+
assert.strictEqual(err.name, 'HTTPFatalError');
|
|
89
|
+
assert.strictEqual(err.message, `500 Internal Server Error: post ${url}/${dbName}/_changes - Error: foo, Reason: bar`);
|
|
90
|
+
assert.ok(nock.isDone());
|
|
155
91
|
done();
|
|
156
|
-
}
|
|
157
|
-
};
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
92
|
+
});
|
|
93
|
+
}).timeout(longTestTimeout);
|
|
94
|
+
|
|
95
|
+
it('should keep collecting changes', function(done) {
|
|
96
|
+
// This test validates that spooling will correctly
|
|
97
|
+
// continue across multiple requests
|
|
98
|
+
// (4 batches of 100000 to be precise).
|
|
99
|
+
// This test might take up to 10 seconds
|
|
100
|
+
this.timeout(10 * 1000);
|
|
101
|
+
|
|
102
|
+
// Use full changes for this test
|
|
103
|
+
provideChanges(100000, 400000, true);
|
|
104
|
+
changes(db, '/dev/null', 500, null, function(err) {
|
|
105
|
+
assert.ok(!err);
|
|
106
|
+
assert.ok(nock.isDone());
|
|
107
|
+
done();
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('should keep collecting sparse changes', function(done) {
|
|
112
|
+
// This test checks that making thousands of requests doesn't
|
|
113
|
+
// make anything bad happen.
|
|
114
|
+
// This test might take up to 25 seconds
|
|
115
|
+
this.timeout(25 * 1000);
|
|
116
|
+
// Use sparse changes for this test and a batch size of 1
|
|
117
|
+
provideChanges(1, 2500);
|
|
118
|
+
changes(db, '/dev/null', 500, null, function(err) {
|
|
119
|
+
assert.ok(!err);
|
|
120
|
+
assert.ok(nock.isDone());
|
|
121
|
+
done();
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
describe('Longer spool changes checks', function() {
|
|
127
|
+
it('#slow should keep collecting changes (25M)', function(done) {
|
|
128
|
+
// This test might take up to 5 minutes
|
|
129
|
+
this.timeout(5 * 60 * 1000);
|
|
130
|
+
// Note changes spooling uses a constant batch size, we are setting
|
|
131
|
+
// a test value here and setting the buffer to match
|
|
132
|
+
const batch = 100000;
|
|
133
|
+
// Use sparse changes for this test
|
|
134
|
+
provideChanges(batch, 25000000);
|
|
135
|
+
changes(db, '/dev/null', batch, null, function(err) {
|
|
136
|
+
assert.ok(!err);
|
|
137
|
+
assert.ok(nock.isDone());
|
|
138
|
+
done();
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
it('#slower should keep collecting changes (500M)', function(done) {
|
|
143
|
+
// This test might take up to 90 minutes
|
|
144
|
+
this.timeout(90 * 60 * 1000);
|
|
145
|
+
// Note changes spooling uses a constant batch size, we are setting
|
|
146
|
+
// a test value here and setting the buffer to match
|
|
147
|
+
const batch = 1000000;
|
|
148
|
+
// Use full changes for this test to exercise load
|
|
149
|
+
provideChanges(batch, 500000000, true);
|
|
150
|
+
changes(db, '/dev/null', batch, null, function(err) {
|
|
151
|
+
assert.ok(!err);
|
|
152
|
+
assert.ok(nock.isDone());
|
|
153
|
+
done();
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
});
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright © 2017
|
|
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.
|
|
@@ -11,165 +11,65 @@
|
|
|
11
11
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
12
|
// See the License for the specific language governing permissions and
|
|
13
13
|
// limitations under the License.
|
|
14
|
-
|
|
15
|
-
// Small script which backs up a Cloudant or CouchDB database to an S3
|
|
16
|
-
// bucket via a stream rather than on-disk file.
|
|
17
|
-
//
|
|
18
|
-
// The script generates the backup object name by combining together the path
|
|
19
|
-
// part of the database URL and the current time.
|
|
20
|
-
|
|
21
14
|
'use strict';
|
|
22
15
|
|
|
16
|
+
const fs = require('fs');
|
|
23
17
|
const stream = require('stream');
|
|
24
|
-
const
|
|
25
|
-
|
|
26
|
-
const
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
awsprofile: { nargs: 1, describe: 'The profile section to use in the ~/.aws/credentials file', default: 'default' }
|
|
44
|
-
})
|
|
45
|
-
.help('h').alias('h', 'help')
|
|
46
|
-
.epilog('Copyright (C) IBM 2017')
|
|
47
|
-
.argv;
|
|
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
|
+
}
|
|
48
37
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
38
|
+
// extract batch
|
|
39
|
+
matches = line.match(/ batch([0-9]+)/);
|
|
40
|
+
if (matches) {
|
|
41
|
+
obj.batch = parseInt(matches[1]);
|
|
42
|
+
}
|
|
54
43
|
|
|
55
|
-
|
|
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
|
+
};
|
|
56
55
|
|
|
57
|
-
|
|
58
|
-
|
|
56
|
+
module.exports = function(log, batches, callback) {
|
|
57
|
+
// our sense of state
|
|
58
|
+
const retval = { };
|
|
59
59
|
|
|
60
|
-
//
|
|
61
|
-
const
|
|
62
|
-
|
|
63
|
-
credentials: new AWS.SharedIniFileCredentials({ profile: awsProfile })
|
|
60
|
+
// called with each line from the log file
|
|
61
|
+
const onCommand = function(obj) {
|
|
62
|
+
retval[obj.batch] = obj;
|
|
64
63
|
};
|
|
65
|
-
if (typeof s3Endpoint !== 'undefined') {
|
|
66
|
-
awsOpts.endpoint = new AWS.Endpoint(s3Endpoint);
|
|
67
|
-
}
|
|
68
|
-
const s3 = new AWS.S3(awsOpts);
|
|
69
64
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
.
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
debug('done.');
|
|
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);
|
|
77
71
|
})
|
|
78
|
-
.
|
|
79
|
-
|
|
80
|
-
process.exit(1);
|
|
72
|
+
.on('finish', function() {
|
|
73
|
+
callback(null, retval);
|
|
81
74
|
});
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
* Return a promise that resolves if the bucket is available and
|
|
86
|
-
* rejects if not.
|
|
87
|
-
*
|
|
88
|
-
* @param {any} s3 S3 client object
|
|
89
|
-
* @param {any} bucketName Bucket name
|
|
90
|
-
* @returns Promise
|
|
91
|
-
*/
|
|
92
|
-
function bucketAccessible(s3, bucketName) {
|
|
93
|
-
return new Promise(function(resolve, reject) {
|
|
94
|
-
const params = {
|
|
95
|
-
Bucket: bucketName
|
|
96
|
-
};
|
|
97
|
-
s3.headBucket(params, function(err, data) {
|
|
98
|
-
if (err) {
|
|
99
|
-
reject(new VError(err, 'S3 bucket not accessible'));
|
|
100
|
-
} else {
|
|
101
|
-
resolve();
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Backup directly from Cloudant to an object store object via a stream.
|
|
109
|
-
*
|
|
110
|
-
* @param {any} sourceUrl URL of database
|
|
111
|
-
* @param {any} s3Client Object store client
|
|
112
|
-
* @param {any} s3Bucket Backup destination bucket
|
|
113
|
-
* @param {any} s3Key Backup destination key name (shouldn't exist)
|
|
114
|
-
* @param {any} shallow Whether to use the couchbackup `shallow` mode
|
|
115
|
-
* @returns Promise
|
|
116
|
-
*/
|
|
117
|
-
function backupToS3(sourceUrl, s3Client, s3Bucket, s3Key, shallow) {
|
|
118
|
-
return new Promise((resolve, reject) => {
|
|
119
|
-
debug(`Setting up S3 upload to ${s3Bucket}/${s3Key}`);
|
|
120
|
-
|
|
121
|
-
// A pass through stream that has couchbackup's output
|
|
122
|
-
// written to it and it then read by the S3 upload client.
|
|
123
|
-
// It has a 64MB highwater mark to allow for fairly
|
|
124
|
-
// uneven network connectivity.
|
|
125
|
-
const streamToUpload = new stream.PassThrough({ highWaterMark: 67108864 });
|
|
126
|
-
|
|
127
|
-
// Set up S3 upload.
|
|
128
|
-
const params = {
|
|
129
|
-
Bucket: s3Bucket,
|
|
130
|
-
Key: s3Key,
|
|
131
|
-
Body: streamToUpload
|
|
132
|
-
};
|
|
133
|
-
s3Client.upload(params, function(err, data) {
|
|
134
|
-
debug('Object store upload done');
|
|
135
|
-
if (err) {
|
|
136
|
-
debug(err);
|
|
137
|
-
reject(new VError(err, 'Object store upload failed'));
|
|
138
|
-
return;
|
|
139
|
-
}
|
|
140
|
-
debug('Object store upload succeeded');
|
|
141
|
-
debug(data);
|
|
142
|
-
resolve();
|
|
143
|
-
}).httpUploadProgress = (progress) => {
|
|
144
|
-
debug(`Object store upload progress: ${progress}`);
|
|
145
|
-
};
|
|
146
|
-
|
|
147
|
-
debug(`Starting streaming data from ${s(sourceUrl)}`);
|
|
148
|
-
couchbackup.backup(
|
|
149
|
-
sourceUrl,
|
|
150
|
-
streamToUpload,
|
|
151
|
-
(err, obj) => {
|
|
152
|
-
if (err) {
|
|
153
|
-
debug(err);
|
|
154
|
-
reject(new VError(err, 'CouchBackup failed with an error'));
|
|
155
|
-
return;
|
|
156
|
-
}
|
|
157
|
-
debug(`Download from ${s(sourceUrl)} complete.`);
|
|
158
|
-
streamToUpload.end(); // must call end() to complete upload.
|
|
159
|
-
// resolve() is called by the upload
|
|
160
|
-
}
|
|
161
|
-
);
|
|
162
|
-
});
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
/**
|
|
166
|
-
* Remove creds from a URL, e.g., before logging
|
|
167
|
-
*
|
|
168
|
-
* @param {string} url URL to safen
|
|
169
|
-
*/
|
|
170
|
-
function s(originalUrl) {
|
|
171
|
-
const parts = new url.URL(originalUrl);
|
|
172
|
-
return url.format(parts, { auth: false });
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
main();
|
|
75
|
+
};
|