Skip to content

Commit e91e12c

Browse files
committed
add cbt interfaces
Signed-off-by: Lyndon-Li <lyonghui@vmware.com>
1 parent eaef4ea commit e91e12c

3 files changed

Lines changed: 85 additions & 0 deletions

File tree

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Fix issue #9709, add interfaces for CBT service and CBT bitmap

pkg/cbtservice/service.go

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
/*
2+
Copyright The Velero Contributors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package cbtservice
18+
19+
import "context"
20+
21+
// Range defines the range of a change
22+
type Range struct {
23+
Offset int64
24+
Length int64
25+
}
26+
27+
// ChangeID uniquely identifies what the current allocated/changed blocks are queried for
28+
// could be a VolumeSnapshot name or any other values defined by customized services
29+
type ChangeID string
30+
31+
// Service defines the methods for CBT service which could be implemented by Kubernetes SnapshotMetadataService or other customized services
32+
type Service interface {
33+
// GetAllocatedBlocks enumerates the allocated blocks and call the record callback
34+
GetAllocatedBlocks(ctx context.Context, changeID ChangeID, record func([]Range) error) error
35+
36+
// GetChangedBlocks enumerates the changed blocks between base and target and call the record callback
37+
GetChangedBlocks(ctx context.Context, base ChangeID, target ChangeID, record func([]Range) error) error
38+
}

pkg/uploader/cbt/bitmap.go

Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
/*
2+
Copyright The Velero Contributors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package cbt
18+
19+
import "github.com/vmware-tanzu/velero/pkg/cbtservice"
20+
21+
// Bitmap defines the methods to store and iterate the CBT bitmap
22+
type Bitmap interface {
23+
// Set sets bits within the provided range
24+
Set(cbtservice.Range)
25+
26+
// Iterator returns the iterator for the CBT Bitmap
27+
Iterator() Iterator
28+
}
29+
30+
// Iterator defines the methods to iterate the CBT bitmap and query the associated information
31+
type Iterator interface {
32+
// BaseID returns the base changeID
33+
BaseID() cbtservice.ChangeID
34+
35+
// ChangeID returns the current changeID
36+
ChangeID() cbtservice.ChangeID
37+
38+
// BlockSize returns the granularity of the bitmap
39+
BlockSize() int
40+
41+
// Count returns the toal number of count in the bitmap
42+
Count() uint64
43+
44+
// Next returns the offset of the next set block and whether it comes to the end of the iteration
45+
Next() (int64, bool)
46+
}

0 commit comments

Comments
 (0)