| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 | package commandimport (	"crypto/ed25519"	"crypto/rand"	"strings"	"github.com/gravitl/netmaker/logger"	"github.com/gravitl/netmaker/netclient/config"	"github.com/gravitl/netmaker/netclient/daemon"	"github.com/gravitl/netmaker/netclient/functions"	"github.com/gravitl/netmaker/netclient/ncutils"	"github.com/gravitl/netmaker/tls")// Join - join command to run from clifunc Join(cfg *config.ClientConfig, privateKey string) error {	var err error	//join network	err = functions.JoinNetwork(cfg, privateKey)	if err != nil && !cfg.DebugOn {		if !strings.Contains(err.Error(), "ALREADY_INSTALLED") {			logger.Log(1, "error installing: ", err.Error())			err = functions.LeaveNetwork(cfg.Network, true)			if err != nil {				err = functions.WipeLocal(cfg.Network)				if err != nil {					logger.Log(1, "error removing artifacts: ", err.Error())				}			}			if cfg.Daemon != "off" {				if ncutils.IsLinux() {					err = daemon.RemoveSystemDServices()				}				if err != nil {					logger.Log(1, "error removing services: ", err.Error())				}				if ncutils.IsFreeBSD() {					daemon.RemoveFreebsdDaemon()				}			}		} else {			logger.Log(0, "success")		}		if err != nil && strings.Contains(err.Error(), "ALREADY_INSTALLED") {			logger.Log(0, err.Error())			err = nil		}		return err	}	logger.Log(1, "joined ", cfg.Network)	/*		if ncutils.IsWindows() {			logger.Log("setting up WireGuard app", 0)			time.Sleep(time.Second >> 1)			functions.Pull(cfg.Network, true)		}	*/	return err}// Leave - runs the leave command from clifunc Leave(cfg *config.ClientConfig, force bool) error {	err := functions.LeaveNetwork(cfg.Network, force)	if err != nil {		logger.Log(1, "error attempting to leave network "+cfg.Network)	} else {		logger.Log(0, "success")	}	return err}// Pull - runs pull command from clifunc Pull(cfg *config.ClientConfig) error {	var err error	if cfg.Network == "all" {		logger.Log(0, "No network selected. Running Pull for all networks.")		networks, err := ncutils.GetSystemNetworks()		if err != nil {			logger.Log(1, "Error retrieving networks. Exiting.")			return err		}		for _, network := range networks {			_, err = functions.Pull(network, true)			if err != nil {				logger.Log(1, "Error pulling network config for network: ", network, "\n", err.Error())			} else {				logger.Log(1, "pulled network config for "+network)			}		}		err = nil	} else {		_, err = functions.Pull(cfg.Network, true)		_, newKey, kerr := ed25519.GenerateKey(rand.Reader)		if kerr == nil {			if kerr := tls.SaveKey(ncutils.GetNetclientPath(), "/client.key", newKey); err != nil {				logger.Log(0, "error saving key", kerr.Error())			} else {				if kerr = functions.RegisterWithServer(&newKey, cfg); err != nil {					logger.Log(0, "registration error", kerr.Error())				} else {					daemon.Restart()				}			}		}	}	logger.Log(1, "reset network and peer configs")	if err == nil {		logger.Log(1, "reset network and peer configs")		logger.Log(1, "success")	} else {		logger.Log(0, "error occurred pulling configs from server")	}	return err}// List - runs list command from clifunc List(cfg config.ClientConfig) error {	err := functions.List(cfg.Network)	return err}// Uninstall - runs uninstall command from clifunc Uninstall() error {	logger.Log(0, "uninstalling netclient...")	err := functions.Uninstall()	logger.Log(0, "uninstalled netclient")	return err}// Daemon - runs the daemonfunc Daemon() error {	err := functions.Daemon()	return err}
 |