network.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * Copyright (c)2019 ZeroTier, Inc.
  3. *
  4. * Use of this software is governed by the Business Source License included
  5. * in the LICENSE.TXT file in the project's root directory.
  6. *
  7. * Change Date: 2023-01-01
  8. *
  9. * On the date above, in accordance with the Business Source License, use
  10. * of this software will be governed by version 2.0 of the Apache License.
  11. */
  12. /****/
  13. package cli
  14. import (
  15. "fmt"
  16. "os"
  17. "strconv"
  18. "zerotier/pkg/zerotier"
  19. )
  20. // Network CLI command
  21. func Network(basePath, authToken string, args []string, jsonOutput bool) {
  22. if len(args) != 1 {
  23. Help()
  24. os.Exit(1)
  25. }
  26. if len(args[0]) != 16 {
  27. fmt.Printf("ERROR: invalid network ID: %s\n", args[0])
  28. os.Exit(1)
  29. }
  30. nwid, err := strconv.ParseUint(args[0], 16, 64)
  31. if err != nil {
  32. fmt.Printf("ERROR: invalid network ID: %s\n", args[0])
  33. os.Exit(1)
  34. }
  35. nwids := fmt.Sprintf("%.16x", nwid)
  36. var network zerotier.APINetwork
  37. apiGet(basePath, authToken, "/network/"+nwids, &network)
  38. if jsonOutput {
  39. fmt.Println(jsonDump(&network))
  40. } else {
  41. fmt.Printf("%s: %s\n", nwids, network.Config.Name)
  42. fmt.Printf("\tstatus:\t%s\n", networkStatusStr(network.Config.Status))
  43. enabled := "no"
  44. if network.PortEnabled {
  45. enabled = "yes"
  46. }
  47. bridge := "no"
  48. if network.Config.Bridge {
  49. bridge = "yes"
  50. }
  51. broadcast := "off"
  52. if network.Config.BroadcastEnabled {
  53. broadcast = "on"
  54. }
  55. fmt.Printf("\tport:\t%s dev %s type %s mtu %d enabled %s bridge %s broadcast %s\n", network.Config.MAC.String(), network.PortName, network.PortType, network.Config.MTU, enabled, bridge, broadcast)
  56. fmt.Printf("\tmanaged addresses:\t")
  57. for i, a := range network.Config.AssignedAddresses {
  58. if i > 0 {
  59. fmt.Print(" ")
  60. }
  61. fmt.Print(a.String())
  62. }
  63. fmt.Printf("\n\tmanaged routes:\t")
  64. for i, r := range network.Config.Routes {
  65. if i > 0 {
  66. fmt.Print(" ")
  67. }
  68. fmt.Print(r.Target.String())
  69. if r.Via == nil {
  70. fmt.Print("->LAN")
  71. } else {
  72. fmt.Printf("->%s", r.Via.String())
  73. }
  74. }
  75. managedIPs := "disabled"
  76. if network.Settings.AllowManagedIPs {
  77. managedIPs = "enabled"
  78. }
  79. managedIPsGlobal := "disabled"
  80. if network.Settings.AllowGlobalIPs {
  81. managedIPsGlobal = "enabled"
  82. }
  83. fmt.Printf("\n\tmanaged address local permissions:\t%s global %s\n", managedIPs, managedIPsGlobal)
  84. managedRoutes := "diabled"
  85. if network.Settings.AllowManagedRoutes {
  86. managedRoutes = "enabled"
  87. }
  88. managedGlobalRoutes := "disabled"
  89. if network.Settings.AllowGlobalRoutes {
  90. managedGlobalRoutes = "enabled"
  91. }
  92. managedDefaultRoute := "disabled"
  93. if network.Settings.AllowDefaultRouteOverride {
  94. managedDefaultRoute = "enabled"
  95. }
  96. fmt.Printf("\tmanaged route local permissions:\t%s global %s default %s\n", managedRoutes, managedGlobalRoutes, managedDefaultRoute)
  97. }
  98. }