nodeGrpcController.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. package controller
  2. import (
  3. "context"
  4. "encoding/json"
  5. "errors"
  6. "strings"
  7. "github.com/gravitl/netmaker/functions"
  8. nodepb "github.com/gravitl/netmaker/grpc"
  9. "github.com/gravitl/netmaker/logic"
  10. "github.com/gravitl/netmaker/models"
  11. )
  12. type NodeServiceServer struct {
  13. nodepb.UnimplementedNodeServiceServer
  14. }
  15. func (s *NodeServiceServer) ReadNode(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  16. // convert string id (from proto) to mongoDB ObjectId
  17. macAndNetwork := strings.Split(req.Data, "###")
  18. if len(macAndNetwork) != 2 {
  19. return nil, errors.New("could not read node, invalid node id given")
  20. }
  21. node, err := GetNode(macAndNetwork[0], macAndNetwork[1])
  22. if err != nil {
  23. return nil, err
  24. }
  25. node.SetLastCheckIn()
  26. // Cast to ReadNodeRes type
  27. nodeData, err := json.Marshal(&node)
  28. if err != nil {
  29. return nil, err
  30. }
  31. node.Update(&node)
  32. response := &nodepb.Object{
  33. Data: string(nodeData),
  34. Type: nodepb.NODE_TYPE,
  35. }
  36. return response, nil
  37. }
  38. func (s *NodeServiceServer) CreateNode(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  39. // Get the protobuf node type from the protobuf request type
  40. // Essentially doing req.Node to access the struct with a nil check
  41. var node models.Node
  42. data := req.GetData()
  43. if err := json.Unmarshal([]byte(data), &node); err != nil {
  44. return nil, err
  45. }
  46. //Check to see if key is valid
  47. //TODO: Triple inefficient!!! This is the third call to the DB we make for networks
  48. validKey := functions.IsKeyValid(node.Network, node.AccessKey)
  49. network, err := functions.GetParentNetwork(node.Network)
  50. if err != nil {
  51. return nil, err
  52. }
  53. if !validKey {
  54. //Check to see if network will allow manual sign up
  55. //may want to switch this up with the valid key check and avoid a DB call that way.
  56. if network.AllowManualSignUp == "yes" {
  57. node.IsPending = "yes"
  58. } else {
  59. return nil, errors.New("invalid key, and network does not allow no-key signups")
  60. }
  61. }
  62. node, err = logic.CreateNode(node, node.Network)
  63. if err != nil {
  64. return nil, err
  65. }
  66. nodeData, err := json.Marshal(&node)
  67. // return the node in a CreateNodeRes type
  68. response := &nodepb.Object{
  69. Data: string(nodeData),
  70. Type: nodepb.NODE_TYPE,
  71. }
  72. err = logic.SetNetworkNodesLastModified(node.Network)
  73. if err != nil {
  74. return nil, err
  75. }
  76. return response, nil
  77. }
  78. func (s *NodeServiceServer) UpdateNode(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  79. // Get the node data from the request
  80. var newnode models.Node
  81. if err := json.Unmarshal([]byte(req.GetData()), &newnode); err != nil {
  82. return nil, err
  83. }
  84. macaddress := newnode.MacAddress
  85. networkName := newnode.Network
  86. node, err := functions.GetNodeByMacAddress(networkName, macaddress)
  87. if err != nil {
  88. return nil, err
  89. }
  90. err = node.Update(&newnode)
  91. if err != nil {
  92. return nil, err
  93. }
  94. nodeData, err := json.Marshal(&newnode)
  95. if err != nil {
  96. return nil, err
  97. }
  98. return &nodepb.Object{
  99. Data: string(nodeData),
  100. Type: nodepb.NODE_TYPE,
  101. }, nil
  102. }
  103. func (s *NodeServiceServer) DeleteNode(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  104. nodeID := req.GetData()
  105. err := DeleteNode(nodeID, true)
  106. if err != nil {
  107. return nil, err
  108. }
  109. return &nodepb.Object{
  110. Data: "success",
  111. Type: nodepb.STRING_TYPE,
  112. }, nil
  113. }
  114. func (s *NodeServiceServer) GetPeers(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  115. macAndNetwork := strings.Split(req.Data, "###")
  116. if len(macAndNetwork) == 2 {
  117. // TODO: Make constant and new variable for isServer
  118. node, err := GetNode(macAndNetwork[0], macAndNetwork[1])
  119. if err != nil {
  120. return nil, err
  121. }
  122. if node.IsServer == "yes" && logic.IsLeader(&node){
  123. logic.SetNetworkServerPeers(&node)
  124. }
  125. excludeIsRelayed := node.IsRelay != "yes"
  126. var relayedNode string
  127. if node.IsRelayed == "yes" {
  128. relayedNode = node.Address
  129. }
  130. peers, err := logic.GetPeersList(macAndNetwork[1], excludeIsRelayed, relayedNode)
  131. if err != nil {
  132. return nil, err
  133. }
  134. peersData, err := json.Marshal(&peers)
  135. functions.PrintUserLog(node.Address, "checked in successfully", 3)
  136. return &nodepb.Object{
  137. Data: string(peersData),
  138. Type: nodepb.NODE_TYPE,
  139. }, err
  140. }
  141. return &nodepb.Object{
  142. Data: "",
  143. Type: nodepb.NODE_TYPE,
  144. }, errors.New("could not fetch peers, invalid node id")
  145. }
  146. /**
  147. * Return Ext Peers (clients).NodeCheckIn
  148. * When a gateway node checks in, it pulls these peers to add to peers list in addition to normal network peers.
  149. */
  150. func (s *NodeServiceServer) GetExtPeers(ctx context.Context, req *nodepb.Object) (*nodepb.Object, error) {
  151. // Initiate a NodeItem type to write decoded data to
  152. //data := &models.PeersResponse{}
  153. // collection.Find returns a cursor for our (empty) query
  154. macAndNetwork := strings.Split(req.Data, "###")
  155. if len(macAndNetwork) != 2 {
  156. return nil, errors.New("did not receive valid node id when fetching ext peers")
  157. }
  158. peers, err := logic.GetExtPeersList(macAndNetwork[0], macAndNetwork[1])
  159. if err != nil {
  160. return nil, err
  161. }
  162. var extPeers []models.Node
  163. for i := 0; i < len(peers); i++ {
  164. extPeers = append(extPeers, models.Node{
  165. Address: peers[i].Address,
  166. Address6: peers[i].Address6,
  167. Endpoint: peers[i].Endpoint,
  168. PublicKey: peers[i].PublicKey,
  169. PersistentKeepalive: peers[i].KeepAlive,
  170. ListenPort: peers[i].ListenPort,
  171. LocalAddress: peers[i].LocalAddress,
  172. })
  173. }
  174. extData, err := json.Marshal(&extPeers)
  175. if err != nil {
  176. return nil, err
  177. }
  178. return &nodepb.Object{
  179. Data: string(extData),
  180. Type: nodepb.EXT_PEER,
  181. }, nil
  182. }