Integrate BACKBEAT SDK and resolve KACHING license validation
Major integrations and fixes: - Added BACKBEAT SDK integration for P2P operation timing - Implemented beat-aware status tracking for distributed operations - Added Docker secrets support for secure license management - Resolved KACHING license validation via HTTPS/TLS - Updated docker-compose configuration for clean stack deployment - Disabled rollback policies to prevent deployment failures - Added license credential storage (CHORUS-DEV-MULTI-001) Technical improvements: - BACKBEAT P2P operation tracking with phase management - Enhanced configuration system with file-based secrets - Improved error handling for license validation - Clean separation of KACHING and CHORUS deployment stacks 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
171
vendor/github.com/libp2p/go-libp2p-kad-dht/pb/message.go
generated
vendored
Normal file
171
vendor/github.com/libp2p/go-libp2p-kad-dht/pb/message.go
generated
vendored
Normal file
@@ -0,0 +1,171 @@
|
||||
package dht_pb
|
||||
|
||||
import (
|
||||
"github.com/libp2p/go-libp2p/core/network"
|
||||
"github.com/libp2p/go-libp2p/core/peer"
|
||||
|
||||
logging "github.com/ipfs/go-log"
|
||||
ma "github.com/multiformats/go-multiaddr"
|
||||
)
|
||||
|
||||
var log = logging.Logger("dht.pb")
|
||||
|
||||
type PeerRoutingInfo struct {
|
||||
peer.AddrInfo
|
||||
network.Connectedness
|
||||
}
|
||||
|
||||
// NewMessage constructs a new dht message with given type, key, and level
|
||||
func NewMessage(typ Message_MessageType, key []byte, level int) *Message {
|
||||
m := &Message{
|
||||
Type: typ,
|
||||
Key: key,
|
||||
}
|
||||
m.SetClusterLevel(level)
|
||||
return m
|
||||
}
|
||||
|
||||
func peerRoutingInfoToPBPeer(p PeerRoutingInfo) Message_Peer {
|
||||
var pbp Message_Peer
|
||||
|
||||
pbp.Addrs = make([][]byte, len(p.Addrs))
|
||||
for i, maddr := range p.Addrs {
|
||||
pbp.Addrs[i] = maddr.Bytes() // Bytes, not String. Compressed.
|
||||
}
|
||||
pbp.Id = byteString(p.ID)
|
||||
pbp.Connection = ConnectionType(p.Connectedness)
|
||||
return pbp
|
||||
}
|
||||
|
||||
func peerInfoToPBPeer(p peer.AddrInfo) Message_Peer {
|
||||
var pbp Message_Peer
|
||||
|
||||
pbp.Addrs = make([][]byte, len(p.Addrs))
|
||||
for i, maddr := range p.Addrs {
|
||||
pbp.Addrs[i] = maddr.Bytes() // Bytes, not String. Compressed.
|
||||
}
|
||||
pbp.Id = byteString(p.ID)
|
||||
return pbp
|
||||
}
|
||||
|
||||
// PBPeerToPeer turns a *Message_Peer into its peer.AddrInfo counterpart
|
||||
func PBPeerToPeerInfo(pbp Message_Peer) peer.AddrInfo {
|
||||
return peer.AddrInfo{
|
||||
ID: peer.ID(pbp.Id),
|
||||
Addrs: pbp.Addresses(),
|
||||
}
|
||||
}
|
||||
|
||||
// RawPeerInfosToPBPeers converts a slice of Peers into a slice of *Message_Peers,
|
||||
// ready to go out on the wire.
|
||||
func RawPeerInfosToPBPeers(peers []peer.AddrInfo) []Message_Peer {
|
||||
pbpeers := make([]Message_Peer, len(peers))
|
||||
for i, p := range peers {
|
||||
pbpeers[i] = peerInfoToPBPeer(p)
|
||||
}
|
||||
return pbpeers
|
||||
}
|
||||
|
||||
// PeersToPBPeers converts given []peer.Peer into a set of []*Message_Peer,
|
||||
// which can be written to a message and sent out. the key thing this function
|
||||
// does (in addition to PeersToPBPeers) is set the ConnectionType with
|
||||
// information from the given network.Network.
|
||||
func PeerInfosToPBPeers(n network.Network, peers []peer.AddrInfo) []Message_Peer {
|
||||
pbps := RawPeerInfosToPBPeers(peers)
|
||||
for i, pbp := range pbps {
|
||||
c := ConnectionType(n.Connectedness(peers[i].ID))
|
||||
pbp.Connection = c
|
||||
}
|
||||
return pbps
|
||||
}
|
||||
|
||||
func PeerRoutingInfosToPBPeers(peers []PeerRoutingInfo) []Message_Peer {
|
||||
pbpeers := make([]Message_Peer, len(peers))
|
||||
for i, p := range peers {
|
||||
pbpeers[i] = peerRoutingInfoToPBPeer(p)
|
||||
}
|
||||
return pbpeers
|
||||
}
|
||||
|
||||
// PBPeersToPeerInfos converts given []*Message_Peer into []peer.AddrInfo
|
||||
// Invalid addresses will be silently omitted.
|
||||
func PBPeersToPeerInfos(pbps []Message_Peer) []*peer.AddrInfo {
|
||||
peers := make([]*peer.AddrInfo, 0, len(pbps))
|
||||
for _, pbp := range pbps {
|
||||
ai := PBPeerToPeerInfo(pbp)
|
||||
peers = append(peers, &ai)
|
||||
}
|
||||
return peers
|
||||
}
|
||||
|
||||
// Addresses returns a multiaddr associated with the Message_Peer entry
|
||||
func (m *Message_Peer) Addresses() []ma.Multiaddr {
|
||||
if m == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
maddrs := make([]ma.Multiaddr, 0, len(m.Addrs))
|
||||
for _, addr := range m.Addrs {
|
||||
maddr, err := ma.NewMultiaddrBytes(addr)
|
||||
if err != nil {
|
||||
log.Debugw("error decoding multiaddr for peer", "peer", peer.ID(m.Id), "error", err)
|
||||
continue
|
||||
}
|
||||
|
||||
maddrs = append(maddrs, maddr)
|
||||
}
|
||||
return maddrs
|
||||
}
|
||||
|
||||
// GetClusterLevel gets and adjusts the cluster level on the message.
|
||||
// a +/- 1 adjustment is needed to distinguish a valid first level (1) and
|
||||
// default "no value" protobuf behavior (0)
|
||||
func (m *Message) GetClusterLevel() int {
|
||||
level := m.GetClusterLevelRaw() - 1
|
||||
if level < 0 {
|
||||
return 0
|
||||
}
|
||||
return int(level)
|
||||
}
|
||||
|
||||
// SetClusterLevel adjusts and sets the cluster level on the message.
|
||||
// a +/- 1 adjustment is needed to distinguish a valid first level (1) and
|
||||
// default "no value" protobuf behavior (0)
|
||||
func (m *Message) SetClusterLevel(level int) {
|
||||
lvl := int32(level)
|
||||
m.ClusterLevelRaw = lvl + 1
|
||||
}
|
||||
|
||||
// ConnectionType returns a Message_ConnectionType associated with the
|
||||
// network.Connectedness.
|
||||
func ConnectionType(c network.Connectedness) Message_ConnectionType {
|
||||
switch c {
|
||||
default:
|
||||
return Message_NOT_CONNECTED
|
||||
case network.NotConnected:
|
||||
return Message_NOT_CONNECTED
|
||||
case network.Connected:
|
||||
return Message_CONNECTED
|
||||
case network.CanConnect:
|
||||
return Message_CAN_CONNECT
|
||||
case network.CannotConnect:
|
||||
return Message_CANNOT_CONNECT
|
||||
}
|
||||
}
|
||||
|
||||
// Connectedness returns an network.Connectedness associated with the
|
||||
// Message_ConnectionType.
|
||||
func Connectedness(c Message_ConnectionType) network.Connectedness {
|
||||
switch c {
|
||||
default:
|
||||
return network.NotConnected
|
||||
case Message_NOT_CONNECTED:
|
||||
return network.NotConnected
|
||||
case Message_CONNECTED:
|
||||
return network.Connected
|
||||
case Message_CAN_CONNECT:
|
||||
return network.CanConnect
|
||||
case Message_CANNOT_CONNECT:
|
||||
return network.CannotConnect
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user