@cloudant/couchbackup 2.9.15 → 2.9.16-SNAPSHOT.179
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-cache2.pb +0 -0
- package/.scannerwork/scanner-report/analysis-warnings.pb +2 -2
- package/.scannerwork/scanner-report/changesets-10.pb +2 -0
- package/.scannerwork/scanner-report/changesets-11.pb +1 -0
- package/.scannerwork/scanner-report/changesets-13.pb +1 -0
- package/.scannerwork/scanner-report/changesets-15.pb +1 -0
- package/.scannerwork/scanner-report/changesets-3.pb +1 -0
- package/.scannerwork/scanner-report/changesets-4.pb +1 -0
- package/.scannerwork/scanner-report/changesets-40.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-5.pb +1 -0
- package/.scannerwork/scanner-report/changesets-6.pb +1 -0
- package/.scannerwork/scanner-report/changesets-7.pb +1 -0
- package/.scannerwork/scanner-report/changesets-70.pb +1 -0
- package/.scannerwork/scanner-report/changesets-8.pb +1 -0
- package/.scannerwork/scanner-report/changesets-9.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 -0
- package/.scannerwork/scanner-report/component-12.pb +1 -1
- package/.scannerwork/scanner-report/component-13.pb +1 -0
- package/.scannerwork/scanner-report/component-14.pb +1 -1
- package/.scannerwork/scanner-report/component-15.pb +1 -0
- package/.scannerwork/scanner-report/component-16.pb +1 -1
- package/.scannerwork/scanner-report/component-18.pb +1 -1
- package/.scannerwork/scanner-report/component-19.pb +1 -1
- package/.scannerwork/scanner-report/component-2.pb +1 -0
- package/.scannerwork/scanner-report/component-24.pb +1 -1
- package/.scannerwork/scanner-report/component-27.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-34.pb +1 -1
- package/.scannerwork/scanner-report/component-36.pb +1 -1
- package/.scannerwork/scanner-report/component-37.pb +1 -1
- package/.scannerwork/scanner-report/component-38.pb +1 -1
- package/.scannerwork/scanner-report/component-39.pb +1 -1
- package/.scannerwork/scanner-report/component-4.pb +1 -0
- package/.scannerwork/scanner-report/component-40.pb +1 -0
- 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-5.pb +1 -0
- package/.scannerwork/scanner-report/component-56.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-60.pb +1 -1
- package/.scannerwork/scanner-report/component-61.pb +1 -1
- package/.scannerwork/scanner-report/component-62.pb +1 -1
- package/.scannerwork/scanner-report/component-63.pb +1 -1
- package/.scannerwork/scanner-report/component-64.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-67.pb +1 -1
- package/.scannerwork/scanner-report/component-68.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/component-70.pb +1 -1
- package/.scannerwork/scanner-report/component-8.pb +1 -0
- package/.scannerwork/scanner-report/component-9.pb +1 -0
- package/.scannerwork/scanner-report/coverages-10.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-15.pb +0 -0
- package/.scannerwork/scanner-report/coverages-16.pb +0 -0
- package/.scannerwork/scanner-report/coverages-18.pb +0 -0
- package/.scannerwork/scanner-report/coverages-19.pb +0 -0
- package/.scannerwork/scanner-report/coverages-24.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-36.pb +0 -0
- package/.scannerwork/scanner-report/coverages-37.pb +0 -0
- package/.scannerwork/scanner-report/coverages-38.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-40.pb +0 -0
- package/.scannerwork/scanner-report/coverages-43.pb +0 -0
- package/.scannerwork/scanner-report/coverages-44.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-62.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-66.pb +0 -0
- package/.scannerwork/scanner-report/coverages-67.pb +0 -0
- package/.scannerwork/scanner-report/coverages-68.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/coverages-70.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-10.pb +2 -0
- package/.scannerwork/scanner-report/duplications-12.pb +0 -2
- package/.scannerwork/scanner-report/duplications-13.pb +3 -0
- package/.scannerwork/scanner-report/duplications-14.pb +0 -2
- package/.scannerwork/scanner-report/duplications-18.pb +2 -0
- package/.scannerwork/scanner-report/duplications-19.pb +2 -0
- package/.scannerwork/scanner-report/duplications-39.pb +0 -2
- package/.scannerwork/scanner-report/duplications-43.pb +2 -0
- package/.scannerwork/scanner-report/duplications-56.pb +0 -2
- package/.scannerwork/scanner-report/duplications-60.pb +3 -0
- package/.scannerwork/scanner-report/duplications-66.pb +0 -2
- package/.scannerwork/scanner-report/measures-10.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-15.pb +0 -0
- package/.scannerwork/scanner-report/measures-16.pb +0 -0
- package/.scannerwork/scanner-report/measures-18.pb +0 -0
- package/.scannerwork/scanner-report/measures-19.pb +0 -0
- package/.scannerwork/scanner-report/measures-2.pb +0 -0
- package/.scannerwork/scanner-report/measures-24.pb +0 -0
- package/.scannerwork/scanner-report/measures-27.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-34.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-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-40.pb +0 -0
- package/.scannerwork/scanner-report/measures-43.pb +0 -0
- package/.scannerwork/scanner-report/measures-44.pb +15 -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 +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-60.pb +0 -0
- package/.scannerwork/scanner-report/measures-61.pb +0 -0
- package/.scannerwork/scanner-report/measures-62.pb +0 -0
- package/.scannerwork/scanner-report/measures-63.pb +0 -0
- package/.scannerwork/scanner-report/measures-64.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-67.pb +0 -0
- package/.scannerwork/scanner-report/measures-68.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/measures-70.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 +92 -424
- package/.scannerwork/scanner-report/source-12.txt +150 -162
- package/.scannerwork/scanner-report/source-13.txt +75 -0
- package/.scannerwork/scanner-report/source-14.txt +88 -150
- package/.scannerwork/scanner-report/source-15.txt +281 -0
- package/.scannerwork/scanner-report/source-16.txt +21 -26
- package/.scannerwork/scanner-report/source-18.txt +154 -113
- package/.scannerwork/scanner-report/source-19.txt +170 -17
- package/.scannerwork/scanner-report/source-2.txt +424 -0
- package/.scannerwork/scanner-report/source-24.txt +397 -15
- package/.scannerwork/scanner-report/source-27.txt +102 -100
- package/.scannerwork/scanner-report/source-29.txt +424 -42
- package/.scannerwork/scanner-report/source-3.txt +46 -424
- package/.scannerwork/scanner-report/source-30.txt +65 -13
- package/.scannerwork/scanner-report/source-31.txt +43 -20
- package/.scannerwork/scanner-report/source-34.txt +424 -106
- package/.scannerwork/scanner-report/source-36.txt +40 -129
- package/.scannerwork/scanner-report/source-37.txt +101 -158
- package/.scannerwork/scanner-report/source-38.txt +161 -10
- package/.scannerwork/scanner-report/source-39.txt +18 -168
- package/.scannerwork/scanner-report/source-4.txt +31 -0
- package/.scannerwork/scanner-report/source-40.txt +29 -0
- package/.scannerwork/scanner-report/source-43.txt +187 -0
- package/.scannerwork/scanner-report/source-44.txt +151 -0
- package/.scannerwork/scanner-report/source-56.txt +15 -58
- package/.scannerwork/scanner-report/source-57.txt +22 -263
- package/.scannerwork/scanner-report/source-58.txt +116 -66
- package/.scannerwork/scanner-report/source-59.txt +47 -150
- package/.scannerwork/scanner-report/source-6.txt +111 -102
- package/.scannerwork/scanner-report/source-60.txt +199 -99
- package/.scannerwork/scanner-report/source-61.txt +430 -40
- package/.scannerwork/scanner-report/source-62.txt +92 -115
- package/.scannerwork/scanner-report/source-63.txt +87 -17
- package/.scannerwork/scanner-report/source-64.txt +79 -20
- package/.scannerwork/scanner-report/source-65.txt +26 -95
- package/.scannerwork/scanner-report/source-66.txt +26 -77
- package/.scannerwork/scanner-report/source-67.txt +41 -390
- package/.scannerwork/scanner-report/source-68.txt +20 -43
- package/.scannerwork/scanner-report/source-69.txt +274 -62
- package/.scannerwork/scanner-report/source-7.txt +59 -0
- package/.scannerwork/scanner-report/source-70.txt +46 -424
- package/.scannerwork/scanner-report/source-8.txt +80 -0
- package/.scannerwork/scanner-report/source-9.txt +129 -0
- package/.scannerwork/scanner-report/symbols-10.pb +44 -0
- package/.scannerwork/scanner-report/symbols-12.pb +143 -179
- package/.scannerwork/scanner-report/symbols-13.pb +42 -0
- package/.scannerwork/scanner-report/symbols-14.pb +45 -152
- package/.scannerwork/scanner-report/symbols-15.pb +354 -0
- package/.scannerwork/scanner-report/symbols-16.pb +18 -7
- package/.scannerwork/scanner-report/symbols-18.pb +153 -71
- package/.scannerwork/scanner-report/symbols-19.pb +180 -9
- package/.scannerwork/scanner-report/symbols-24.pb +604 -9
- package/.scannerwork/scanner-report/symbols-30.pb +32 -8
- package/.scannerwork/scanner-report/symbols-31.pb +21 -13
- package/.scannerwork/scanner-report/symbols-36.pb +22 -91
- package/.scannerwork/scanner-report/symbols-37.pb +71 -209
- package/.scannerwork/scanner-report/symbols-38.pb +207 -21
- package/.scannerwork/scanner-report/symbols-39.pb +9 -227
- package/.scannerwork/scanner-report/symbols-4.pb +14 -0
- package/.scannerwork/scanner-report/symbols-40.pb +8 -0
- package/.scannerwork/scanner-report/symbols-43.pb +227 -0
- package/.scannerwork/scanner-report/symbols-44.pb +93 -0
- package/.scannerwork/scanner-report/symbols-56.pb +9 -42
- package/.scannerwork/scanner-report/symbols-57.pb +23 -354
- package/.scannerwork/scanner-report/symbols-58.pb +86 -46
- package/.scannerwork/scanner-report/symbols-59.pb +39 -144
- package/.scannerwork/scanner-report/symbols-6.pb +59 -0
- package/.scannerwork/scanner-report/symbols-60.pb +264 -46
- package/.scannerwork/scanner-report/symbols-61.pb +789 -18
- package/.scannerwork/scanner-report/symbols-62.pb +59 -33
- package/.scannerwork/scanner-report/symbols-63.pb +57 -13
- package/.scannerwork/scanner-report/symbols-64.pb +68 -17
- package/.scannerwork/scanner-report/symbols-65.pb +19 -59
- package/.scannerwork/scanner-report/symbols-66.pb +30 -43
- package/.scannerwork/scanner-report/symbols-67.pb +33 -604
- package/.scannerwork/scanner-report/symbols-68.pb +13 -21
- package/.scannerwork/scanner-report/symbols-69.pb +428 -32
- package/.scannerwork/scanner-report/symbols-7.pb +19 -0
- package/.scannerwork/scanner-report/symbols-70.pb +7 -0
- package/.scannerwork/scanner-report/symbols-8.pb +46 -0
- package/.scannerwork/scanner-report/symbols-9.pb +33 -0
- package/.scannerwork/scanner-report/syntax-highlightings-10.pb +82 -3329
- package/.scannerwork/scanner-report/syntax-highlightings-12.pb +171 -153
- package/.scannerwork/scanner-report/syntax-highlightings-13.pb +81 -0
- package/.scannerwork/scanner-report/syntax-highlightings-14.pb +90 -178
- package/.scannerwork/scanner-report/syntax-highlightings-15.pb +285 -0
- package/.scannerwork/scanner-report/syntax-highlightings-16.pb +22 -32
- package/.scannerwork/scanner-report/syntax-highlightings-18.pb +168 -135
- package/.scannerwork/scanner-report/syntax-highlightings-19.pb +195 -31
- package/.scannerwork/scanner-report/syntax-highlightings-2.pb +3341 -0
- package/.scannerwork/scanner-report/syntax-highlightings-24.pb +611 -24
- package/.scannerwork/scanner-report/syntax-highlightings-27.pb +690 -105
- package/.scannerwork/scanner-report/syntax-highlightings-29.pb +3331 -55
- package/.scannerwork/scanner-report/syntax-highlightings-3.pb +53 -3331
- package/.scannerwork/scanner-report/syntax-highlightings-30.pb +81 -30
- package/.scannerwork/scanner-report/syntax-highlightings-31.pb +63 -43
- package/.scannerwork/scanner-report/syntax-highlightings-34.pb +3331 -167
- package/.scannerwork/scanner-report/syntax-highlightings-36.pb +59 -199
- package/.scannerwork/scanner-report/syntax-highlightings-37.pb +127 -236
- package/.scannerwork/scanner-report/syntax-highlightings-38.pb +250 -16
- package/.scannerwork/scanner-report/syntax-highlightings-39.pb +25 -332
- package/.scannerwork/scanner-report/syntax-highlightings-4.pb +45 -0
- package/.scannerwork/scanner-report/syntax-highlightings-40.pb +49 -0
- package/.scannerwork/scanner-report/syntax-highlightings-43.pb +368 -0
- package/.scannerwork/scanner-report/syntax-highlightings-44.pb +237 -0
- package/.scannerwork/scanner-report/syntax-highlightings-56.pb +22 -49
- package/.scannerwork/scanner-report/syntax-highlightings-57.pb +20 -249
- package/.scannerwork/scanner-report/syntax-highlightings-58.pb +92 -62
- package/.scannerwork/scanner-report/syntax-highlightings-59.pb +59 -201
- package/.scannerwork/scanner-report/syntax-highlightings-6.pb +131 -689
- package/.scannerwork/scanner-report/syntax-highlightings-60.pb +261 -90
- package/.scannerwork/scanner-report/syntax-highlightings-61.pb +591 -23
- package/.scannerwork/scanner-report/syntax-highlightings-62.pb +141 -92
- package/.scannerwork/scanner-report/syntax-highlightings-63.pb +124 -15
- package/.scannerwork/scanner-report/syntax-highlightings-64.pb +75 -20
- package/.scannerwork/scanner-report/syntax-highlightings-65.pb +28 -95
- package/.scannerwork/scanner-report/syntax-highlightings-66.pb +36 -60
- package/.scannerwork/scanner-report/syntax-highlightings-67.pb +69 -600
- package/.scannerwork/scanner-report/syntax-highlightings-68.pb +43 -63
- package/.scannerwork/scanner-report/syntax-highlightings-69.pb +689 -69
- package/.scannerwork/scanner-report/syntax-highlightings-7.pb +59 -0
- package/.scannerwork/scanner-report/syntax-highlightings-70.pb +51 -3328
- package/.scannerwork/scanner-report/syntax-highlightings-8.pb +95 -0
- package/.scannerwork/scanner-report/syntax-highlightings-9.pb +129 -0
- package/package.json +1 -1
- package/test-18-results.xml +160 -160
- package/test-20-results.xml +163 -163
- package/test-21-results.xml +161 -161
- package/test-iam-20-results.xml +50 -50
- package/.scannerwork/scanner-report/changesets-17.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-25.pb +0 -1
- package/.scannerwork/scanner-report/changesets-26.pb +0 -1
- package/.scannerwork/scanner-report/changesets-27.pb +0 -1
- package/.scannerwork/scanner-report/changesets-28.pb +0 -1
- package/.scannerwork/scanner-report/changesets-29.pb +0 -1
- package/.scannerwork/scanner-report/changesets-32.pb +0 -1
- package/.scannerwork/scanner-report/changesets-33.pb +0 -1
- package/.scannerwork/scanner-report/changesets-34.pb +0 -1
- package/.scannerwork/scanner-report/changesets-35.pb +0 -1
- package/.scannerwork/scanner-report/changesets-53.pb +0 -1
- package/.scannerwork/scanner-report/changesets-54.pb +0 -1
- package/.scannerwork/scanner-report/changesets-55.pb +0 -1
- package/.scannerwork/scanner-report/component-17.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-25.pb +0 -1
- package/.scannerwork/scanner-report/component-26.pb +0 -1
- package/.scannerwork/scanner-report/component-28.pb +0 -1
- package/.scannerwork/scanner-report/component-32.pb +0 -1
- package/.scannerwork/scanner-report/component-33.pb +0 -1
- package/.scannerwork/scanner-report/component-35.pb +0 -1
- package/.scannerwork/scanner-report/component-53.pb +0 -1
- package/.scannerwork/scanner-report/component-54.pb +0 -1
- package/.scannerwork/scanner-report/component-55.pb +0 -1
- package/.scannerwork/scanner-report/coverages-17.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-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-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/duplications-26.pb +0 -3
- package/.scannerwork/scanner-report/duplications-54.pb +0 -0
- package/.scannerwork/scanner-report/duplications-55.pb +0 -0
- package/.scannerwork/scanner-report/measures-17.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 -16
- package/.scannerwork/scanner-report/measures-23.pb +0 -0
- package/.scannerwork/scanner-report/measures-26.pb +0 -0
- package/.scannerwork/scanner-report/measures-28.pb +0 -0
- package/.scannerwork/scanner-report/measures-33.pb +0 -0
- package/.scannerwork/scanner-report/measures-35.pb +0 -0
- package/.scannerwork/scanner-report/measures-54.pb +0 -0
- package/.scannerwork/scanner-report/source-17.txt +0 -130
- package/.scannerwork/scanner-report/source-20.txt +0 -62
- package/.scannerwork/scanner-report/source-21.txt +0 -41
- package/.scannerwork/scanner-report/source-22.txt +0 -293
- package/.scannerwork/scanner-report/source-23.txt +0 -101
- package/.scannerwork/scanner-report/source-26.txt +0 -213
- package/.scannerwork/scanner-report/source-28.txt +0 -449
- package/.scannerwork/scanner-report/source-33.txt +0 -65
- package/.scannerwork/scanner-report/source-35.txt +0 -75
- package/.scannerwork/scanner-report/source-54.txt +0 -46
- package/.scannerwork/scanner-report/symbols-17.pb +0 -86
- package/.scannerwork/scanner-report/symbols-20.pb +0 -24
- package/.scannerwork/scanner-report/symbols-21.pb +0 -31
- package/.scannerwork/scanner-report/symbols-22.pb +0 -428
- package/.scannerwork/scanner-report/symbols-23.pb +0 -58
- package/.scannerwork/scanner-report/symbols-26.pb +0 -264
- package/.scannerwork/scanner-report/symbols-27.pb +0 -69
- package/.scannerwork/scanner-report/symbols-28.pb +0 -790
- package/.scannerwork/scanner-report/symbols-29.pb +0 -19
- package/.scannerwork/scanner-report/symbols-33.pb +0 -33
- package/.scannerwork/scanner-report/symbols-34.pb +0 -59
- package/.scannerwork/scanner-report/symbols-35.pb +0 -39
- package/.scannerwork/scanner-report/syntax-highlightings-17.pb +0 -125
- package/.scannerwork/scanner-report/syntax-highlightings-20.pb +0 -97
- package/.scannerwork/scanner-report/syntax-highlightings-21.pb +0 -69
- package/.scannerwork/scanner-report/syntax-highlightings-22.pb +0 -720
- package/.scannerwork/scanner-report/syntax-highlightings-23.pb +0 -154
- package/.scannerwork/scanner-report/syntax-highlightings-26.pb +0 -297
- package/.scannerwork/scanner-report/syntax-highlightings-28.pb +0 -627
- package/.scannerwork/scanner-report/syntax-highlightings-33.pb +0 -110
- package/.scannerwork/scanner-report/syntax-highlightings-35.pb +0 -101
- package/.scannerwork/scanner-report/syntax-highlightings-54.pb +0 -64
- /package/.scannerwork/scanner-report/{coverages-53.pb → coverages-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-54.pb → coverages-3.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-25.pb → coverages-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-32.pb → coverages-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{coverages-55.pb → coverages-5.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-17.pb → duplications-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-20.pb → duplications-15.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-21.pb → duplications-3.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-22.pb → duplications-30.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-23.pb → duplications-4.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-25.pb → duplications-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-27.pb → duplications-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-28.pb → duplications-44.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-29.pb → duplications-5.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-32.pb → duplications-6.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-33.pb → duplications-7.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-34.pb → duplications-70.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-35.pb → duplications-8.pb} +0 -0
- /package/.scannerwork/scanner-report/{duplications-53.pb → duplications-9.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-32.pb → issues-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-17.pb → issues-58.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-26.pb → issues-60.pb} +0 -0
- /package/.scannerwork/scanner-report/{issues-29.pb → issues-65.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-53.pb → measures-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-25.pb → measures-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-32.pb → measures-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{measures-55.pb → measures-5.pb} +0 -0
- /package/.scannerwork/scanner-report/{source-53.txt → source-11.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-25.txt → source-41.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-32.txt → source-42.txt} +0 -0
- /package/.scannerwork/scanner-report/{source-55.txt → source-5.txt} +0 -0
- /package/.scannerwork/scanner-report/{symbols-53.pb → symbols-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-54.pb → symbols-3.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-25.pb → symbols-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-32.pb → symbols-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{symbols-55.pb → symbols-5.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-53.pb → syntax-highlightings-11.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-25.pb → syntax-highlightings-41.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-32.pb → syntax-highlightings-42.pb} +0 -0
- /package/.scannerwork/scanner-report/{syntax-highlightings-55.pb → syntax-highlightings-5.pb} +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright ©
|
|
1
|
+
// Copyright © 2018, 2023 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,168 +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
|
+
/* global describe it */
|
|
14
16
|
'use strict';
|
|
15
17
|
|
|
16
|
-
const
|
|
17
|
-
const
|
|
18
|
-
const
|
|
19
|
-
const
|
|
20
|
-
const
|
|
18
|
+
const fs = require('fs');
|
|
19
|
+
const { once } = require('node:events');
|
|
20
|
+
const readline = require('readline');
|
|
21
|
+
const u = require('./citestutils.js');
|
|
22
|
+
const uuid = require('uuid').v4;
|
|
21
23
|
|
|
22
|
-
const
|
|
23
|
-
process.version + ')';
|
|
24
|
+
const params = { useApi: true };
|
|
24
25
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
//
|
|
28
|
-
|
|
29
|
-
constructor(options) {
|
|
30
|
-
super(options);
|
|
31
|
-
this.data = [];
|
|
32
|
-
}
|
|
26
|
+
describe(u.scenario('Concurrent database backups', params), function() {
|
|
27
|
+
it('should run concurrent API database backups correctly #slower', async function() {
|
|
28
|
+
// Allow up to 900 s to backup and compare (it should be much faster)!
|
|
29
|
+
u.setTimeout(this, 900);
|
|
33
30
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
callback();
|
|
37
|
-
}
|
|
31
|
+
const checkForEmptyBatches = async function(fileName) {
|
|
32
|
+
let foundEmptyBatch = false;
|
|
38
33
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
34
|
+
const rd = readline.createInterface({
|
|
35
|
+
input: fs.createReadStream(fileName),
|
|
36
|
+
output: fs.createWriteStream('/dev/null'),
|
|
37
|
+
terminal: false
|
|
38
|
+
});
|
|
43
39
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
//
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
let requestUrl;
|
|
50
|
-
if (err.response) {
|
|
51
|
-
if (err.response.config.url) {
|
|
52
|
-
requestUrl = err.response.config.url;
|
|
53
|
-
method = err.response.config.method;
|
|
54
|
-
}
|
|
55
|
-
// Override the status text with an improved message
|
|
56
|
-
let errorMsg = `${err.response.status} ${err.response.statusText || ''}: ` +
|
|
57
|
-
`${method} ${requestUrl}`;
|
|
58
|
-
if (err.response.data) {
|
|
59
|
-
// Check if we have a JSON response and try to get the error/reason
|
|
60
|
-
if (err.response.headers['content-type'] === 'application/json') {
|
|
61
|
-
if (!err.response.data.error && err.response.data.pipe) {
|
|
62
|
-
// If we didn't find a JSON object with `error` then we might have a stream response.
|
|
63
|
-
// Detect the stream by the presence of `pipe` and use it to get the body and parse
|
|
64
|
-
// the error information.
|
|
65
|
-
const p = new Promise((resolve, reject) => {
|
|
66
|
-
const errorBody = new ResponseWriteable();
|
|
67
|
-
err.response.data.pipe(errorBody)
|
|
68
|
-
.on('finish', () => { resolve(JSON.parse(errorBody.stringBody())); })
|
|
69
|
-
.on('error', () => { reject(err); });
|
|
70
|
-
});
|
|
71
|
-
// Replace the stream on the response with the parsed object
|
|
72
|
-
err.response.data = await p;
|
|
73
|
-
}
|
|
74
|
-
// Append the error/reason if available
|
|
75
|
-
if (err.response.data.error) {
|
|
76
|
-
// Override the status text with our more complete message
|
|
77
|
-
errorMsg += ` - Error: ${err.response.data.error}`;
|
|
78
|
-
if (err.response.data.reason) {
|
|
79
|
-
errorMsg += `, Reason: ${err.response.data.reason}`;
|
|
80
|
-
}
|
|
40
|
+
rd.on('line', function(line) {
|
|
41
|
+
if (JSON.parse(line).length === 0) {
|
|
42
|
+
// Note: Empty batch arrays indicate that the running backup is
|
|
43
|
+
// incorrectly sharing a log file with another ongoing backup job.
|
|
44
|
+
foundEmptyBatch = true;
|
|
81
45
|
}
|
|
82
|
-
} else {
|
|
83
|
-
errorMsg += err.response.data;
|
|
84
|
-
}
|
|
85
|
-
// Set a new message for use by the node-sdk-core
|
|
86
|
-
// We use the errors array because it gets processed
|
|
87
|
-
// ahead of all other service errors.
|
|
88
|
-
err.response.data.errors = [{ message: errorMsg }];
|
|
89
|
-
}
|
|
90
|
-
} else if (err.request) {
|
|
91
|
-
if (!err.message.includes(err.config.url)) {
|
|
92
|
-
// Augment the message with the URL and method
|
|
93
|
-
// but don't do it again if we already have the URL.
|
|
94
|
-
err.message = `${err.message}: ${err.config.method} ${err.config.url}`;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
return Promise.reject(err);
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
module.exports = {
|
|
101
|
-
client: function(rawUrl, opts) {
|
|
102
|
-
const url = new URL(rawUrl);
|
|
103
|
-
// Split the URL to separate service from database
|
|
104
|
-
// Use origin as the "base" to remove auth elements
|
|
105
|
-
const actUrl = new URL(url.pathname.substring(0, url.pathname.lastIndexOf('/')), url.origin);
|
|
106
|
-
const dbName = url.pathname.substring(url.pathname.lastIndexOf('/') + 1);
|
|
107
|
-
let authenticator;
|
|
108
|
-
// Default to cookieauth unless an IAM key is provided
|
|
109
|
-
if (opts.iamApiKey) {
|
|
110
|
-
const iamAuthOpts = { apikey: opts.iamApiKey };
|
|
111
|
-
if (opts.iamTokenUrl) {
|
|
112
|
-
iamAuthOpts.url = opts.iamTokenUrl;
|
|
113
|
-
}
|
|
114
|
-
authenticator = new IamAuthenticator(iamAuthOpts);
|
|
115
|
-
} else if (url.username) {
|
|
116
|
-
authenticator = new CouchdbSessionAuthenticator({
|
|
117
|
-
username: decodeURIComponent(url.username),
|
|
118
|
-
password: decodeURIComponent(url.password)
|
|
119
46
|
});
|
|
120
|
-
} else {
|
|
121
|
-
authenticator = new NoAuthAuthenticator();
|
|
122
|
-
}
|
|
123
|
-
const serviceOpts = {
|
|
124
|
-
authenticator: authenticator,
|
|
125
|
-
timeout: opts.requestTimeout,
|
|
126
|
-
// Axios performance options
|
|
127
|
-
maxContentLength: -1
|
|
128
|
-
};
|
|
129
47
|
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
service.getHttpClient().defaults.raxConfig = {
|
|
134
|
-
// retries for status codes
|
|
135
|
-
retry: maxRetries,
|
|
136
|
-
// retries for non-response e.g. ETIMEDOUT
|
|
137
|
-
noResponseRetries: maxRetries,
|
|
138
|
-
backoffType: 'exponential',
|
|
139
|
-
httpMethodsToRetry: ['GET', 'HEAD', 'POST'],
|
|
140
|
-
statusCodesToRetry: [
|
|
141
|
-
[429, 429],
|
|
142
|
-
[500, 599]
|
|
143
|
-
],
|
|
144
|
-
shouldRetry: err => {
|
|
145
|
-
const cfg = retryPlugin.getConfig(err);
|
|
146
|
-
// cap at max retries regardless of response/non-response type
|
|
147
|
-
if (cfg.currentRetryAttempt >= maxRetries) {
|
|
148
|
-
return false;
|
|
48
|
+
rd.on('close', function() {
|
|
49
|
+
if (foundEmptyBatch) {
|
|
50
|
+
return Promise.reject(new Error(`Log file '${fileName}' contains empty batches`));
|
|
149
51
|
} else {
|
|
150
|
-
return
|
|
52
|
+
return Promise.resolve();
|
|
151
53
|
}
|
|
152
|
-
}
|
|
153
|
-
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
const backupPromise = async function() {
|
|
58
|
+
const actualBackup = `./${uuid()}`;
|
|
59
|
+
const output = fs.createWriteStream(actualBackup);
|
|
60
|
+
return once(output, 'open').then(() => {
|
|
61
|
+
return u.testBackup(params, 'largedb1g', output);
|
|
62
|
+
}).then(() => {
|
|
63
|
+
return checkForEmptyBatches(actualBackup);
|
|
64
|
+
});
|
|
154
65
|
};
|
|
155
|
-
retryPlugin.attach(service.getHttpClient());
|
|
156
66
|
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
// Awkward workaround for known Couch issue with compression on _session requests
|
|
160
|
-
// It is not feasible to disable compression on all requests with the amount of
|
|
161
|
-
// data this lib needs to move, so override the property in the tokenManager instance.
|
|
162
|
-
authenticator.tokenManager.requestWrapperInstance.compressRequestData = false;
|
|
163
|
-
}
|
|
164
|
-
if (authenticator.tokenManager && authenticator.tokenManager.requestWrapperInstance) {
|
|
165
|
-
authenticator.tokenManager.requestWrapperInstance.axiosInstance.interceptors.response.use(null, errorHelper);
|
|
166
|
-
}
|
|
167
|
-
// Add error interceptors to put URLs in error messages
|
|
168
|
-
service.getHttpClient().interceptors.response.use(null, errorHelper);
|
|
67
|
+
// [1] Run 'largedb1g' database backup
|
|
68
|
+
const backup1 = backupPromise();
|
|
169
69
|
|
|
170
|
-
//
|
|
171
|
-
|
|
172
|
-
requestConfig.headers['User-Agent'] = userAgent;
|
|
173
|
-
return requestConfig;
|
|
174
|
-
}, null);
|
|
70
|
+
// [2] Run 'largedb1g' database backup
|
|
71
|
+
const backup2 = backupPromise();
|
|
175
72
|
|
|
176
|
-
return
|
|
177
|
-
}
|
|
178
|
-
};
|
|
73
|
+
return Promise.all([backup1, backup2]);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
@@ -1,102 +1,111 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
1
|
+
// Copyright © 2017, 2022 IBM Corp. All rights reserved.
|
|
2
|
+
//
|
|
3
|
+
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
// you may not use this file except in compliance with the License.
|
|
5
|
+
// You may obtain a copy of the License at
|
|
6
|
+
//
|
|
7
|
+
// http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
//
|
|
9
|
+
// Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
// See the License for the specific language governing permissions and
|
|
13
|
+
// limitations under the License.
|
|
14
|
+
'use strict';
|
|
15
|
+
|
|
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');
|
|
21
|
+
|
|
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;
|
|
40
|
+
|
|
41
|
+
// send documents ids to the queue in batches of bufferSize + the last batch
|
|
42
|
+
const processBuffer = function(lastOne) {
|
|
43
|
+
if (buffer.length >= bufferSize || (lastOne && buffer.length > 0)) {
|
|
44
|
+
debug('writing', buffer.length, 'changes to the backup file');
|
|
45
|
+
const b = { docs: buffer.splice(0, bufferSize), batch: batch };
|
|
46
|
+
logStream.write(':t batch' + batch + ' ' + JSON.stringify(b.docs) + '\n');
|
|
47
|
+
ee.emit('changes', batch);
|
|
48
|
+
batch++;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
|
|
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
|
+
}
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
function getChanges(since = 0) {
|
|
69
|
+
debug('making changes request since ' + since);
|
|
70
|
+
return db.service.postChangesAsStream({ db: db.db, since: since, limit: limit, seqInterval: limit })
|
|
71
|
+
.then(response => {
|
|
72
|
+
response.result.pipe(liner())
|
|
73
|
+
.on('error', function(err) {
|
|
74
|
+
logStream.end();
|
|
75
|
+
callback(err);
|
|
76
|
+
})
|
|
77
|
+
.pipe(change(onChange))
|
|
78
|
+
.on('error', function(err) {
|
|
79
|
+
logStream.end();
|
|
80
|
+
callback(err);
|
|
81
|
+
})
|
|
82
|
+
.on('finish', function() {
|
|
83
|
+
processBuffer(true);
|
|
84
|
+
if (!lastSeq) {
|
|
85
|
+
logStream.end();
|
|
86
|
+
debug('changes request terminated before last_seq was sent');
|
|
87
|
+
callback(new error.BackupError('SpoolChangesError', 'Changes request terminated before last_seq was sent'));
|
|
88
|
+
} else {
|
|
89
|
+
debug(`changes request completed with last_seq: ${lastSeq} and ${pending} changes pending.`);
|
|
90
|
+
if (pending > 0) {
|
|
91
|
+
// Return the next promise
|
|
92
|
+
return getChanges(lastSeq);
|
|
93
|
+
} else {
|
|
94
|
+
debug('finished streaming database changes');
|
|
95
|
+
logStream.end(':changes_complete ' + lastSeq + '\n', 'utf8', callback);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
})
|
|
100
|
+
.catch(err => {
|
|
101
|
+
logStream.end();
|
|
102
|
+
if (err.status && err.status >= 400) {
|
|
103
|
+
callback(error.convertResponseError(err));
|
|
104
|
+
} else if (err.name !== 'SpoolChangesError') {
|
|
105
|
+
callback(new error.BackupError('SpoolChangesError', `Failed changes request - ${err.message}`));
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
getChanges();
|
|
111
|
+
};
|