Browse Source

zones: introduce RingInfo and Machine.Rings

RingInfo includes Wireguard ring related details

Signed-off-by: Alejandro Mery <amery@jpi.io>
pull/1/head
Alejandro Mery 1 year ago
parent
commit
c92873f07d
  1. 5
      pkg/zones/machine.go
  2. 15
      pkg/zones/rings.go

5
pkg/zones/machine.go

@ -16,9 +16,10 @@ type Machine struct {
zone *Zone zone *Zone
id int id int
Name string Name string `toml:"name"`
PublicAddresses []netip.Addr PublicAddresses []netip.Addr `toml:"public,omitempty"`
RingAddresses []*RingInfo `toml:"rings,omitempty"`
} }
func (m *Machine) String() string { func (m *Machine) String() string {

15
pkg/zones/rings.go

@ -1,6 +1,10 @@
package zones package zones
import "net/netip" import (
"net/netip"
"git.jpi.io/amery/jpictl/pkg/wireguard"
)
const ( const (
// MaxZoneID indicates the highest ID allowed for a Zone // MaxZoneID indicates the highest ID allowed for a Zone
@ -11,6 +15,15 @@ const (
RingsCount = 2 RingsCount = 2
) )
// RingInfo contains represents the Wireguard endpoint details
// for a Machine on a particular ring
type RingInfo struct {
Ring int `toml:"ring"`
Enabled bool `toml:"enabled,omitempty"`
Keys *wireguard.KeyPair `toml:"keys,omitempty"`
Address netip.Addr `toml:"address,omitempty"`
}
// RingAddressEncoder provides encoder/decoder access for a particular // RingAddressEncoder provides encoder/decoder access for a particular
// Wireguard ring // Wireguard ring
type RingAddressEncoder struct { type RingAddressEncoder struct {

Loading…
Cancel
Save