-
Notifications
You must be signed in to change notification settings - Fork 6
/
logstream.go
42 lines (35 loc) · 1.17 KB
/
logstream.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
package logstream
import (
"context"
"github.com/kakao/varlog/internal/varlogctl"
"github.com/kakao/varlog/pkg/types"
"github.com/kakao/varlog/pkg/varlog"
)
func Describe(tpid types.TopicID, lsid ...types.LogStreamID) varlogctl.ExecuteFunc {
return func(ctx context.Context, adm varlog.Admin) (any, error) {
if len(lsid) > 0 {
return adm.GetLogStream(ctx, tpid, lsid[0])
}
return adm.ListLogStreams(ctx, tpid)
}
}
func Add(tpid types.TopicID) varlogctl.ExecuteFunc {
return func(ctx context.Context, adm varlog.Admin) (any, error) {
return adm.AddLogStream(ctx, tpid, nil)
}
}
func Seal(tpid types.TopicID, lsid types.LogStreamID) varlogctl.ExecuteFunc {
return func(ctx context.Context, adm varlog.Admin) (any, error) {
return adm.Seal(ctx, tpid, lsid)
}
}
func Unseal(tpid types.TopicID, lsid types.LogStreamID) varlogctl.ExecuteFunc {
return func(ctx context.Context, adm varlog.Admin) (any, error) {
return adm.Unseal(ctx, tpid, lsid)
}
}
func Sync(tpid types.TopicID, lsid types.LogStreamID, src, dst types.StorageNodeID) varlogctl.ExecuteFunc {
return func(ctx context.Context, adm varlog.Admin) (any, error) {
return adm.Sync(ctx, tpid, lsid, src, dst)
}
}