allow.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. package acl
  2. import (
  3. "fmt"
  4. "log"
  5. "strings"
  6. "github.com/gravitl/netmaker/cli/functions"
  7. "github.com/gravitl/netmaker/logic/acls"
  8. "github.com/spf13/cobra"
  9. )
  10. var aclAllowCmd = &cobra.Command{
  11. Use: "allow [NETWORK NAME] [FROM_NODE_NAME] [TO_NODE_NAME]",
  12. Args: cobra.ExactArgs(3),
  13. Short: "Allow access from one node to another",
  14. Long: `Allow access from one node to another`,
  15. Run: func(cmd *cobra.Command, args []string) {
  16. nameIDMap := make(map[string]string)
  17. for _, node := range *functions.GetNodes(args[0]) {
  18. nameIDMap[strings.ToLower(node.Name)] = node.ID
  19. }
  20. fromNodeID, ok := nameIDMap[strings.ToLower(args[1])]
  21. if !ok {
  22. log.Fatalf("Node %s doesn't exist", args[1])
  23. }
  24. toNodeID, ok := nameIDMap[strings.ToLower(args[2])]
  25. if !ok {
  26. log.Fatalf("Node %s doesn't exist", args[2])
  27. }
  28. payload := acls.ACLContainer(map[acls.AclID]acls.ACL{
  29. acls.AclID(fromNodeID): map[acls.AclID]byte{
  30. acls.AclID(toNodeID): acls.Allowed,
  31. },
  32. acls.AclID(toNodeID): map[acls.AclID]byte{
  33. acls.AclID(fromNodeID): acls.Allowed,
  34. },
  35. })
  36. functions.UpdateACL(args[0], &payload)
  37. fmt.Println("Success")
  38. },
  39. }
  40. func init() {
  41. rootCmd.AddCommand(aclAllowCmd)
  42. }