|
@@ -2,6 +2,7 @@ package acl
|
|
|
|
|
|
import (
|
|
import (
|
|
"fmt"
|
|
"fmt"
|
|
|
|
+ "log"
|
|
|
|
|
|
"github.com/gravitl/netmaker/cli/functions"
|
|
"github.com/gravitl/netmaker/cli/functions"
|
|
"github.com/gravitl/netmaker/logic/acls"
|
|
"github.com/gravitl/netmaker/logic/acls"
|
|
@@ -14,17 +15,34 @@ var aclAllowCmd = &cobra.Command{
|
|
Short: "Allow access from one node to another",
|
|
Short: "Allow access from one node to another",
|
|
Long: `Allow access from one node to another`,
|
|
Long: `Allow access from one node to another`,
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
|
|
+ network := args[0]
|
|
fromNodeID := args[1]
|
|
fromNodeID := args[1]
|
|
toNodeID := args[2]
|
|
toNodeID := 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)
|
|
|
|
|
|
+
|
|
|
|
+ if fromNodeID == toNodeID {
|
|
|
|
+ log.Fatal("Cannot allow access from a node to itself")
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // get current acls
|
|
|
|
+ res := functions.GetACL(network)
|
|
|
|
+ if res == nil {
|
|
|
|
+ log.Fatalf("Could not load network ACLs")
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ payload := *res
|
|
|
|
+
|
|
|
|
+ if _, ok := payload[acls.AclID(fromNodeID)]; !ok {
|
|
|
|
+ log.Fatalf("Node %s does not exist", fromNodeID)
|
|
|
|
+ }
|
|
|
|
+ if _, ok := payload[acls.AclID(toNodeID)]; !ok {
|
|
|
|
+ log.Fatalf("Node %s does not exist", toNodeID)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // update acls
|
|
|
|
+ payload[acls.AclID(fromNodeID)][acls.AclID(toNodeID)] = acls.Allowed
|
|
|
|
+ payload[acls.AclID(toNodeID)][acls.AclID(fromNodeID)] = acls.Allowed
|
|
|
|
+
|
|
|
|
+ functions.UpdateACL(network, &payload)
|
|
fmt.Println("Success")
|
|
fmt.Println("Success")
|
|
},
|
|
},
|
|
}
|
|
}
|