mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-28 14:35:27 +08:00
issue: #43897 - support never expire txn message. Signed-off-by: chyezh <chyezh@outlook.com>
55 lines
1.3 KiB
Go
55 lines
1.3 KiB
Go
package message
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/proto/messagespb"
|
|
)
|
|
|
|
type (
|
|
TxnState = messagespb.TxnState
|
|
TxnID int64
|
|
)
|
|
|
|
const (
|
|
TxnStateInFlight TxnState = messagespb.TxnState_TxnInFlight
|
|
TxnStateOnCommit TxnState = messagespb.TxnState_TxnOnCommit
|
|
TxnStateCommitted TxnState = messagespb.TxnState_TxnCommitted
|
|
TxnStateOnRollback TxnState = messagespb.TxnState_TxnOnRollback
|
|
TxnStateRollbacked TxnState = messagespb.TxnState_TxnRollbacked
|
|
|
|
NonTxnID = TxnID(-1)
|
|
|
|
// TxnKeepaliveInfinite is the infinite keepalive duration.
|
|
// If the keepalive is infinite, the txn will never be expired.
|
|
TxnKeepaliveInfinite = -1 * time.Second
|
|
)
|
|
|
|
// NewTxnContextFromProto generates TxnContext from proto message.
|
|
func NewTxnContextFromProto(proto *messagespb.TxnContext) *TxnContext {
|
|
if proto == nil {
|
|
return nil
|
|
}
|
|
return &TxnContext{
|
|
TxnID: TxnID(proto.TxnId),
|
|
Keepalive: time.Duration(proto.KeepaliveMilliseconds) * time.Millisecond,
|
|
}
|
|
}
|
|
|
|
// TxnContext is the transaction context for message.
|
|
type TxnContext struct {
|
|
TxnID TxnID
|
|
Keepalive time.Duration
|
|
}
|
|
|
|
// IntoProto converts TxnContext to proto message.
|
|
func (t *TxnContext) IntoProto() *messagespb.TxnContext {
|
|
if t == nil {
|
|
return nil
|
|
}
|
|
return &messagespb.TxnContext{
|
|
TxnId: int64(t.TxnID),
|
|
KeepaliveMilliseconds: t.Keepalive.Milliseconds(),
|
|
}
|
|
}
|