mirror of
https://github.com/gravitl/netmaker.git
synced 2025-10-13 04:24:53 +08:00
47 lines
1.2 KiB
Go
47 lines
1.2 KiB
Go
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)
|
|
}
|