| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | 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 {		if !strings.Contains(err.Error(), "ALREADY_INSTALLED") {			logger.Log(0, "error installing: ", err.Error())			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()				}			}		}		if err != nil && strings.Contains(err.Error(), "ALREADY_INSTALLED") {			logger.Log(0, err.Error())			err = nil		}		return err	}	logger.Log(1, "joined ", cfg.Network)	return err}// Leave - runs the leave command from clifunc Leave(cfg *config.ClientConfig) error {	err := functions.LeaveNetwork(cfg.Network)	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	var networks = []string{}	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		}	} else {		networks = append(networks, cfg.Network)	}	var currentServers = make(map[string]config.ClientConfig)	for _, network := range networks {		currCfg, err := config.ReadConfig(network)		if err != nil {			logger.Log(1, "could not read config when pulling for network", network)			continue		}		_, 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)		}		currentServers[currCfg.Server.Server] = *currCfg	}	//generate new client key if one doesn' exist	var private *ed25519.PrivateKey	private, err = tls.ReadKey(ncutils.GetNetclientPath() + ncutils.GetSeparator() + "client.key")	if err != nil {		_, newKey, err := ed25519.GenerateKey(rand.Reader)		if err != nil {			return err		}		if err := tls.SaveKey(ncutils.GetNetclientPath(), ncutils.GetSeparator()+"client.key", newKey); err != nil {			return err		}		private = &newKey	}	// re-register with server -- get new certs for broker	for _, clientCfg := range currentServers {		if err = functions.RegisterWithServer(private, &clientCfg); err != nil {			logger.Log(0, "registration error", err.Error())		} else {			daemon.Restart()		}	}	logger.Log(1, "reset network and peer configs")	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}
 |