networks.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744
  1. package logic
  2. import (
  3. "encoding/binary"
  4. "encoding/json"
  5. "errors"
  6. "fmt"
  7. "net"
  8. "os/exec"
  9. "strings"
  10. "github.com/go-playground/validator/v10"
  11. "github.com/gravitl/netmaker/database"
  12. "github.com/gravitl/netmaker/logger"
  13. nodeacls "github.com/gravitl/netmaker/logic/acls/node-acls"
  14. "github.com/gravitl/netmaker/models"
  15. "github.com/gravitl/netmaker/netclient/ncutils"
  16. "github.com/gravitl/netmaker/validation"
  17. )
  18. // GetNetworks - returns all networks from database
  19. func GetNetworks() ([]models.Network, error) {
  20. var networks []models.Network
  21. collection, err := database.FetchRecords(database.NETWORKS_TABLE_NAME)
  22. if err != nil {
  23. return networks, err
  24. }
  25. for _, value := range collection {
  26. var network models.Network
  27. if err := json.Unmarshal([]byte(value), &network); err != nil {
  28. return networks, err
  29. }
  30. // add network our array
  31. networks = append(networks, network)
  32. }
  33. return networks, err
  34. }
  35. // DeleteNetwork - deletes a network
  36. func DeleteNetwork(network string) error {
  37. // remove ACL for network
  38. err := nodeacls.DeleteACLContainer(nodeacls.NetworkID(network))
  39. if err != nil {
  40. logger.Log(1, "failed to remove the node acls during network delete for network,", network)
  41. }
  42. nodeCount, err := GetNetworkNonServerNodeCount(network)
  43. if nodeCount == 0 || database.IsEmptyRecord(err) {
  44. // delete server nodes first then db records
  45. servers, err := GetSortedNetworkServerNodes(network)
  46. if err == nil {
  47. for _, s := range servers {
  48. if err = DeleteNodeByID(&s, true); err != nil {
  49. logger.Log(2, "could not removed server", s.Name, "before deleting network", network)
  50. } else {
  51. logger.Log(2, "removed server", s.Name, "before deleting network", network)
  52. }
  53. }
  54. } else {
  55. logger.Log(1, "could not remove servers before deleting network", network)
  56. }
  57. return database.DeleteRecord(database.NETWORKS_TABLE_NAME, network)
  58. }
  59. return errors.New("node check failed. All nodes must be deleted before deleting network")
  60. }
  61. // CreateNetwork - creates a network in database
  62. func CreateNetwork(network models.Network) error {
  63. network.SetDefaults()
  64. network.SetNodesLastModified()
  65. network.SetNetworkLastModified()
  66. err := ValidateNetwork(&network, false)
  67. if err != nil {
  68. //returnErrorResponse(w, r, formatError(err, "badrequest"))
  69. return err
  70. }
  71. data, err := json.Marshal(&network)
  72. if err != nil {
  73. return err
  74. }
  75. if err = database.Insert(network.NetID, string(data), database.NETWORKS_TABLE_NAME); err != nil {
  76. return err
  77. }
  78. return err
  79. }
  80. // NetworkNodesUpdatePullChanges - tells nodes on network to pull
  81. func NetworkNodesUpdatePullChanges(networkName string) error {
  82. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  83. if err != nil {
  84. if database.IsEmptyRecord(err) {
  85. return nil
  86. }
  87. return err
  88. }
  89. for _, value := range collections {
  90. var node models.Node
  91. err := json.Unmarshal([]byte(value), &node)
  92. if err != nil {
  93. fmt.Println("error in node address assignment!")
  94. return err
  95. }
  96. if node.Network == networkName {
  97. data, err := json.Marshal(&node)
  98. if err != nil {
  99. return err
  100. }
  101. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  102. }
  103. }
  104. return nil
  105. }
  106. // GetNetworkNonServerNodeCount - get number of network non server nodes
  107. func GetNetworkNonServerNodeCount(networkName string) (int, error) {
  108. collection, err := database.FetchRecords(database.NODES_TABLE_NAME)
  109. count := 0
  110. if err != nil && !database.IsEmptyRecord(err) {
  111. return count, err
  112. }
  113. for _, value := range collection {
  114. var node models.Node
  115. if err = json.Unmarshal([]byte(value), &node); err != nil {
  116. return count, err
  117. } else {
  118. if node.Network == networkName && node.IsServer != "yes" {
  119. count++
  120. }
  121. }
  122. }
  123. return count, nil
  124. }
  125. // GetParentNetwork - get parent network
  126. func GetParentNetwork(networkname string) (models.Network, error) {
  127. var network models.Network
  128. networkData, err := database.FetchRecord(database.NETWORKS_TABLE_NAME, networkname)
  129. if err != nil {
  130. return network, err
  131. }
  132. if err = json.Unmarshal([]byte(networkData), &network); err != nil {
  133. return models.Network{}, err
  134. }
  135. return network, nil
  136. }
  137. // GetParentNetwork - get parent network
  138. func GetNetworkSettings(networkname string) (models.Network, error) {
  139. var network models.Network
  140. networkData, err := database.FetchRecord(database.NETWORKS_TABLE_NAME, networkname)
  141. if err != nil {
  142. return network, err
  143. }
  144. if err = json.Unmarshal([]byte(networkData), &network); err != nil {
  145. return models.Network{}, err
  146. }
  147. network.AccessKeys = []models.AccessKey{}
  148. return network, nil
  149. }
  150. // UniqueAddress - see if address is unique
  151. func UniqueAddress(networkName string) (string, error) {
  152. var network models.Network
  153. network, err := GetParentNetwork(networkName)
  154. if err != nil {
  155. fmt.Println("UniqueAddress encountered an error")
  156. return "666", err
  157. }
  158. offset := true
  159. ip, ipnet, err := net.ParseCIDR(network.AddressRange)
  160. if err != nil {
  161. fmt.Println("UniqueAddress encountered an error")
  162. return "666", err
  163. }
  164. for ip := ip.Mask(ipnet.Mask); ipnet.Contains(ip); Inc(ip) {
  165. if offset {
  166. offset = false
  167. continue
  168. }
  169. if IsIPUnique(networkName, ip.String(), database.NODES_TABLE_NAME, false) && IsIPUnique(networkName, ip.String(), database.EXT_CLIENT_TABLE_NAME, false) {
  170. return ip.String(), err
  171. }
  172. }
  173. //TODO
  174. err1 := errors.New("ERROR: No unique addresses available. Check network subnet")
  175. return "W1R3: NO UNIQUE ADDRESSES AVAILABLE", err1
  176. }
  177. // UniqueAddressServer - get unique address starting from last available
  178. func UniqueAddressServer(networkName string) (string, error) {
  179. var network models.Network
  180. network, err := GetParentNetwork(networkName)
  181. if err != nil {
  182. logger.Log(0, "UniqueAddressServer encountered an error")
  183. return "666", err
  184. }
  185. _, ipv4Net, err := net.ParseCIDR(network.AddressRange)
  186. if err != nil {
  187. logger.Log(0, "UniqueAddressServer encountered an error")
  188. return "666", err
  189. }
  190. // convert IPNet struct mask and address to uint32
  191. // network is BigEndian
  192. mask := binary.BigEndian.Uint32(ipv4Net.Mask)
  193. start := binary.BigEndian.Uint32(ipv4Net.IP)
  194. // find the final address
  195. finish := (start & mask) | (mask ^ 0xffffffff)
  196. // loop through addresses as uint32
  197. for i := finish - 1; i > start; i-- {
  198. // convert back to net.IP
  199. ip := make(net.IP, 4)
  200. binary.BigEndian.PutUint32(ip, i)
  201. if IsIPUnique(networkName, ip.String(), database.NODES_TABLE_NAME, false) && IsIPUnique(networkName, ip.String(), database.EXT_CLIENT_TABLE_NAME, false) {
  202. return ip.String(), err
  203. }
  204. }
  205. return "W1R3: NO UNIQUE ADDRESSES AVAILABLE", fmt.Errorf("no unique server addresses found")
  206. }
  207. // IsIPUnique - checks if an IP is unique
  208. func IsIPUnique(network string, ip string, tableName string, isIpv6 bool) bool {
  209. isunique := true
  210. collection, err := database.FetchRecords(tableName)
  211. if err != nil {
  212. return isunique
  213. }
  214. for _, value := range collection { // filter
  215. var node models.Node
  216. if err = json.Unmarshal([]byte(value), &node); err != nil {
  217. continue
  218. }
  219. if isIpv6 {
  220. if node.Address6 == ip && node.Network == network {
  221. return false
  222. }
  223. } else {
  224. if node.Address == ip && node.Network == network {
  225. return false
  226. }
  227. }
  228. }
  229. return isunique
  230. }
  231. // UniqueAddress6 - see if ipv6 address is unique
  232. func UniqueAddress6(networkName string) (string, error) {
  233. var network models.Network
  234. network, err := GetParentNetwork(networkName)
  235. if err != nil {
  236. fmt.Println("Network Not Found")
  237. return "", err
  238. }
  239. if network.IsDualStack == "no" {
  240. return "", nil
  241. }
  242. offset := true
  243. ip, ipnet, err := net.ParseCIDR(network.AddressRange6)
  244. if err != nil {
  245. fmt.Println("UniqueAddress6 encountered an error")
  246. return "666", err
  247. }
  248. for ip := ip.Mask(ipnet.Mask); ipnet.Contains(ip); Inc(ip) {
  249. if offset {
  250. offset = false
  251. continue
  252. }
  253. if IsIPUnique(networkName, ip.String(), database.NODES_TABLE_NAME, true) {
  254. return ip.String(), err
  255. }
  256. }
  257. //TODO
  258. err1 := errors.New("ERROR: No unique addresses available. Check network subnet")
  259. return "W1R3: NO UNIQUE ADDRESSES AVAILABLE", err1
  260. }
  261. // GetLocalIP - gets the local ip
  262. func GetLocalIP(node models.Node) string {
  263. var local string
  264. ifaces, err := net.Interfaces()
  265. if err != nil {
  266. return local
  267. }
  268. _, localrange, err := net.ParseCIDR(node.LocalRange)
  269. if err != nil {
  270. return local
  271. }
  272. found := false
  273. for _, i := range ifaces {
  274. if i.Flags&net.FlagUp == 0 {
  275. continue // interface down
  276. }
  277. if i.Flags&net.FlagLoopback != 0 {
  278. continue // loopback interface
  279. }
  280. addrs, err := i.Addrs()
  281. if err != nil {
  282. return local
  283. }
  284. for _, addr := range addrs {
  285. var ip net.IP
  286. switch v := addr.(type) {
  287. case *net.IPNet:
  288. if !found {
  289. ip = v.IP
  290. local = ip.String()
  291. if node.IsLocal == "yes" {
  292. found = localrange.Contains(ip)
  293. } else {
  294. found = true
  295. }
  296. }
  297. case *net.IPAddr:
  298. if !found {
  299. ip = v.IP
  300. local = ip.String()
  301. if node.IsLocal == "yes" {
  302. found = localrange.Contains(ip)
  303. } else {
  304. found = true
  305. }
  306. }
  307. }
  308. }
  309. }
  310. return local
  311. }
  312. // UpdateNetworkLocalAddresses - updates network localaddresses
  313. func UpdateNetworkLocalAddresses(networkName string) error {
  314. collection, err := database.FetchRecords(database.NODES_TABLE_NAME)
  315. if err != nil {
  316. return err
  317. }
  318. for _, value := range collection {
  319. var node models.Node
  320. err := json.Unmarshal([]byte(value), &node)
  321. if err != nil {
  322. fmt.Println("error in node address assignment!")
  323. return err
  324. }
  325. if node.Network == networkName {
  326. var ipaddr string
  327. var iperr error
  328. if node.IsServer == "yes" {
  329. ipaddr, iperr = UniqueAddressServer(networkName)
  330. } else {
  331. ipaddr, iperr = UniqueAddress(networkName)
  332. }
  333. if iperr != nil {
  334. fmt.Println("error in node address assignment!")
  335. return iperr
  336. }
  337. node.Address = ipaddr
  338. newNodeData, err := json.Marshal(&node)
  339. if err != nil {
  340. logger.Log(1, "error in node address assignment!")
  341. return err
  342. }
  343. database.Insert(node.ID, string(newNodeData), database.NODES_TABLE_NAME)
  344. }
  345. }
  346. return nil
  347. }
  348. // UpdateNetworkLocalAddresses - updates network localaddresses
  349. func UpdateNetworkHolePunching(networkName string, holepunch string) error {
  350. nodes, err := GetNetworkNodes(networkName)
  351. if err != nil {
  352. return err
  353. }
  354. for _, node := range nodes {
  355. if node.IsServer != "yes" {
  356. node.UDPHolePunch = holepunch
  357. newNodeData, err := json.Marshal(&node)
  358. if err != nil {
  359. logger.Log(1, "error in node hole punch assignment")
  360. return err
  361. }
  362. database.Insert(node.ID, string(newNodeData), database.NODES_TABLE_NAME)
  363. }
  364. }
  365. return nil
  366. }
  367. // RemoveNetworkNodeIPv6Addresses - removes network node IPv6 addresses
  368. func RemoveNetworkNodeIPv6Addresses(networkName string) error {
  369. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  370. if err != nil {
  371. return err
  372. }
  373. for _, value := range collections {
  374. var node models.Node
  375. err := json.Unmarshal([]byte(value), &node)
  376. if err != nil {
  377. fmt.Println("error in node address assignment!")
  378. return err
  379. }
  380. if node.Network == networkName {
  381. node.IsDualStack = "no"
  382. node.Address6 = ""
  383. data, err := json.Marshal(&node)
  384. if err != nil {
  385. return err
  386. }
  387. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  388. }
  389. }
  390. return nil
  391. }
  392. // UpdateNetworkNodeAddresses - updates network node addresses
  393. func UpdateNetworkNodeAddresses(networkName string) error {
  394. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  395. if err != nil {
  396. return err
  397. }
  398. for _, value := range collections {
  399. var node models.Node
  400. err := json.Unmarshal([]byte(value), &node)
  401. if err != nil {
  402. fmt.Println("error in node address assignment!")
  403. return err
  404. }
  405. if node.Network == networkName {
  406. var ipaddr string
  407. var iperr error
  408. if node.IsServer == "yes" {
  409. ipaddr, iperr = UniqueAddressServer(networkName)
  410. } else {
  411. ipaddr, iperr = UniqueAddress(networkName)
  412. }
  413. if iperr != nil {
  414. fmt.Println("error in node address assignment!")
  415. return iperr
  416. }
  417. node.Address = ipaddr
  418. data, err := json.Marshal(&node)
  419. if err != nil {
  420. return err
  421. }
  422. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  423. }
  424. }
  425. return nil
  426. }
  427. // IsNetworkNameUnique - checks to see if any other networks have the same name (id)
  428. func IsNetworkNameUnique(network *models.Network) (bool, error) {
  429. isunique := true
  430. dbs, err := GetNetworks()
  431. if err != nil && !database.IsEmptyRecord(err) {
  432. return false, err
  433. }
  434. for i := 0; i < len(dbs); i++ {
  435. if network.NetID == dbs[i].NetID {
  436. isunique = false
  437. }
  438. }
  439. return isunique, nil
  440. }
  441. // UpdateNetwork - updates a network with another network's fields
  442. func UpdateNetwork(currentNetwork *models.Network, newNetwork *models.Network) (bool, bool, bool, error) {
  443. if err := ValidateNetwork(newNetwork, true); err != nil {
  444. return false, false, false, err
  445. }
  446. if newNetwork.NetID == currentNetwork.NetID {
  447. hasrangeupdate := newNetwork.AddressRange != currentNetwork.AddressRange
  448. localrangeupdate := newNetwork.LocalRange != currentNetwork.LocalRange
  449. hasholepunchupdate := newNetwork.DefaultUDPHolePunch != currentNetwork.DefaultUDPHolePunch
  450. data, err := json.Marshal(newNetwork)
  451. if err != nil {
  452. return false, false, false, err
  453. }
  454. newNetwork.SetNetworkLastModified()
  455. err = database.Insert(newNetwork.NetID, string(data), database.NETWORKS_TABLE_NAME)
  456. return hasrangeupdate, localrangeupdate, hasholepunchupdate, err
  457. }
  458. // copy values
  459. return false, false, false, errors.New("failed to update network " + newNetwork.NetID + ", cannot change netid.")
  460. }
  461. // Inc - increments an IP
  462. func Inc(ip net.IP) {
  463. for j := len(ip) - 1; j >= 0; j-- {
  464. ip[j]++
  465. if ip[j] > 0 {
  466. break
  467. }
  468. }
  469. }
  470. // GetNetwork - gets a network from database
  471. func GetNetwork(networkname string) (models.Network, error) {
  472. var network models.Network
  473. networkData, err := database.FetchRecord(database.NETWORKS_TABLE_NAME, networkname)
  474. if err != nil {
  475. return network, err
  476. }
  477. if err = json.Unmarshal([]byte(networkData), &network); err != nil {
  478. return models.Network{}, err
  479. }
  480. return network, nil
  481. }
  482. // Network.NetIDInNetworkCharSet - checks if a netid of a network uses valid characters
  483. func NetIDInNetworkCharSet(network *models.Network) bool {
  484. charset := "abcdefghijklmnopqrstuvwxyz1234567890-_."
  485. for _, char := range network.NetID {
  486. if !strings.Contains(charset, strings.ToLower(string(char))) {
  487. return false
  488. }
  489. }
  490. return true
  491. }
  492. // Network.Validate - validates fields of an network struct
  493. func ValidateNetwork(network *models.Network, isUpdate bool) error {
  494. v := validator.New()
  495. _ = v.RegisterValidation("netid_valid", func(fl validator.FieldLevel) bool {
  496. inCharSet := NetIDInNetworkCharSet(network)
  497. if isUpdate {
  498. return inCharSet
  499. }
  500. isFieldUnique, _ := IsNetworkNameUnique(network)
  501. return isFieldUnique && inCharSet
  502. })
  503. //
  504. _ = v.RegisterValidation("checkyesorno", func(fl validator.FieldLevel) bool {
  505. return validation.CheckYesOrNo(fl)
  506. })
  507. err := v.Struct(network)
  508. if err != nil {
  509. for _, e := range err.(validator.ValidationErrors) {
  510. fmt.Println(e)
  511. }
  512. }
  513. return err
  514. }
  515. // ParseNetwork - parses a network into a model
  516. func ParseNetwork(value string) (models.Network, error) {
  517. var network models.Network
  518. err := json.Unmarshal([]byte(value), &network)
  519. return network, err
  520. }
  521. // ValidateNetworkUpdate - checks if network is valid to update
  522. func ValidateNetworkUpdate(network models.Network) error {
  523. v := validator.New()
  524. _ = v.RegisterValidation("netid_valid", func(fl validator.FieldLevel) bool {
  525. if fl.Field().String() == "" {
  526. return true
  527. }
  528. inCharSet := nameInNetworkCharSet(fl.Field().String())
  529. return inCharSet
  530. })
  531. err := v.Struct(network)
  532. if err != nil {
  533. for _, e := range err.(validator.ValidationErrors) {
  534. logger.Log(1, "validator", e.Error())
  535. }
  536. }
  537. return err
  538. }
  539. // KeyUpdate - updates keys on network
  540. func KeyUpdate(netname string) (models.Network, error) {
  541. err := networkNodesUpdateAction(netname, models.NODE_UPDATE_KEY)
  542. if err != nil {
  543. return models.Network{}, err
  544. }
  545. return models.Network{}, nil
  546. }
  547. //SaveNetwork - save network struct to database
  548. func SaveNetwork(network *models.Network) error {
  549. data, err := json.Marshal(network)
  550. if err != nil {
  551. return err
  552. }
  553. if err := database.Insert(network.NetID, string(data), database.NETWORKS_TABLE_NAME); err != nil {
  554. return err
  555. }
  556. return nil
  557. }
  558. // == Private ==
  559. func networkNodesUpdateAction(networkName string, action string) error {
  560. collections, err := database.FetchRecords(database.NODES_TABLE_NAME)
  561. if err != nil {
  562. if database.IsEmptyRecord(err) {
  563. return nil
  564. }
  565. return err
  566. }
  567. for _, value := range collections {
  568. var node models.Node
  569. err := json.Unmarshal([]byte(value), &node)
  570. if err != nil {
  571. fmt.Println("error in node address assignment!")
  572. return err
  573. }
  574. if action == models.NODE_UPDATE_KEY && node.IsStatic == "yes" {
  575. continue
  576. }
  577. if node.Network == networkName {
  578. node.Action = action
  579. data, err := json.Marshal(&node)
  580. if err != nil {
  581. return err
  582. }
  583. database.Insert(node.ID, string(data), database.NODES_TABLE_NAME)
  584. }
  585. }
  586. return nil
  587. }
  588. func nameInNetworkCharSet(name string) bool {
  589. charset := "abcdefghijklmnopqrstuvwxyz1234567890-_."
  590. for _, char := range name {
  591. if !strings.Contains(charset, strings.ToLower(string(char))) {
  592. return false
  593. }
  594. }
  595. return true
  596. }
  597. func deleteInterface(ifacename string, postdown string) error {
  598. var err error
  599. if !ncutils.IsKernel() {
  600. err = RemoveConf(ifacename, true)
  601. } else {
  602. ipExec, errN := exec.LookPath("ip")
  603. err = errN
  604. if err != nil {
  605. logger.Log(1, err.Error())
  606. }
  607. _, err = ncutils.RunCmd(ipExec+" link del "+ifacename, false)
  608. if postdown != "" {
  609. runcmds := strings.Split(postdown, "; ")
  610. err = ncutils.RunCmds(runcmds, false)
  611. }
  612. }
  613. return err
  614. }
  615. func isInterfacePresent(iface string, address string) (string, bool) {
  616. var interfaces []net.Interface
  617. var err error
  618. interfaces, err = net.Interfaces()
  619. if err != nil {
  620. logger.Log(0, "ERROR: could not read interfaces")
  621. return "", true
  622. }
  623. for _, currIface := range interfaces {
  624. var currAddrs []net.Addr
  625. currAddrs, err = currIface.Addrs()
  626. if err != nil || len(currAddrs) == 0 {
  627. continue
  628. }
  629. for _, addr := range currAddrs {
  630. if strings.Contains(addr.String(), address) && currIface.Name != iface {
  631. // logger.Log(2, "found iface", addr.String(), currIface.Name)
  632. interfaces = nil
  633. currAddrs = nil
  634. return currIface.Name, false
  635. }
  636. }
  637. currAddrs = nil
  638. }
  639. interfaces = nil
  640. // logger.Log(2, "failed to find iface", iface)
  641. return "", true
  642. }