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