mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-12-11 22:11:58 +01:00
54 lines
1.5 KiB
Go
54 lines
1.5 KiB
Go
|
package zkhelper
|
||
|
|
||
|
import (
|
||
|
zk "github.com/ngaut/go-zookeeper/zk"
|
||
|
)
|
||
|
|
||
|
/*
|
||
|
type Stat interface {
|
||
|
Czxid() int64
|
||
|
Mzxid() int64
|
||
|
CTime() time.Time
|
||
|
MTime() time.Time
|
||
|
Version() int
|
||
|
CVersion() int
|
||
|
AVersion() int
|
||
|
EphemeralOwner() int64
|
||
|
DataLength() int
|
||
|
NumChildren() int
|
||
|
Pzxid() int64
|
||
|
}
|
||
|
*/
|
||
|
|
||
|
// This interface is really close to the zookeeper connection
|
||
|
// interface. It uses the Stat interface defined here instead of the
|
||
|
// zookeeper.Stat structure for stats. Everything else is the same as
|
||
|
// in zookeeper. So refer to the zookeeper docs for the conventions
|
||
|
// used here (for instance, using -1 as version to specify any
|
||
|
// version)
|
||
|
type Conn interface {
|
||
|
Get(path string) (data []byte, stat zk.Stat, err error)
|
||
|
GetW(path string) (data []byte, stat zk.Stat, watch <-chan zk.Event, err error)
|
||
|
|
||
|
Children(path string) (children []string, stat zk.Stat, err error)
|
||
|
ChildrenW(path string) (children []string, stat zk.Stat, watch <-chan zk.Event, err error)
|
||
|
|
||
|
Exists(path string) (exist bool, stat zk.Stat, err error)
|
||
|
ExistsW(path string) (exist bool, stat zk.Stat, watch <-chan zk.Event, err error)
|
||
|
|
||
|
Create(path string, value []byte, flags int32, aclv []zk.ACL) (pathCreated string, err error)
|
||
|
|
||
|
Set(path string, value []byte, version int32) (stat zk.Stat, err error)
|
||
|
|
||
|
Delete(path string, version int32) (err error)
|
||
|
|
||
|
Close()
|
||
|
|
||
|
//RetryChange(path string, flags int, acl []ACL, changeFunc ChangeFunc) error
|
||
|
|
||
|
GetACL(path string) ([]zk.ACL, zk.Stat, error)
|
||
|
SetACL(path string, aclv []zk.ACL, version int32) (zk.Stat, error)
|
||
|
|
||
|
Seq2Str(seq int64) string
|
||
|
}
|