mirror of
https://github.com/netbirdio/netbird.git
synced 2024-11-25 17:43:38 +01:00
1a8c03bef0
* created InitializePeer and ClosePeerConnection functions * feature: simplify peer stopping * chore: remove unused code * feature: basic management service implementation (#44) * feat: basic management service implementation [FAILING TESTS] * test: fix healthcheck test * test: #39 add peer registration endpoint test * feat: #39 add setup key handling * feat: #39 add peer management store persistence * refactor: extract config read/write to the utility package * refactor: move file contents copy to the utility package * refactor: use Accounts instead of Users in the Store * feature: add management server Docker file * refactor: introduce datadir instead of config * chore: use filepath.Join to concat filepaths instead of string concat * refactor: move stop channel to the root * refactor: move stop channel to the root * review: fix PR review notes Co-authored-by: braginini <hello@wiretrustee.com> * Handle read config file errors * feature: add letsencrypt support to the management service * fix: lint warnings * chore: change default datadir * refactor: set default flags in code not Dockerfile * chore: remove unused code * Added RemovePeer and centralized configureDevice code * remove peer from the wg interface when closing proxy * remove config file * add iface tests * fix tests, validate if file exists before removing it * removed unused functions UpdateListenPort and ConfigureWithKeyGen * Ensure we don't wait for timeout when closing * Rename ClosePeerConnection to RemovePeerConnection * Avoid returning on uapi Accept failures * Added engine tests * Remove extra add address code * Adding iface.Close * Ensure Close the interface and disable parallel test execution * check err var when listing interfaces * chore: add synchronisation to peer management * chore: add connection status to track peer connection * refactor: remove unused code Co-authored-by: braginini <hello@wiretrustee.com> Co-authored-by: Mikhail Bragin <bangvalo@gmail.com>
45 lines
1.3 KiB
Go
45 lines
1.3 KiB
Go
package iface
|
|
|
|
import (
|
|
log "github.com/sirupsen/logrus"
|
|
"net"
|
|
"os/exec"
|
|
"strings"
|
|
)
|
|
|
|
// Create Creates a new Wireguard interface, sets a given IP and brings it up.
|
|
func Create(iface string, address string) error {
|
|
return CreateWithUserspace(iface, address)
|
|
}
|
|
|
|
// assignAddr Adds IP address to the tunnel interface and network route based on the range provided
|
|
func assignAddr(address string, ifaceName string) error {
|
|
ip := strings.Split(address, "/")
|
|
cmd := exec.Command("ifconfig", ifaceName, "inet", address, ip[0])
|
|
if out, err := cmd.CombinedOutput(); err != nil {
|
|
log.Infof("Command: %v failed with output %s and error: ", cmd.String(), out)
|
|
return err
|
|
}
|
|
_, resolvedNet, err := net.ParseCIDR(address)
|
|
err = addRoute(ifaceName, resolvedNet)
|
|
if err != nil {
|
|
log.Infoln("Adding route failed with error:", err)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// addRoute Adds network route based on the range provided
|
|
func addRoute(iface string, ipNet *net.IPNet) error {
|
|
cmd := exec.Command("route", "add", "-net", ipNet.String(), "-interface", iface)
|
|
if out, err := cmd.CombinedOutput(); err != nil {
|
|
log.Printf("Command: %v failed with output %s and error: ", cmd.String(), out)
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Closes the tunnel interface
|
|
func Close() error {
|
|
return CloseWithUserspace()
|
|
}
|