forked from folbricht/desync
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstore.go
123 lines (102 loc) · 4.42 KB
/
store.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
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
package desync
import (
"context"
"encoding/json"
"fmt"
"io"
"time"
)
const DefaultErrorRetry = 3
const DefaultErrorRetryBaseInterval = 500 * time.Millisecond
// Store is a generic interface implemented by read-only stores, like SSH or
// HTTP remote stores currently.
type Store interface {
GetChunk(id ChunkID) (*Chunk, error)
HasChunk(id ChunkID) (bool, error)
io.Closer
fmt.Stringer
}
// WriteStore is implemented by stores supporting both read and write operations
// such as a local store or an S3 store.
type WriteStore interface {
Store
StoreChunk(c *Chunk) error
}
// PruneStore is a store that supports read, write and pruning of chunks
type PruneStore interface {
WriteStore
Prune(ctx context.Context, ids map[ChunkID]struct{}) error
}
// IndexStore is implemented by stores that hold indexes.
type IndexStore interface {
GetIndexReader(name string) (io.ReadCloser, error)
GetIndex(name string) (Index, error)
io.Closer
fmt.Stringer
}
// IndexWriteStore is used by stores that support reading and writing of indexes.
type IndexWriteStore interface {
IndexStore
StoreIndex(name string, idx Index) error
}
// StoreOptions provide additional common settings used in chunk stores, such as compression
// error retry or timeouts. Not all options available are applicable to all types of stores.
type StoreOptions struct {
// Concurrency used in the store. Depending on store type, it's used for
// the number of goroutines, processes, or connection pool size.
N int `json:"n,omitempty"`
// Cert file name for HTTP SSL connections that require mutual SSL.
ClientCert string `json:"client-cert,omitempty"`
// Key file name for HTTP SSL connections that require mutual SSL.
ClientKey string `json:"client-key,omitempty"`
// CA certificates to trust in TLS connections. If not set, the systems CA store is used.
CACert string `json:"ca-cert,omitempty"`
// Trust any certificate presented by the remote chunk store.
TrustInsecure bool `json:"trust-insecure,omitempty"`
// Authorization header value for HTTP stores
HTTPAuth string `json:"http-auth,omitempty"`
// Cookie header value for HTTP stores
HTTPCookie string `json:"http-cookie,omitempty"`
// Timeout for waiting for objects to be retrieved. Infinite if negative. Default: 1 minute
Timeout time.Duration `json:"timeout,omitempty"`
// Number of times object retrieval should be attempted on error. Useful when dealing
// with unreliable connections.
ErrorRetry int `json:"error-retry,omitempty"`
// Number of nanoseconds to wait before first retry attempt.
// Retry attempt number N for the same request will wait N times this interval.
ErrorRetryBaseInterval time.Duration `json:"error-retry-base-interval,omitempty"`
// If SkipVerify is true, this store will not verify the data it reads and serves up. This is
// helpful when a store is merely a proxy and the data will pass through additional stores
// before being used. Verifying the checksum of a chunk requires it be uncompressed, so if
// a compressed chunkstore is being proxied, all chunks would have to be decompressed first.
// This setting avoids the extra overhead. While this could be used in other cases, it's not
// recommended as a damaged chunk might be processed further leading to unpredictable results.
SkipVerify bool `json:"skip-verify,omitempty"`
// Store and read chunks uncompressed, without chunk file extension
Uncompressed bool `json:"uncompressed"`
}
// NewStoreOptionsWithDefaults creates a new StoreOptions struct with the default values set
func NewStoreOptionsWithDefaults() (o StoreOptions) {
o.ErrorRetry = DefaultErrorRetry
o.ErrorRetryBaseInterval = DefaultErrorRetryBaseInterval
return o
}
func (o *StoreOptions) UnmarshalJSON(data []byte) error {
// Set all the default values before loading the JSON store options
o.ErrorRetry = DefaultErrorRetry
o.ErrorRetryBaseInterval = DefaultErrorRetryBaseInterval
type Alias StoreOptions
return json.Unmarshal(data, (*Alias)(o))
}
// Returns data converters that convert between plain and storage-format. Each layer
// represents a modification such as compression or encryption and is applied in order
// depending the direction of data. If data is written to storage, the layer's toStorage
// method is called in the order they are returned. If data is read, the fromStorage
// method is called in reverse order.
func (o *StoreOptions) converters() []converter {
var m []converter
if !o.Uncompressed {
m = append(m, Compressor{})
}
return m
}