local.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. package local
  2. import (
  3. //"github.com/davecgh/go-spew/spew"
  4. "errors"
  5. "log"
  6. "net"
  7. "os"
  8. "os/exec"
  9. "runtime"
  10. "strings"
  11. "github.com/gravitl/netmaker/netclient/ncutils"
  12. )
  13. // SetIPForwarding - Sets IP forwarding if it's mac or linux
  14. func SetIPForwarding() error {
  15. os := runtime.GOOS
  16. var err error
  17. switch os {
  18. case "linux":
  19. err = SetIPForwardingUnix()
  20. case "freebsd":
  21. err = SetIPForwardingFreeBSD()
  22. case "darwin":
  23. err = SetIPForwardingMac()
  24. default:
  25. err = errors.New("this OS is not currently supported")
  26. }
  27. return err
  28. }
  29. // SetIPForwardingLinux - sets the ipforwarding for linux
  30. func SetIPForwardingUnix() error {
  31. // ipv4
  32. out, err := ncutils.RunCmd("sysctl net.ipv4.ip_forward", true)
  33. if err != nil {
  34. log.Println("WARNING: Error encountered setting ip forwarding. This can break functionality.")
  35. return err
  36. } else {
  37. s := strings.Fields(string(out))
  38. if s[2] != "1" {
  39. _, err = ncutils.RunCmd("sysctl -w net.ipv4.ip_forward=1", true)
  40. if err != nil {
  41. log.Println("WARNING: Error encountered setting ip forwarding. You may want to investigate this.")
  42. return err
  43. }
  44. }
  45. }
  46. // ipv6
  47. out, err = ncutils.RunCmd("sysctl net.ipv6.conf.all.forwarding", true)
  48. if err != nil {
  49. log.Println("WARNING: Error encountered setting ipv6 forwarding. This can break functionality.")
  50. return err
  51. } else {
  52. s := strings.Fields(string(out))
  53. if s[2] != "1" {
  54. _, err = ncutils.RunCmd("sysctl -w net.ipv6.conf.all.forwarding=1", true)
  55. if err != nil {
  56. log.Println("WARNING: Error encountered setting ipv6 forwarding. You may want to investigate this.")
  57. return err
  58. }
  59. }
  60. }
  61. return nil
  62. }
  63. // SetIPForwardingLinux - sets the ipforwarding for linux
  64. func SetIPForwardingFreeBSD() error {
  65. out, err := ncutils.RunCmd("sysctl net.inet.ip.forwarding", true)
  66. if err != nil {
  67. log.Println("WARNING: Error encountered setting ip forwarding. This can break functionality.")
  68. return err
  69. } else {
  70. s := strings.Fields(string(out))
  71. if s[1] != "1" {
  72. _, err = ncutils.RunCmd("sysctl -w net.inet.ip.forwarding=1", true)
  73. if err != nil {
  74. log.Println("WARNING: Error encountered setting ip forwarding. You may want to investigate this.")
  75. return err
  76. }
  77. }
  78. }
  79. return nil
  80. }
  81. // SetIPForwardingMac - sets ip forwarding for mac
  82. func SetIPForwardingMac() error {
  83. _, err := ncutils.RunCmd("sysctl -w net.inet.ip.forwarding=1", true)
  84. if err != nil {
  85. log.Println("WARNING: Error encountered setting ip forwarding. This can break functionality.")
  86. }
  87. return err
  88. }
  89. // IsWGInstalled - checks if WireGuard is installed
  90. func IsWGInstalled() bool {
  91. out, err := ncutils.RunCmd("wg help", true)
  92. if err != nil {
  93. _, err = exec.LookPath(os.Getenv("WG_QUICK_USERSPACE_IMPLEMENTATION"))
  94. return err == nil
  95. }
  96. return strings.Contains(out, "Available subcommand")
  97. }
  98. // GetMacIface - gets mac interface
  99. func GetMacIface(ipstring string) (string, error) {
  100. var wgiface string
  101. _, checknet, err := net.ParseCIDR(ipstring + "/24")
  102. if err != nil {
  103. return wgiface, errors.New("could not parse ip " + ipstring)
  104. }
  105. ifaces, err := net.Interfaces()
  106. if err != nil {
  107. return wgiface, err
  108. }
  109. for _, iface := range ifaces {
  110. addrs, err := iface.Addrs()
  111. if err != nil {
  112. continue
  113. }
  114. for _, addr := range addrs {
  115. ip := addr.(*net.IPNet).IP
  116. if checknet.Contains(ip) {
  117. wgiface = iface.Name
  118. break
  119. }
  120. }
  121. }
  122. if wgiface == "" {
  123. err = errors.New("could not find iface for address " + ipstring)
  124. }
  125. return wgiface, err
  126. }
  127. // HasNetwork - checks if a network exists locally
  128. func HasNetwork(network string) bool {
  129. return ncutils.FileExists(ncutils.GetNetclientPathSpecific() + "netconfig-" + network)
  130. }