@cloudant/couchbackup 2.9.8-SNAPSHOT.94 → 2.9.8
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/analysis.log +1 -1
- package/.scannerwork/scanner-report/changesets-36.pb +1 -0
- package/.scannerwork/scanner-report/changesets-37.pb +1 -0
- package/.scannerwork/scanner-report/changesets-41.pb +1 -0
- package/.scannerwork/scanner-report/changesets-42.pb +1 -0
- package/.scannerwork/scanner-report/changesets-43.pb +1 -0
- package/.scannerwork/scanner-report/changesets-44.pb +1 -0
- package/.scannerwork/scanner-report/changesets-45.pb +1 -0
- package/.scannerwork/scanner-report/changesets-46.pb +1 -0
- package/.scannerwork/scanner-report/changesets-47.pb +1 -0
- package/.scannerwork/scanner-report/changesets-48.pb +1 -0
- package/.scannerwork/scanner-report/changesets-51.pb +1 -0
- package/.scannerwork/scanner-report/changesets-52.pb +1 -0
- package/.scannerwork/scanner-report/changesets-6.pb +0 -0
- package/.scannerwork/scanner-report/changesets-7.pb +1 -0
- package/.scannerwork/scanner-report/component-1.pb +1 -1
- package/.scannerwork/scanner-report/component-19.pb +1 -1
- package/.scannerwork/scanner-report/component-20.pb +1 -1
- package/.scannerwork/scanner-report/component-21.pb +1 -1
- package/.scannerwork/scanner-report/component-22.pb +1 -1
- package/.scannerwork/scanner-report/component-23.pb +1 -1
- package/.scannerwork/scanner-report/component-24.pb +1 -1
- package/.scannerwork/scanner-report/component-25.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-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 -1
- package/.scannerwork/scanner-report/component-38.pb +1 -1
- package/.scannerwork/scanner-report/component-4.pb +1 -1
- package/.scannerwork/scanner-report/component-40.pb +1 -1
- package/.scannerwork/scanner-report/component-41.pb +1 -0
- package/.scannerwork/scanner-report/component-42.pb +1 -0
- package/.scannerwork/scanner-report/component-43.pb +1 -0
- package/.scannerwork/scanner-report/component-44.pb +1 -0
- package/.scannerwork/scanner-report/component-45.pb +1 -0
- package/.scannerwork/scanner-report/component-46.pb +1 -0
- package/.scannerwork/scanner-report/component-47.pb +1 -0
- package/.scannerwork/scanner-report/component-48.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-50.pb +1 -1
- package/.scannerwork/scanner-report/component-51.pb +1 -1
- package/.scannerwork/scanner-report/component-52.pb +1 -0
- package/.scannerwork/scanner-report/component-53.pb +1 -1
- package/.scannerwork/scanner-report/component-54.pb +1 -1
- package/.scannerwork/scanner-report/component-55.pb +1 -1
- package/.scannerwork/scanner-report/component-57.pb +1 -1
- package/.scannerwork/scanner-report/component-58.pb +1 -1
- package/.scannerwork/scanner-report/component-59.pb +1 -1
- package/.scannerwork/scanner-report/component-6.pb +1 -1
- package/.scannerwork/scanner-report/component-61.pb +1 -1
- package/.scannerwork/scanner-report/component-65.pb +1 -1
- package/.scannerwork/scanner-report/component-66.pb +1 -1
- package/.scannerwork/scanner-report/component-69.pb +1 -1
- package/.scannerwork/scanner-report/component-7.pb +1 -0
- 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-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-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-36.pb +0 -0
- package/.scannerwork/scanner-report/coverages-37.pb +0 -0
- package/.scannerwork/scanner-report/coverages-4.pb +0 -0
- package/.scannerwork/scanner-report/coverages-41.pb +0 -0
- package/.scannerwork/scanner-report/coverages-46.pb +0 -0
- package/.scannerwork/scanner-report/coverages-47.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-50.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-57.pb +0 -0
- package/.scannerwork/scanner-report/coverages-58.pb +0 -0
- package/.scannerwork/scanner-report/coverages-6.pb +0 -0
- package/.scannerwork/scanner-report/coverages-65.pb +0 -0
- package/.scannerwork/scanner-report/coverages-66.pb +0 -0
- package/.scannerwork/scanner-report/coverages-69.pb +0 -0
- package/.scannerwork/scanner-report/coverages-7.pb +0 -0
- package/.scannerwork/scanner-report/duplications-19.pb +3 -0
- package/.scannerwork/scanner-report/duplications-21.pb +2 -0
- package/.scannerwork/scanner-report/duplications-22.pb +3 -0
- package/.scannerwork/scanner-report/duplications-32.pb +2 -3
- package/.scannerwork/scanner-report/duplications-34.pb +0 -2
- package/.scannerwork/scanner-report/duplications-36.pb +2 -0
- package/.scannerwork/scanner-report/duplications-43.pb +2 -0
- package/.scannerwork/scanner-report/duplications-45.pb +2 -0
- package/.scannerwork/scanner-report/duplications-49.pb +0 -2
- package/.scannerwork/scanner-report/duplications-5.pb +3 -3
- package/.scannerwork/scanner-report/duplications-50.pb +0 -2
- package/.scannerwork/scanner-report/duplications-6.pb +0 -2
- package/.scannerwork/scanner-report/duplications-65.pb +2 -0
- package/.scannerwork/scanner-report/duplications-66.pb +2 -0
- package/.scannerwork/scanner-report/duplications-7.pb +0 -0
- package/.scannerwork/scanner-report/issues-28.pb +3 -0
- package/.scannerwork/scanner-report/issues-29.pb +4 -1
- 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-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-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-36.pb +0 -0
- package/.scannerwork/scanner-report/measures-37.pb +0 -0
- package/.scannerwork/scanner-report/measures-4.pb +0 -0
- package/.scannerwork/scanner-report/measures-41.pb +0 -0
- package/.scannerwork/scanner-report/measures-44.pb +16 -0
- package/.scannerwork/scanner-report/measures-46.pb +0 -0
- package/.scannerwork/scanner-report/measures-47.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-50.pb +0 -0
- package/.scannerwork/scanner-report/measures-51.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-57.pb +0 -0
- package/.scannerwork/scanner-report/measures-58.pb +0 -0
- package/.scannerwork/scanner-report/measures-59.pb +0 -0
- package/.scannerwork/scanner-report/measures-6.pb +0 -0
- package/.scannerwork/scanner-report/measures-61.pb +0 -0
- package/.scannerwork/scanner-report/measures-65.pb +0 -0
- package/.scannerwork/scanner-report/measures-66.pb +0 -0
- package/.scannerwork/scanner-report/measures-69.pb +0 -0
- package/.scannerwork/scanner-report/measures-7.pb +0 -0
- package/.scannerwork/scanner-report/metadata.pb +0 -0
- package/.scannerwork/scanner-report/source-19.txt +106 -11
- package/.scannerwork/scanner-report/source-20.txt +16 -73
- package/.scannerwork/scanner-report/source-21.txt +269 -23
- package/.scannerwork/scanner-report/source-22.txt +86 -123
- package/.scannerwork/scanner-report/source-23.txt +73 -15
- package/.scannerwork/scanner-report/source-24.txt +603 -14
- package/.scannerwork/scanner-report/source-25.txt +11 -127
- package/.scannerwork/scanner-report/source-26.txt +36 -41
- package/.scannerwork/scanner-report/source-27.txt +15 -14
- package/.scannerwork/scanner-report/source-28.txt +127 -85
- package/.scannerwork/scanner-report/source-29.txt +325 -101
- package/.scannerwork/scanner-report/source-30.txt +17 -49
- package/.scannerwork/scanner-report/source-31.txt +60 -585
- package/.scannerwork/scanner-report/source-32.txt +114 -88
- package/.scannerwork/scanner-report/source-33.txt +136 -9
- package/.scannerwork/scanner-report/source-34.txt +43 -200
- package/.scannerwork/scanner-report/source-35.txt +125 -92
- package/.scannerwork/scanner-report/source-36.txt +225 -0
- package/.scannerwork/scanner-report/source-37.txt +114 -509
- package/.scannerwork/scanner-report/source-38.txt +50 -50
- package/.scannerwork/scanner-report/source-4.txt +14 -346
- package/.scannerwork/scanner-report/source-40.txt +165 -165
- package/.scannerwork/scanner-report/source-41.txt +31 -0
- package/.scannerwork/scanner-report/source-44.txt +178 -0
- package/.scannerwork/scanner-report/source-46.txt +54 -0
- package/.scannerwork/scanner-report/source-47.txt +41 -0
- package/.scannerwork/scanner-report/source-49.txt +108 -154
- package/.scannerwork/scanner-report/source-5.txt +215 -102
- package/.scannerwork/scanner-report/source-50.txt +234 -143
- package/.scannerwork/scanner-report/source-51.txt +80 -509
- package/.scannerwork/scanner-report/source-52.txt +111 -0
- package/.scannerwork/scanner-report/source-53.txt +20 -138
- package/.scannerwork/scanner-report/source-54.txt +138 -20
- package/.scannerwork/scanner-report/source-55.txt +509 -178
- package/.scannerwork/scanner-report/source-57.txt +58 -22
- package/.scannerwork/scanner-report/source-58.txt +38 -36
- package/.scannerwork/scanner-report/source-59.txt +509 -111
- package/.scannerwork/scanner-report/source-6.txt +41 -266
- package/.scannerwork/scanner-report/source-61.txt +509 -80
- package/.scannerwork/scanner-report/source-65.txt +173 -14
- package/.scannerwork/scanner-report/source-66.txt +133 -239
- package/.scannerwork/scanner-report/source-69.txt +401 -39
- package/.scannerwork/scanner-report/source-7.txt +47 -0
- package/.scannerwork/scanner-report/symbols-19.pb +95 -9
- package/.scannerwork/scanner-report/symbols-20.pb +17 -60
- package/.scannerwork/scanner-report/symbols-21.pb +486 -27
- package/.scannerwork/scanner-report/symbols-22.pb +75 -110
- package/.scannerwork/scanner-report/symbols-23.pb +60 -10
- package/.scannerwork/scanner-report/symbols-24.pb +1253 -13
- package/.scannerwork/scanner-report/symbols-25.pb +9 -102
- package/.scannerwork/scanner-report/symbols-26.pb +42 -35
- package/.scannerwork/scanner-report/symbols-27.pb +11 -17
- package/.scannerwork/scanner-report/symbols-28.pb +115 -68
- package/.scannerwork/scanner-report/symbols-29.pb +494 -116
- package/.scannerwork/scanner-report/symbols-30.pb +14 -45
- package/.scannerwork/scanner-report/symbols-31.pb +68 -1253
- package/.scannerwork/scanner-report/symbols-32.pb +102 -77
- package/.scannerwork/scanner-report/symbols-33.pb +112 -9
- package/.scannerwork/scanner-report/symbols-34.pb +35 -417
- package/.scannerwork/scanner-report/symbols-35.pb +85 -28
- package/.scannerwork/scanner-report/symbols-36.pb +418 -0
- package/.scannerwork/scanner-report/symbols-37.pb +28 -0
- package/.scannerwork/scanner-report/symbols-4.pb +10 -494
- package/.scannerwork/scanner-report/symbols-41.pb +14 -0
- package/.scannerwork/scanner-report/symbols-46.pb +15 -0
- package/.scannerwork/scanner-report/symbols-47.pb +18 -0
- package/.scannerwork/scanner-report/symbols-49.pb +33 -153
- package/.scannerwork/scanner-report/symbols-5.pb +394 -97
- package/.scannerwork/scanner-report/symbols-50.pb +352 -178
- package/.scannerwork/scanner-report/symbols-53.pb +20 -126
- package/.scannerwork/scanner-report/symbols-54.pb +126 -20
- package/.scannerwork/scanner-report/symbols-57.pb +29 -17
- package/.scannerwork/scanner-report/symbols-58.pb +18 -14
- package/.scannerwork/scanner-report/symbols-6.pb +44 -485
- package/.scannerwork/scanner-report/symbols-65.pb +180 -14
- package/.scannerwork/scanner-report/symbols-66.pb +146 -347
- package/.scannerwork/scanner-report/symbols-69.pb +610 -19
- package/.scannerwork/scanner-report/symbols-7.pb +27 -0
- package/.scannerwork/scanner-report/syntax-highlightings-19.pb +142 -19
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +27 -74
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +619 -28
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +118 -183
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +74 -14
- package/.scannerwork/scanner-report/syntax-highlightings-24.pb +854 -21
- package/.scannerwork/scanner-report/syntax-highlightings-25.pb +15 -194
- package/.scannerwork/scanner-report/syntax-highlightings-26.pb +43 -56
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +23 -27
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +100 -71
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +587 -91
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +21 -77
- package/.scannerwork/scanner-report/syntax-highlightings-31.pb +64 -846
- package/.scannerwork/scanner-report/syntax-highlightings-32.pb +187 -118
- package/.scannerwork/scanner-report/syntax-highlightings-33.pb +189 -14
- package/.scannerwork/scanner-report/syntax-highlightings-34.pb +58 -294
- package/.scannerwork/scanner-report/syntax-highlightings-35.pb +156 -103
- package/.scannerwork/scanner-report/syntax-highlightings-36.pb +331 -0
- package/.scannerwork/scanner-report/syntax-highlightings-37.pb +127 -3737
- package/.scannerwork/scanner-report/syntax-highlightings-38.pb +21 -22
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +14 -594
- package/.scannerwork/scanner-report/syntax-highlightings-40.pb +100 -98
- package/.scannerwork/scanner-report/syntax-highlightings-41.pb +45 -0
- package/.scannerwork/scanner-report/syntax-highlightings-44.pb +243 -0
- package/.scannerwork/scanner-report/syntax-highlightings-46.pb +54 -0
- package/.scannerwork/scanner-report/syntax-highlightings-47.pb +50 -0
- package/.scannerwork/scanner-report/syntax-highlightings-49.pb +98 -183
- package/.scannerwork/scanner-report/syntax-highlightings-5.pb +294 -147
- package/.scannerwork/scanner-report/syntax-highlightings-50.pb +224 -164
- package/.scannerwork/scanner-report/syntax-highlightings-51.pb +84 -3738
- package/.scannerwork/scanner-report/syntax-highlightings-52.pb +133 -0
- package/.scannerwork/scanner-report/syntax-highlightings-53.pb +29 -178
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +178 -29
- package/.scannerwork/scanner-report/syntax-highlightings-55.pb +3712 -209
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +84 -31
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +63 -35
- package/.scannerwork/scanner-report/syntax-highlightings-59.pb +3736 -122
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +66 -615
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +3737 -84
- package/.scannerwork/scanner-report/syntax-highlightings-65.pb +195 -15
- package/.scannerwork/scanner-report/syntax-highlightings-66.pb +155 -226
- package/.scannerwork/scanner-report/syntax-highlightings-69.pb +624 -58
- package/.scannerwork/scanner-report/syntax-highlightings-7.pb +68 -0
- package/CHANGES.md +3 -0
- package/package.json +1 -1
- package/test-14-results.xml +165 -165
- package/test-16-results.xml +153 -153
- package/test-18-results.xml +146 -146
- package/test-19-results.xml +153 -153
- package/test-iam-18-results.xml +50 -50
- package/.scannerwork/scanner-report/changesets-18.pb +0 -1
- package/.scannerwork/scanner-report/changesets-2.pb +0 -1
- package/.scannerwork/scanner-report/changesets-3.pb +0 -1
- package/.scannerwork/scanner-report/changesets-55.pb +0 -1
- package/.scannerwork/scanner-report/changesets-56.pb +0 -1
- package/.scannerwork/scanner-report/changesets-59.pb +0 -1
- package/.scannerwork/scanner-report/changesets-60.pb +0 -1
- package/.scannerwork/scanner-report/changesets-61.pb +0 -1
- package/.scannerwork/scanner-report/changesets-62.pb +0 -1
- package/.scannerwork/scanner-report/changesets-63.pb +0 -1
- package/.scannerwork/scanner-report/changesets-64.pb +0 -1
- package/.scannerwork/scanner-report/changesets-68.pb +0 -1
- package/.scannerwork/scanner-report/changesets-70.pb +0 -1
- package/.scannerwork/scanner-report/component-18.pb +0 -1
- package/.scannerwork/scanner-report/component-2.pb +0 -1
- package/.scannerwork/scanner-report/component-3.pb +0 -1
- package/.scannerwork/scanner-report/component-56.pb +0 -1
- package/.scannerwork/scanner-report/component-60.pb +0 -1
- package/.scannerwork/scanner-report/component-62.pb +0 -1
- package/.scannerwork/scanner-report/component-63.pb +0 -1
- package/.scannerwork/scanner-report/component-64.pb +0 -1
- package/.scannerwork/scanner-report/component-67.pb +0 -1
- package/.scannerwork/scanner-report/component-68.pb +0 -1
- package/.scannerwork/scanner-report/component-70.pb +0 -1
- package/.scannerwork/scanner-report/coverages-18.pb +0 -0
- package/.scannerwork/scanner-report/coverages-2.pb +0 -0
- package/.scannerwork/scanner-report/coverages-3.pb +0 -0
- package/.scannerwork/scanner-report/coverages-56.pb +0 -0
- package/.scannerwork/scanner-report/coverages-68.pb +0 -0
- package/.scannerwork/scanner-report/coverages-70.pb +0 -0
- package/.scannerwork/scanner-report/duplications-25.pb +0 -2
- package/.scannerwork/scanner-report/duplications-3.pb +0 -3
- package/.scannerwork/scanner-report/duplications-60.pb +0 -2
- package/.scannerwork/scanner-report/duplications-62.pb +0 -2
- package/.scannerwork/scanner-report/issues-4.pb +0 -6
- package/.scannerwork/scanner-report/measures-18.pb +0 -0
- package/.scannerwork/scanner-report/measures-2.pb +0 -0
- package/.scannerwork/scanner-report/measures-3.pb +0 -0
- package/.scannerwork/scanner-report/measures-56.pb +0 -0
- package/.scannerwork/scanner-report/measures-67.pb +0 -0
- package/.scannerwork/scanner-report/measures-68.pb +0 -0
- package/.scannerwork/scanner-report/measures-70.pb +0 -0
- package/.scannerwork/scanner-report/source-18.txt +0 -63
- package/.scannerwork/scanner-report/source-2.txt +0 -147
- package/.scannerwork/scanner-report/source-3.txt +0 -244
- package/.scannerwork/scanner-report/source-56.txt +0 -129
- package/.scannerwork/scanner-report/source-67.txt +0 -509
- package/.scannerwork/scanner-report/source-68.txt +0 -77
- package/.scannerwork/scanner-report/source-70.txt +0 -418
- package/.scannerwork/scanner-report/symbols-18.pb +0 -43
- package/.scannerwork/scanner-report/symbols-2.pb +0 -85
- package/.scannerwork/scanner-report/symbols-3.pb +0 -394
- package/.scannerwork/scanner-report/symbols-56.pb +0 -33
- package/.scannerwork/scanner-report/symbols-68.pb +0 -30
- package/.scannerwork/scanner-report/symbols-70.pb +0 -610
- package/.scannerwork/scanner-report/syntax-highlightings-18.pb +0 -82
- package/.scannerwork/scanner-report/syntax-highlightings-2.pb +0 -191
- package/.scannerwork/scanner-report/syntax-highlightings-3.pb +0 -329
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +0 -129
- package/.scannerwork/scanner-report/syntax-highlightings-67.pb +0 -3747
- package/.scannerwork/scanner-report/syntax-highlightings-68.pb +0 -103
- package/.scannerwork/scanner-report/syntax-highlightings-70.pb +0 -648
- /package/.scannerwork/scanner-report/{coverages-63.pb → coverages-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-60.pb → coverages-43.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-55.pb → coverages-44.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-62.pb → coverages-45.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-64.pb → coverages-48.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-61.pb → coverages-51.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-59.pb → coverages-52.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-18.pb → duplications-33.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-2.pb → duplications-37.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-55.pb → duplications-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-56.pb → duplications-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-59.pb → duplications-44.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-61.pb → duplications-46.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-63.pb → duplications-47.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-64.pb → duplications-48.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-68.pb → duplications-51.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-70.pb → duplications-52.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-3.pb → issues-5.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-21.pb → issues-7.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-63.pb → measures-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-60.pb → measures-43.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-62.pb → measures-45.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-64.pb → measures-48.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-63.txt → source-42.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-60.txt → source-43.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-62.txt → source-45.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-64.txt → source-48.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-63.pb → symbols-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-60.pb → symbols-43.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-55.pb → symbols-44.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-62.pb → symbols-45.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-64.pb → symbols-48.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-61.pb → symbols-51.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-59.pb → symbols-52.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-63.pb → syntax-highlightings-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-60.pb → syntax-highlightings-43.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-62.pb → syntax-highlightings-45.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-64.pb → syntax-highlightings-48.pb} +0 -0
|
@@ -11,21 +11,180 @@
|
|
|
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, using an intermediary file on disk.
|
|
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
|
+
|
|
14
21
|
'use strict';
|
|
15
22
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
23
|
+
const stream = require('stream');
|
|
24
|
+
const fs = require('fs');
|
|
25
|
+
const url = require('url');
|
|
26
|
+
|
|
27
|
+
const AWS = require('aws-sdk');
|
|
28
|
+
const couchbackup = require('@cloudant/couchbackup');
|
|
29
|
+
const debug = require('debug')('s3-backup');
|
|
30
|
+
const tmp = require('tmp');
|
|
31
|
+
const VError = require('verror').VError;
|
|
32
|
+
|
|
33
|
+
/*
|
|
34
|
+
Main function, run from base of file.
|
|
35
|
+
*/
|
|
36
|
+
function main() {
|
|
37
|
+
const argv = require('yargs')
|
|
38
|
+
.usage('Usage: $0 [options]')
|
|
39
|
+
.example('$0 -s https://user:pass@host/db -b <bucket>', 'Backup db to bucket')
|
|
40
|
+
.options({
|
|
41
|
+
source: { alias: 's', nargs: 1, demandOption: true, describe: 'Source database URL' },
|
|
42
|
+
bucket: { alias: 'b', nargs: 1, demandOption: true, describe: 'Destination bucket' },
|
|
43
|
+
prefix: { alias: 'p', nargs: 1, describe: 'Prefix for backup object key', default: 'couchbackup' },
|
|
44
|
+
s3url: { nargs: 1, describe: 'S3 endpoint URL' },
|
|
45
|
+
awsprofile: { nargs: 1, describe: 'The profile section to use in the ~/.aws/credentials file', default: 'default' }
|
|
46
|
+
})
|
|
47
|
+
.help('h').alias('h', 'help')
|
|
48
|
+
.epilog('Copyright (C) IBM 2017')
|
|
49
|
+
.argv;
|
|
50
|
+
|
|
51
|
+
const sourceUrl = argv.source;
|
|
52
|
+
const backupBucket = argv.bucket;
|
|
53
|
+
const backupName = new url.URL(sourceUrl).pathname.split('/').filter(function(x) { return x; }).join('-');
|
|
54
|
+
const backupKeyPrefix = `${argv.prefix}-${backupName}`;
|
|
55
|
+
|
|
56
|
+
const backupKey = `${backupKeyPrefix}-${new Date().toISOString()}`;
|
|
57
|
+
const backupTmpFile = tmp.fileSync();
|
|
58
|
+
|
|
59
|
+
const s3Endpoint = argv.s3url;
|
|
60
|
+
const awsProfile = argv.awsprofile;
|
|
61
|
+
|
|
62
|
+
// Creds are from ~/.aws/credentials, environment etc. (see S3 docs).
|
|
63
|
+
const awsOpts = {
|
|
64
|
+
signatureVersion: 'v4',
|
|
65
|
+
credentials: new AWS.SharedIniFileCredentials({ profile: awsProfile })
|
|
66
|
+
};
|
|
67
|
+
if (typeof s3Endpoint !== 'undefined') {
|
|
68
|
+
awsOpts.endpoint = new AWS.Endpoint(s3Endpoint);
|
|
69
|
+
}
|
|
70
|
+
const s3 = new AWS.S3(awsOpts);
|
|
71
|
+
|
|
72
|
+
debug(`Creating a new backup of ${s(sourceUrl)} at ${backupBucket}/${backupKey}...`);
|
|
73
|
+
bucketAccessible(s3, backupBucket)
|
|
74
|
+
.then(() => {
|
|
75
|
+
return createBackupFile(sourceUrl, backupTmpFile.name);
|
|
27
76
|
})
|
|
28
|
-
.
|
|
77
|
+
.then(() => {
|
|
78
|
+
return uploadNewBackup(s3, backupTmpFile.name, backupBucket, backupKey);
|
|
79
|
+
})
|
|
80
|
+
.then(() => {
|
|
81
|
+
debug('Backup successful!');
|
|
82
|
+
backupTmpFile.removeCallback();
|
|
83
|
+
debug('done.');
|
|
84
|
+
})
|
|
85
|
+
.catch((reason) => {
|
|
86
|
+
debug(`Error: ${reason}`);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* Return a promise that resolves if the bucket is available and
|
|
92
|
+
* rejects if not.
|
|
93
|
+
*
|
|
94
|
+
* @param {any} s3 S3 client object
|
|
95
|
+
* @param {any} bucketName Bucket name
|
|
96
|
+
* @returns Promise
|
|
97
|
+
*/
|
|
98
|
+
function bucketAccessible(s3, bucketName) {
|
|
99
|
+
return new Promise(function(resolve, reject) {
|
|
100
|
+
const params = {
|
|
101
|
+
Bucket: bucketName
|
|
102
|
+
};
|
|
103
|
+
s3.headBucket(params, function(err, data) {
|
|
104
|
+
if (err) {
|
|
105
|
+
reject(new VError(err, 'S3 bucket not accessible'));
|
|
106
|
+
} else {
|
|
107
|
+
resolve();
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Use couchbackup to create a backup of the specified database to a file path.
|
|
115
|
+
*
|
|
116
|
+
* @param {any} sourceUrl Database URL
|
|
117
|
+
* @param {any} backupTmpFilePath Path to write file
|
|
118
|
+
* @returns Promise
|
|
119
|
+
*/
|
|
120
|
+
function createBackupFile(sourceUrl, backupTmpFilePath) {
|
|
121
|
+
return new Promise((resolve, reject) => {
|
|
122
|
+
couchbackup.backup(
|
|
123
|
+
sourceUrl,
|
|
124
|
+
fs.createWriteStream(backupTmpFilePath),
|
|
125
|
+
(err) => {
|
|
126
|
+
if (err) {
|
|
127
|
+
return reject(new VError(err, 'CouchBackup process failed'));
|
|
128
|
+
}
|
|
129
|
+
debug('couchbackup to file done; uploading to S3');
|
|
130
|
+
resolve('creating backup file complete');
|
|
131
|
+
}
|
|
132
|
+
);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Upload a backup file to an S3 bucket.
|
|
138
|
+
*
|
|
139
|
+
* @param {any} s3 Object store client
|
|
140
|
+
* @param {any} backupTmpFilePath Path of backup file to write.
|
|
141
|
+
* @param {any} bucket Object store bucket name
|
|
142
|
+
* @param {any} key Object store key name
|
|
143
|
+
* @returns Promise
|
|
144
|
+
*/
|
|
145
|
+
function uploadNewBackup(s3, backupTmpFilePath, bucket, key) {
|
|
146
|
+
return new Promise((resolve, reject) => {
|
|
147
|
+
debug(`Uploading from ${backupTmpFilePath} to ${bucket}/${key}`);
|
|
148
|
+
|
|
149
|
+
function uploadFromStream(s3, bucket, key) {
|
|
150
|
+
const pass = new stream.PassThrough();
|
|
151
|
+
|
|
152
|
+
const params = {
|
|
153
|
+
Bucket: bucket,
|
|
154
|
+
Key: key,
|
|
155
|
+
Body: pass
|
|
156
|
+
};
|
|
157
|
+
s3.upload(params, function(err, data) {
|
|
158
|
+
debug('S3 upload done');
|
|
159
|
+
if (err) {
|
|
160
|
+
debug(err);
|
|
161
|
+
reject(new VError(err, 'Upload failed'));
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
debug('Upload succeeded');
|
|
165
|
+
debug(data);
|
|
166
|
+
resolve();
|
|
167
|
+
}).httpUploadProgress = (progress) => {
|
|
168
|
+
debug(`S3 upload progress: ${progress}`);
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
return pass;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
const inputStream = fs.createReadStream(backupTmpFilePath);
|
|
175
|
+
const s3Stream = uploadFromStream(s3, bucket, key);
|
|
176
|
+
inputStream.pipe(s3Stream);
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* Remove creds from a URL, e.g., before logging
|
|
182
|
+
*
|
|
183
|
+
* @param {string} url URL to safen
|
|
184
|
+
*/
|
|
185
|
+
function s(originalUrl) {
|
|
186
|
+
const parts = new url.URL(originalUrl);
|
|
187
|
+
return url.format(parts, { auth: false });
|
|
188
|
+
}
|
|
29
189
|
|
|
30
|
-
|
|
31
|
-
};
|
|
190
|
+
main();
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright © 2017,
|
|
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.
|
|
@@ -11,271 +11,165 @@
|
|
|
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
14
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
const logfilesummary = require('./logfilesummary.js');
|
|
22
|
-
const logfilegetbatches = require('./logfilegetbatches.js');
|
|
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.
|
|
23
20
|
|
|
24
|
-
|
|
25
|
-
* Read documents from a database to be backed up.
|
|
26
|
-
*
|
|
27
|
-
* @param {string} db - `@cloudant/cloudant` DB object for source database.
|
|
28
|
-
* @param {number} blocksize - number of documents to download in single request
|
|
29
|
-
* @param {number} parallelism - number of concurrent downloads
|
|
30
|
-
* @param {string} log - path to log file to use
|
|
31
|
-
* @param {boolean} resume - whether to resume from an existing log file
|
|
32
|
-
* @returns EventEmitter with following events:
|
|
33
|
-
* - `received` - called with a block of documents to write to backup
|
|
34
|
-
* - `error` - on error
|
|
35
|
-
* - `finished` - when backup process is finished (either complete or errored)
|
|
36
|
-
*/
|
|
37
|
-
module.exports = function(db, options) {
|
|
38
|
-
const ee = new events.EventEmitter();
|
|
39
|
-
const start = new Date().getTime(); // backup start time
|
|
40
|
-
const batchesPerDownloadSession = 50; // max batches to read from log file for download at a time (prevent OOM)
|
|
21
|
+
'use strict';
|
|
41
22
|
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
23
|
+
const stream = require('stream');
|
|
24
|
+
const url = require('url');
|
|
25
|
+
|
|
26
|
+
const AWS = require('aws-sdk');
|
|
27
|
+
const couchbackup = require('@cloudant/couchbackup');
|
|
28
|
+
const debug = require('debug')('s3-backup');
|
|
29
|
+
const VError = require('verror').VError;
|
|
30
|
+
|
|
31
|
+
/*
|
|
32
|
+
Main function, run from base of file.
|
|
33
|
+
*/
|
|
34
|
+
function main() {
|
|
35
|
+
const argv = require('yargs')
|
|
36
|
+
.usage('Usage: $0 [options]')
|
|
37
|
+
.example('$0 -s https://user:pass@host/db -b <bucket>', 'Backup db to bucket')
|
|
38
|
+
.options({
|
|
39
|
+
source: { alias: 's', nargs: 1, demandOption: true, describe: 'Source database URL' },
|
|
40
|
+
bucket: { alias: 'b', nargs: 1, demandOption: true, describe: 'Destination bucket' },
|
|
41
|
+
prefix: { alias: 'p', nargs: 1, describe: 'Prefix for backup object key', default: 'couchbackup' },
|
|
42
|
+
s3url: { nargs: 1, describe: 'S3 endpoint URL' },
|
|
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;
|
|
48
|
+
|
|
49
|
+
const sourceUrl = argv.source;
|
|
50
|
+
const backupName = new url.URL(sourceUrl).pathname.split('/').filter(function(x) { return x; }).join('-');
|
|
51
|
+
const backupBucket = argv.bucket;
|
|
52
|
+
const backupKeyPrefix = `${argv.prefix}-${backupName}`;
|
|
53
|
+
const shallow = argv.shallow;
|
|
54
|
+
|
|
55
|
+
const backupKey = `${backupKeyPrefix}-${new Date().toISOString()}`;
|
|
56
|
+
|
|
57
|
+
const s3Endpoint = argv.s3url;
|
|
58
|
+
const awsProfile = argv.awsprofile;
|
|
59
|
+
|
|
60
|
+
// Creds are from ~/.aws/credentials, environment etc. (see S3 docs).
|
|
61
|
+
const awsOpts = {
|
|
62
|
+
signatureVersion: 'v4',
|
|
63
|
+
credentials: new AWS.SharedIniFileCredentials({ profile: awsProfile })
|
|
64
|
+
};
|
|
65
|
+
if (typeof s3Endpoint !== 'undefined') {
|
|
66
|
+
awsOpts.endpoint = new AWS.Endpoint(s3Endpoint);
|
|
56
67
|
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
* Validate /_bulk_get support for a specified database.
|
|
71
|
-
*
|
|
72
|
-
* @param {string} db - nodejs-cloudant db
|
|
73
|
-
* @param {function} callback - called on completion with signature (err)
|
|
74
|
-
*/
|
|
75
|
-
function validateBulkGetSupport(db, callback) {
|
|
76
|
-
db.service.postBulkGet({ db: db.db, docs: [] }).then(() => { callback(); }).catch(err => {
|
|
77
|
-
err = error.convertResponseError(err, function(err) {
|
|
78
|
-
switch (err.status) {
|
|
79
|
-
case undefined:
|
|
80
|
-
// There was no status code on the error
|
|
81
|
-
return err;
|
|
82
|
-
case 404:
|
|
83
|
-
return new error.BackupError('BulkGetError', 'Database does not support /_bulk_get endpoint');
|
|
84
|
-
default:
|
|
85
|
-
return new error.HTTPError(err);
|
|
86
|
-
}
|
|
68
|
+
const s3 = new AWS.S3(awsOpts);
|
|
69
|
+
|
|
70
|
+
debug(`Creating a new backup of ${s(sourceUrl)} at ${backupBucket}/${backupKey}...`);
|
|
71
|
+
bucketAccessible(s3, backupBucket)
|
|
72
|
+
.then(() => {
|
|
73
|
+
return backupToS3(sourceUrl, s3, backupBucket, backupKey, shallow);
|
|
74
|
+
})
|
|
75
|
+
.then(() => {
|
|
76
|
+
debug('done.');
|
|
77
|
+
})
|
|
78
|
+
.catch((reason) => {
|
|
79
|
+
debug(`Error: ${reason}`);
|
|
80
|
+
process.exit(1);
|
|
87
81
|
});
|
|
88
|
-
callback(err);
|
|
89
|
-
});
|
|
90
82
|
}
|
|
91
83
|
|
|
92
84
|
/**
|
|
93
|
-
*
|
|
94
|
-
*
|
|
85
|
+
* Return a promise that resolves if the bucket is available and
|
|
86
|
+
* rejects if not.
|
|
95
87
|
*
|
|
96
|
-
* @param {
|
|
97
|
-
* @param {
|
|
98
|
-
* @
|
|
99
|
-
* @param {time} startTime - start time for backup process
|
|
100
|
-
* @param {number} batchesPerDownloadSession - max batches to enqueue for
|
|
101
|
-
* download at a time. As batches contain many doc IDs, this helps avoid
|
|
102
|
-
* exhausting memory.
|
|
103
|
-
* @param {number} parallelism - number of concurrent downloads
|
|
104
|
-
* @returns function to call do download remaining batches with signature
|
|
105
|
-
* (err, {batches: batch, docs: doccount}) {@see spoolchanges}.
|
|
88
|
+
* @param {any} s3 S3 client object
|
|
89
|
+
* @param {any} bucketName Bucket name
|
|
90
|
+
* @returns Promise
|
|
106
91
|
*/
|
|
107
|
-
function
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
function downloadSingleBatchSet(done) {
|
|
114
|
-
// Fetch the doc IDs for the batches in the current set to
|
|
115
|
-
// download them.
|
|
116
|
-
function batchSetComplete(err, data) {
|
|
117
|
-
if (!err) {
|
|
118
|
-
total = data.total;
|
|
119
|
-
}
|
|
120
|
-
done(err);
|
|
121
|
-
}
|
|
122
|
-
function processRetrievedBatches(err, batches) {
|
|
123
|
-
if (!err) {
|
|
124
|
-
// process them in parallelised queue
|
|
125
|
-
processBatchSet(db, parallelism, log, batches, ee, startTime, total, batchSetComplete);
|
|
126
|
-
} else {
|
|
127
|
-
batchSetComplete(err);
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
readBatchSetIdsFromLogFile(log, batchesPerDownloadSession, function(err, batchSetIds) {
|
|
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) {
|
|
132
98
|
if (err) {
|
|
133
|
-
|
|
134
|
-
// Stop processing changes file for fatal errors
|
|
135
|
-
noRemainingBatches = true;
|
|
136
|
-
done();
|
|
99
|
+
reject(new VError(err, 'S3 bucket not accessible'));
|
|
137
100
|
} else {
|
|
138
|
-
|
|
139
|
-
noRemainingBatches = true;
|
|
140
|
-
return done();
|
|
141
|
-
}
|
|
142
|
-
logfilegetbatches(log, batchSetIds, processRetrievedBatches);
|
|
101
|
+
resolve();
|
|
143
102
|
}
|
|
144
103
|
});
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
// Return true if all batches in log file have been downloaded
|
|
148
|
-
function isFinished(callback) { callback(null, noRemainingBatches); }
|
|
149
|
-
|
|
150
|
-
function onComplete() {
|
|
151
|
-
ee.emit('finished', { total: total });
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
async.doUntil(downloadSingleBatchSet, isFinished, onComplete);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
/**
|
|
158
|
-
* Return a set of uncompleted download batch IDs from the log file.
|
|
159
|
-
*
|
|
160
|
-
* @param {string} log - log file path
|
|
161
|
-
* @param {number} batchesPerDownloadSession - maximum IDs to return
|
|
162
|
-
* @param {function} callback - sign (err, batchSetIds array)
|
|
163
|
-
*/
|
|
164
|
-
function readBatchSetIdsFromLogFile(log, batchesPerDownloadSession, callback) {
|
|
165
|
-
logfilesummary(log, function processSummary(err, summary) {
|
|
166
|
-
if (!err) {
|
|
167
|
-
if (!summary.changesComplete) {
|
|
168
|
-
callback(new error.BackupError('IncompleteChangesInLogFile',
|
|
169
|
-
'WARNING: Changes did not finish spooling'));
|
|
170
|
-
return;
|
|
171
|
-
}
|
|
172
|
-
if (Object.keys(summary.batches).length === 0) {
|
|
173
|
-
return callback(null, []);
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
// batch IDs are the property names of summary.batches
|
|
177
|
-
const batchSetIds = getPropertyNames(summary.batches, batchesPerDownloadSession);
|
|
178
|
-
callback(null, batchSetIds);
|
|
179
|
-
} else {
|
|
180
|
-
callback(err);
|
|
181
|
-
}
|
|
182
104
|
});
|
|
183
105
|
}
|
|
184
106
|
|
|
185
107
|
/**
|
|
186
|
-
*
|
|
187
|
-
* complete, add a line to the logfile indicating such.
|
|
108
|
+
* Backup directly from Cloudant to an object store object via a stream.
|
|
188
109
|
*
|
|
189
|
-
* @param {any}
|
|
190
|
-
* @param {any}
|
|
191
|
-
* @param {any}
|
|
192
|
-
* @param {any}
|
|
193
|
-
* @param {any}
|
|
194
|
-
*
|
|
195
|
-
* @param {any} start - time backup started, to report deltas
|
|
196
|
-
* @param {any} grandtotal - count of documents downloaded prior to this set
|
|
197
|
-
* of batches
|
|
198
|
-
* @param {any} callback - completion callback, (err, {total: number}).
|
|
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
|
|
199
116
|
*/
|
|
200
|
-
function
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
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;
|
|
216
139
|
}
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
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;
|
|
233
156
|
}
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
ee.emit('received', {
|
|
238
|
-
batch: thisBatch,
|
|
239
|
-
data: output,
|
|
240
|
-
length: output.length,
|
|
241
|
-
time: t,
|
|
242
|
-
total: total
|
|
243
|
-
}, q, logCompletedBatch);
|
|
244
|
-
}).catch(err => {
|
|
245
|
-
if (!hasErrored) {
|
|
246
|
-
hasErrored = true;
|
|
247
|
-
err = error.convertResponseError(err);
|
|
248
|
-
// Kill the queue for fatal errors
|
|
249
|
-
q.kill();
|
|
250
|
-
ee.emit('error', err);
|
|
157
|
+
debug(`Download from ${s(sourceUrl)} complete.`);
|
|
158
|
+
streamToUpload.end(); // must call end() to complete upload.
|
|
159
|
+
// resolve() is called by the upload
|
|
251
160
|
}
|
|
252
|
-
|
|
253
|
-
});
|
|
254
|
-
}, parallelism);
|
|
255
|
-
|
|
256
|
-
for (const i in batches) {
|
|
257
|
-
q.push(batches[i]);
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
q.drain(function() {
|
|
261
|
-
callback(null, { total: total });
|
|
161
|
+
);
|
|
262
162
|
});
|
|
263
163
|
}
|
|
264
164
|
|
|
265
165
|
/**
|
|
266
|
-
*
|
|
166
|
+
* Remove creds from a URL, e.g., before logging
|
|
267
167
|
*
|
|
268
|
-
* @param {
|
|
269
|
-
* @param {number} count - number of properties to return
|
|
168
|
+
* @param {string} url URL to safen
|
|
270
169
|
*/
|
|
271
|
-
function
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
let j = 0;
|
|
275
|
-
for (const i in obj) {
|
|
276
|
-
batchestofetch.push(parseInt(i));
|
|
277
|
-
j++;
|
|
278
|
-
if (j >= count) break;
|
|
279
|
-
}
|
|
280
|
-
return batchestofetch;
|
|
170
|
+
function s(originalUrl) {
|
|
171
|
+
const parts = new url.URL(originalUrl);
|
|
172
|
+
return url.format(parts, { auth: false });
|
|
281
173
|
}
|
|
174
|
+
|
|
175
|
+
main();
|