12345678910111213141516171819202122232425262728293031323334353637383940414243444546 |
- package acl
- import (
- "fmt"
- "log"
- "strings"
- "github.com/gravitl/netmaker/cli/functions"
- "github.com/gravitl/netmaker/logic/acls"
- "github.com/spf13/cobra"
- )
- var aclAllowCmd = &cobra.Command{
- Use: "allow [NETWORK NAME] [FROM_NODE_NAME] [TO_NODE_NAME]",
- Args: cobra.ExactArgs(3),
- Short: "Allow access from one node to another",
- Long: `Allow access from one node to another`,
- Run: func(cmd *cobra.Command, args []string) {
- nameIDMap := make(map[string]string)
- for _, node := range *functions.GetNodes(args[0]) {
- nameIDMap[strings.ToLower(node.Name)] = node.ID
- }
- fromNodeID, ok := nameIDMap[strings.ToLower(args[1])]
- if !ok {
- log.Fatalf("Node %s doesn't exist", args[1])
- }
- toNodeID, ok := nameIDMap[strings.ToLower(args[2])]
- if !ok {
- log.Fatalf("Node %s doesn't exist", args[2])
- }
- payload := acls.ACLContainer(map[acls.AclID]acls.ACL{
- acls.AclID(fromNodeID): map[acls.AclID]byte{
- acls.AclID(toNodeID): acls.Allowed,
- },
- acls.AclID(toNodeID): map[acls.AclID]byte{
- acls.AclID(fromNodeID): acls.Allowed,
- },
- })
- functions.UpdateACL(args[0], &payload)
- fmt.Println("Success")
- },
- }
- func init() {
- rootCmd.AddCommand(aclAllowCmd)
- }
|