1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- package functions
- import (
- "fmt"
- "github.com/gravitl/netmaker/netclient/config"
- "github.com/gravitl/netmaker/netclient/daemon"
- "github.com/gravitl/netmaker/netclient/ncutils"
- "github.com/gravitl/netmaker/netclient/wireguard"
- )
- // Connect - will attempt to connect a node on given network
- func Connect(network string) error {
- cfg, err := config.ReadConfig(network)
- if err != nil {
- return err
- }
- if cfg.Node.Connected == "yes" {
- return fmt.Errorf("node already connected")
- }
- cfg.Node.Connected = "yes"
- filePath := ncutils.GetNetclientPathSpecific() + cfg.Node.Interface + ".conf"
- if err = wireguard.ApplyConf(&cfg.Node, cfg.Node.Interface, filePath); err != nil {
- return err
- }
- err = config.ModNodeConfig(&cfg.Node)
- daemon.Restart()
- return err
- }
- // Disconnect - attempts to disconnect a node on given network
- func Disconnect(network string) error {
- cfg, err := config.ReadConfig(network)
- if err != nil {
- return err
- }
- if cfg.Node.Connected == "no" {
- return fmt.Errorf("node already disconnected")
- }
- cfg.Node.Connected = "no"
- filePath := ncutils.GetNetclientPathSpecific() + cfg.Node.Interface + ".conf"
- if err = wireguard.ApplyConf(&cfg.Node, cfg.Node.Interface, filePath); err != nil {
- return err
- }
- err = config.ModNodeConfig(&cfg.Node)
- daemon.Restart()
- return err
- }
|