/
configure.go
59 lines (50 loc) · 1.62 KB
/
configure.go
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
package postgres
import (
"time"
"github.com/apecloud/dataprotection-wal-g/internal"
"github.com/apecloud/dataprotection-wal-g/internal/fsutil"
"github.com/pkg/errors"
"github.com/spf13/viper"
"github.com/wal-g/tracelog"
)
// ConfigureWalUploader connects to storage and creates an uploader. It makes sure
// that a valid session has started; if invalid, returns AWS error
// and `<nil>` values.
func ConfigureWalUploader(baseUploader internal.Uploader) (uploader *WalUploader, err error) {
useWalDelta, deltaDataFolder, err := configureWalDeltaUsage()
if err != nil {
return nil, errors.Wrap(err, "failed to configure WAL Delta usage")
}
var deltaFileManager *DeltaFileManager
if useWalDelta {
deltaFileManager = NewDeltaFileManager(deltaDataFolder)
}
uploader = NewWalUploader(baseUploader, deltaFileManager)
return uploader, err
}
// TODO : unit tests
func configureWalDeltaUsage() (useWalDelta bool, deltaDataFolder fsutil.DataFolder, err error) {
useWalDelta = viper.GetBool(internal.UseWalDeltaSetting)
if !useWalDelta {
return
}
dataFolderPath := internal.GetDataFolderPath()
deltaDataFolder, err = fsutil.NewDiskDataFolder(dataFolderPath)
if err != nil {
useWalDelta = false
tracelog.WarningLogger.Printf("can't use wal delta feature because can't open delta data folder '%s'"+
" due to error: '%v'\n", dataFolderPath, err)
err = nil
}
return
}
func getStopBackupTimeoutSetting() (time.Duration, error) {
if !viper.IsSet(internal.PgStopBackupTimeout) {
return 0, nil
}
timeout, err := internal.GetDurationSetting(internal.PgStopBackupTimeout)
if err != nil {
return 0, err
}
return timeout, nil
}