Alejandro Mery
1 year ago
2 changed files with 72 additions and 0 deletions
@ -0,0 +1,66 @@
|
||||
package zones |
||||
|
||||
import ( |
||||
"bytes" |
||||
"fmt" |
||||
"os" |
||||
|
||||
"darvaza.org/core" |
||||
|
||||
"git.jpi.io/amery/jpictl/pkg/wireguard" |
||||
) |
||||
|
||||
// GetWireguardConfig reads a wgN.conf file
|
||||
func (m *Machine) GetWireguardConfig(ring int) (*wireguard.Config, error) { |
||||
data, err := m.ReadFile("wg%v.conf", ring) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
r := bytes.NewReader(data) |
||||
return wireguard.NewConfigFromReader(r) |
||||
} |
||||
|
||||
func (m *Machine) tryApplyWireguardConfig(ring int) error { |
||||
wg, err := m.GetWireguardConfig(ring) |
||||
switch { |
||||
case os.IsNotExist(err): |
||||
return nil |
||||
case err != nil: |
||||
return err |
||||
default: |
||||
return m.applyWireguardConfig(ring, wg) |
||||
} |
||||
} |
||||
|
||||
func (m *Machine) applyWireguardConfig(ring int, wg *wireguard.Config) error { |
||||
addr := wg.GetAddress() |
||||
zoneID, nodeID, ok := Rings[ring].Decode(addr) |
||||
if !ok { |
||||
return fmt.Errorf("%s: invalid wg%v address: %s", m.Name, ring, addr) |
||||
} |
||||
|
||||
if err := m.applyZoneNodeID(zoneID, nodeID); err != nil { |
||||
err = core.Wrapf(err, "%s: wg%v:%s", m.Name, ring, addr) |
||||
return err |
||||
} |
||||
|
||||
return nil |
||||
} |
||||
|
||||
func (m *Machine) applyZoneNodeID(zoneID, nodeID int) error { |
||||
switch { |
||||
case zoneID == 0: |
||||
return fmt.Errorf("invalid %s", "zoneID") |
||||
case nodeID == 0: |
||||
return fmt.Errorf("invalid %s", "nodeID") |
||||
case m.ID() != nodeID: |
||||
return fmt.Errorf("invalid %s: %v ≠ %v", "zoneID", m.ID(), nodeID) |
||||
case m.zone.ID != 0 && m.zone.ID != zoneID: |
||||
return fmt.Errorf("invalid %s: %v ≠ %v", "zoneID", m.zone.ID, zoneID) |
||||
case m.zone.ID == 0: |
||||
m.zone.ID = zoneID |
||||
} |
||||
|
||||
return nil |
||||
} |
Loading…
Reference in new issue