retrieve.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package nodeacls
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/gravitl/netmaker/logic/acls"
  6. )
  7. // AreNodesAllowed - checks if nodes are allowed to communicate in their network ACL
  8. func AreNodesAllowed(networkID NetworkID, node1, node2 NodeID) bool {
  9. var currentNetworkACL, err = FetchAllACLs(networkID)
  10. if err != nil {
  11. return false
  12. }
  13. var allowed bool
  14. acls.AclMutex.RLock()
  15. allowed = currentNetworkACL[acls.AclID(node1)].IsAllowed(acls.AclID(node2)) && currentNetworkACL[acls.AclID(node2)].IsAllowed(acls.AclID(node1))
  16. acls.AclMutex.RUnlock()
  17. return allowed
  18. }
  19. // FetchNodeACL - fetches a specific node's ACL in a given network
  20. func FetchNodeACL(networkID NetworkID, nodeID NodeID) (acls.ACL, error) {
  21. var currentNetworkACL, err = FetchAllACLs(networkID)
  22. if err != nil {
  23. return nil, err
  24. }
  25. var acl acls.ACL
  26. acls.AclMutex.RLock()
  27. if currentNetworkACL[acls.AclID(nodeID)] == nil {
  28. acls.AclMutex.RUnlock()
  29. return nil, fmt.Errorf("no node ACL present for node %s", nodeID)
  30. }
  31. acl = currentNetworkACL[acls.AclID(nodeID)]
  32. acls.AclMutex.RUnlock()
  33. return acl, nil
  34. }
  35. // FetchNodeACLJson - fetches a node's acl in given network except returns the json string
  36. func FetchNodeACLJson(networkID NetworkID, nodeID NodeID) (acls.ACLJson, error) {
  37. currentNodeACL, err := FetchNodeACL(networkID, nodeID)
  38. if err != nil {
  39. return "", err
  40. }
  41. acls.AclMutex.RLock()
  42. defer acls.AclMutex.RUnlock()
  43. jsonData, err := json.Marshal(&currentNodeACL)
  44. if err != nil {
  45. return "", err
  46. }
  47. return acls.ACLJson(jsonData), nil
  48. }
  49. // FetchAllACLs - fetchs all node
  50. func FetchAllACLs(networkID NetworkID) (acls.ACLContainer, error) {
  51. var err error
  52. var currentNetworkACL acls.ACLContainer
  53. currentNetworkACL, err = currentNetworkACL.Get(acls.ContainerID(networkID))
  54. if err != nil {
  55. return nil, err
  56. }
  57. return currentNetworkACL, nil
  58. }