flags.go 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. package cli_options
  2. import "github.com/urfave/cli/v2"
  3. // GetFlags - Returns the flags used by cli
  4. func GetFlags(hostname string) []cli.Flag {
  5. return []cli.Flag{
  6. &cli.StringFlag{
  7. Name: "network",
  8. Aliases: []string{"n"},
  9. EnvVars: []string{"NETCLIENT_NETWORK"},
  10. Value: "all",
  11. Usage: "Network to perform specified action against.",
  12. },
  13. &cli.StringFlag{
  14. Name: "password",
  15. Aliases: []string{"p"},
  16. EnvVars: []string{"NETCLIENT_PASSWORD"},
  17. Value: "",
  18. Usage: "Password for authenticating with netmaker.",
  19. },
  20. &cli.StringFlag{
  21. Name: "endpoint",
  22. Aliases: []string{"e"},
  23. EnvVars: []string{"NETCLIENT_ENDPOINT"},
  24. Value: "",
  25. Usage: "Reachable (usually public) address for WireGuard (not the private WG address).",
  26. },
  27. &cli.StringFlag{
  28. Name: "macaddress",
  29. Aliases: []string{"m"},
  30. EnvVars: []string{"NETCLIENT_MACADDRESS"},
  31. Value: "",
  32. Usage: "Mac Address for this machine. Used as a unique identifier within Netmaker network.",
  33. },
  34. &cli.StringFlag{
  35. Name: "publickey",
  36. Aliases: []string{"pubkey"},
  37. EnvVars: []string{"NETCLIENT_PUBLICKEY"},
  38. Value: "",
  39. Usage: "Public Key for WireGuard Interface.",
  40. },
  41. &cli.StringFlag{
  42. Name: "privatekey",
  43. Aliases: []string{"privkey"},
  44. EnvVars: []string{"NETCLIENT_PRIVATEKEY"},
  45. Value: "",
  46. Usage: "Private Key for WireGuard Interface.",
  47. },
  48. &cli.StringFlag{
  49. Name: "port",
  50. EnvVars: []string{"NETCLIENT_PORT"},
  51. Value: "",
  52. Usage: "Port for WireGuard Interface.",
  53. },
  54. &cli.IntFlag{
  55. Name: "keepalive",
  56. EnvVars: []string{"NETCLIENT_KEEPALIVE"},
  57. Value: 0,
  58. Usage: "Default PersistentKeepAlive for Peers in WireGuard Interface.",
  59. },
  60. &cli.StringFlag{
  61. Name: "operatingsystem",
  62. Aliases: []string{"os"},
  63. EnvVars: []string{"NETCLIENT_OS"},
  64. Value: "",
  65. Usage: "Identifiable name for machine within Netmaker network.",
  66. },
  67. &cli.StringFlag{
  68. Name: "name",
  69. EnvVars: []string{"NETCLIENT_NAME"},
  70. Value: hostname,
  71. Usage: "Identifiable name for machine within Netmaker network.",
  72. },
  73. &cli.StringFlag{
  74. Name: "localaddress",
  75. EnvVars: []string{"NETCLIENT_LOCALADDRESS"},
  76. Value: "",
  77. Usage: "Local address for machine. Can be used in place of Endpoint for machines on the same LAN.",
  78. },
  79. &cli.StringFlag{
  80. Name: "isstatic",
  81. Aliases: []string{"st"},
  82. EnvVars: []string{"NETCLIENT_IS_STATIC"},
  83. Value: "",
  84. Usage: "Indicates if client is static by default (will not change addresses automatically).",
  85. },
  86. &cli.StringFlag{
  87. Name: "address",
  88. Aliases: []string{"a"},
  89. EnvVars: []string{"NETCLIENT_ADDRESS"},
  90. Value: "",
  91. Usage: "WireGuard address for machine within Netmaker network.",
  92. },
  93. &cli.StringFlag{
  94. Name: "addressIPv6",
  95. Aliases: []string{"a6"},
  96. EnvVars: []string{"NETCLIENT_ADDRESSIPV6"},
  97. Value: "",
  98. Usage: "WireGuard address for machine within Netmaker network.",
  99. },
  100. &cli.StringFlag{
  101. Name: "interface",
  102. Aliases: []string{"i"},
  103. EnvVars: []string{"NETCLIENT_INTERFACE"},
  104. Value: "",
  105. Usage: "WireGuard local network interface name.",
  106. },
  107. &cli.StringFlag{
  108. Name: "apiserver",
  109. EnvVars: []string{"NETCLIENT_API_SERVER"},
  110. Value: "",
  111. Usage: "Address + GRPC Port (e.g. 1.2.3.4:50051) of Netmaker server.",
  112. },
  113. &cli.StringFlag{
  114. Name: "grpcserver",
  115. EnvVars: []string{"NETCLIENT_GRPC_SERVER"},
  116. Value: "",
  117. Usage: "Address + API Port (e.g. 1.2.3.4:8081) of Netmaker server.",
  118. },
  119. &cli.StringFlag{
  120. Name: "grpcssl",
  121. EnvVars: []string{"NETCLIENT_GRPCSSL"},
  122. Value: "",
  123. Usage: "Tells clients to use SSL to connect to GRPC if 'on'. Disable if 'off'. Off by default.",
  124. },
  125. &cli.StringFlag{
  126. Name: "key",
  127. Aliases: []string{"k"},
  128. EnvVars: []string{"NETCLIENT_ACCESSKEY"},
  129. Value: "",
  130. Usage: "Access Key for signing up machine with Netmaker server during initial 'add'.",
  131. },
  132. &cli.StringFlag{
  133. Name: "token",
  134. Aliases: []string{"t"},
  135. EnvVars: []string{"NETCLIENT_ACCESSTOKEN"},
  136. Value: "",
  137. Usage: "Access Token for signing up machine with Netmaker server during initial 'add'.",
  138. },
  139. &cli.StringFlag{
  140. Name: "localrange",
  141. EnvVars: []string{"NETCLIENT_LOCALRANGE"},
  142. Value: "",
  143. Usage: "Local Range if network is local, for instance 192.168.1.0/24.",
  144. },
  145. &cli.StringFlag{
  146. Name: "dnson",
  147. EnvVars: []string{"NETCLIENT_DNS"},
  148. Value: "yes",
  149. Usage: "Sets private dns if 'yes'. Ignores if 'no'. Will retrieve from network if unset.",
  150. },
  151. &cli.StringFlag{
  152. Name: "islocal",
  153. EnvVars: []string{"NETCLIENT_IS_LOCAL"},
  154. Value: "",
  155. Usage: "Sets endpoint to local address if 'yes'. Ignores if 'no'. Will retrieve from network if unset.",
  156. },
  157. &cli.StringFlag{
  158. Name: "isdualstack",
  159. EnvVars: []string{"NETCLIENT_IS_DUALSTACK"},
  160. Value: "",
  161. Usage: "Sets ipv6 address if 'yes'. Ignores if 'no'. Will retrieve from network if unset.",
  162. },
  163. &cli.StringFlag{
  164. Name: "udpholepunch",
  165. EnvVars: []string{"NETCLIENT_UDP_HOLEPUNCH"},
  166. Value: "",
  167. Usage: "Turns on udp holepunching if 'yes'. Ignores if 'no'. Will retrieve from network if unset.",
  168. },
  169. &cli.StringFlag{
  170. Name: "ipforwarding",
  171. EnvVars: []string{"NETCLIENT_IPFORWARDING"},
  172. Value: "on",
  173. Usage: "Sets ip forwarding on if 'on'. Ignores if 'off'. On by default.",
  174. },
  175. &cli.StringFlag{
  176. Name: "postup",
  177. EnvVars: []string{"NETCLIENT_POSTUP"},
  178. Value: "",
  179. Usage: "Sets PostUp command for WireGuard.",
  180. },
  181. &cli.StringFlag{
  182. Name: "postdown",
  183. EnvVars: []string{"NETCLIENT_POSTDOWN"},
  184. Value: "",
  185. Usage: "Sets PostDown command for WireGuard.",
  186. },
  187. &cli.StringFlag{
  188. Name: "daemon",
  189. EnvVars: []string{"NETCLIENT_DAEMON"},
  190. Value: "on",
  191. Usage: "Installs daemon if 'on'. Ignores if 'off'. On by default.",
  192. },
  193. &cli.StringFlag{
  194. Name: "roaming",
  195. EnvVars: []string{"NETCLIENT_ROAMING"},
  196. Value: "yes",
  197. Usage: "Checks for IP changes if 'yes'. Ignores if 'no'. Yes by default.",
  198. },
  199. }
  200. }