mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-23 13:51:06 -05:00
79 lines
2.0 KiB
Go
79 lines
2.0 KiB
Go
|
package peer
|
||
|
|
||
|
import (
|
||
|
"github.com/edgelesssys/constellation/coordinator/pubapi/pubproto"
|
||
|
"github.com/edgelesssys/constellation/coordinator/role"
|
||
|
"github.com/edgelesssys/constellation/coordinator/vpnapi/vpnproto"
|
||
|
)
|
||
|
|
||
|
// AdminData contains all VPN information about the admin.
|
||
|
type AdminData struct {
|
||
|
VPNIP string
|
||
|
PublicKey []byte
|
||
|
}
|
||
|
|
||
|
// Peer holds all information about a peer.
|
||
|
type Peer struct {
|
||
|
// PublicEndpoint is the endpoint on which the peer is reachable.
|
||
|
PublicEndpoint string
|
||
|
// VPNIP holds the internal VPN address, can only be used within the VPN
|
||
|
// and some gRPC services may only be reachable from this IP.
|
||
|
VPNIP string
|
||
|
// VPNPubKey contains the PublicKey used for cryptographic purposes in the VPN.
|
||
|
VPNPubKey []byte
|
||
|
// Role is the peer's role (Coordinator or Node).
|
||
|
Role role.Role
|
||
|
}
|
||
|
|
||
|
func FromPubProto(peers []*pubproto.Peer) []Peer {
|
||
|
var result []Peer
|
||
|
for _, p := range peers {
|
||
|
result = append(result, Peer{
|
||
|
PublicEndpoint: p.PublicEndpoint,
|
||
|
VPNIP: p.VpnIp,
|
||
|
VPNPubKey: p.VpnPubKey,
|
||
|
Role: role.Role(p.Role),
|
||
|
})
|
||
|
}
|
||
|
return result
|
||
|
}
|
||
|
|
||
|
func ToPubProto(peers []Peer) []*pubproto.Peer {
|
||
|
var result []*pubproto.Peer
|
||
|
for _, p := range peers {
|
||
|
result = append(result, &pubproto.Peer{
|
||
|
PublicEndpoint: p.PublicEndpoint,
|
||
|
VpnIp: p.VPNIP,
|
||
|
VpnPubKey: p.VPNPubKey,
|
||
|
Role: uint32(p.Role),
|
||
|
})
|
||
|
}
|
||
|
return result
|
||
|
}
|
||
|
|
||
|
func FromVPNProto(peers []*vpnproto.Peer) []Peer {
|
||
|
var result []Peer
|
||
|
for _, p := range peers {
|
||
|
result = append(result, Peer{
|
||
|
PublicEndpoint: p.PublicEndpoint,
|
||
|
VPNIP: p.VpnIp,
|
||
|
VPNPubKey: p.VpnPubKey,
|
||
|
Role: role.Role(p.Role),
|
||
|
})
|
||
|
}
|
||
|
return result
|
||
|
}
|
||
|
|
||
|
func ToVPNProto(peers []Peer) []*vpnproto.Peer {
|
||
|
var result []*vpnproto.Peer
|
||
|
for _, p := range peers {
|
||
|
result = append(result, &vpnproto.Peer{
|
||
|
PublicEndpoint: p.PublicEndpoint,
|
||
|
VpnIp: p.VPNIP,
|
||
|
VpnPubKey: p.VPNPubKey,
|
||
|
Role: uint32(p.Role),
|
||
|
})
|
||
|
}
|
||
|
return result
|
||
|
}
|