helpers.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. package functions
  2. import (
  3. "encoding/json"
  4. "log"
  5. "strings"
  6. "github.com/gravitl/netmaker/database"
  7. "github.com/gravitl/netmaker/logic"
  8. "github.com/gravitl/netmaker/models"
  9. )
  10. // ParseNode - parses a node into a model
  11. func ParseNode(value string) (models.Node, error) {
  12. var node models.Node
  13. err := json.Unmarshal([]byte(value), &node)
  14. return node, err
  15. }
  16. // ParseExtClient - parses an extclient into a model
  17. func ParseExtClient(value string) (models.ExtClient, error) {
  18. var extClient models.ExtClient
  19. err := json.Unmarshal([]byte(value), &extClient)
  20. return extClient, err
  21. }
  22. // ParseIntClient - parses int client
  23. func ParseIntClient(value string) (models.IntClient, error) {
  24. var intClient models.IntClient
  25. err := json.Unmarshal([]byte(value), &intClient)
  26. return intClient, err
  27. }
  28. //Takes in an arbitrary field and value for field and checks to see if any other
  29. //node has that value for the same field within the network
  30. // SliceContains - sees if a slice contains something
  31. func SliceContains(slice []string, item string) bool {
  32. set := make(map[string]struct{}, len(slice))
  33. for _, s := range slice {
  34. set[s] = struct{}{}
  35. }
  36. _, ok := set[item]
  37. return ok
  38. }
  39. // GetPeersList - gets peers for given network
  40. func GetPeersList(networkName string) ([]models.PeersResponse, error) {
  41. var peers []models.PeersResponse
  42. collection, err := database.FetchRecords(database.NODES_TABLE_NAME)
  43. if err != nil {
  44. return peers, err
  45. }
  46. for _, value := range collection {
  47. var peer models.PeersResponse
  48. err := json.Unmarshal([]byte(value), &peer)
  49. if err != nil {
  50. continue // try the rest
  51. }
  52. peers = append(peers, peer)
  53. }
  54. return peers, err
  55. }
  56. // GetIntPeersList - get int peers list
  57. func GetIntPeersList() ([]models.PeersResponse, error) {
  58. var peers []models.PeersResponse
  59. records, err := database.FetchRecords(database.INT_CLIENTS_TABLE_NAME)
  60. if err != nil {
  61. return peers, err
  62. }
  63. // parse the peers
  64. for _, value := range records {
  65. var peer models.PeersResponse
  66. err := json.Unmarshal([]byte(value), &peer)
  67. if err != nil {
  68. log.Fatal(err)
  69. }
  70. // add the node to our node array
  71. //maybe better to just return this? But then that's just GetNodes...
  72. peers = append(peers, peer)
  73. }
  74. return peers, err
  75. }
  76. // GetServerIntClient - get server int client
  77. func GetServerIntClient() (*models.IntClient, error) {
  78. intClients, err := database.FetchRecords(database.INT_CLIENTS_TABLE_NAME)
  79. for _, value := range intClients {
  80. var intClient models.IntClient
  81. err = json.Unmarshal([]byte(value), &intClient)
  82. if err != nil {
  83. return nil, err
  84. }
  85. if intClient.IsServer == "yes" && intClient.Network == "comms" {
  86. return &intClient, nil
  87. }
  88. }
  89. return nil, err
  90. }
  91. // NetworkExists - check if network exists
  92. func NetworkExists(name string) (bool, error) {
  93. var network string
  94. var err error
  95. if network, err = database.FetchRecord(database.NETWORKS_TABLE_NAME, name); err != nil {
  96. return false, err
  97. }
  98. return len(network) > 0, nil
  99. }
  100. // IsNetworkDisplayNameUnique - checks if network display name unique
  101. func IsNetworkDisplayNameUnique(name string) (bool, error) {
  102. isunique := true
  103. dbs, err := logic.GetNetworks()
  104. if err != nil {
  105. return database.IsEmptyRecord(err), err
  106. }
  107. for i := 0; i < len(dbs); i++ {
  108. if name == dbs[i].DisplayName {
  109. isunique = false
  110. }
  111. }
  112. return isunique, nil
  113. }
  114. // IsMacAddressUnique - checks if mac is unique
  115. func IsMacAddressUnique(macaddress string, networkName string) (bool, error) {
  116. _, err := database.FetchRecord(database.NODES_TABLE_NAME, macaddress+"###"+networkName)
  117. if err != nil {
  118. return database.IsEmptyRecord(err), err
  119. }
  120. return true, nil
  121. }
  122. // IsKeyValidGlobal - checks if a key is valid globally
  123. func IsKeyValidGlobal(keyvalue string) bool {
  124. networks, _ := logic.GetNetworks()
  125. var key models.AccessKey
  126. foundkey := false
  127. isvalid := false
  128. for _, network := range networks {
  129. for i := len(network.AccessKeys) - 1; i >= 0; i-- {
  130. currentkey := network.AccessKeys[i]
  131. if currentkey.Value == keyvalue {
  132. key = currentkey
  133. foundkey = true
  134. break
  135. }
  136. }
  137. if foundkey {
  138. break
  139. }
  140. }
  141. if foundkey {
  142. if key.Uses > 0 {
  143. isvalid = true
  144. }
  145. }
  146. return isvalid
  147. }
  148. // NameInDNSCharSet - name in dns char set
  149. func NameInDNSCharSet(name string) bool {
  150. charset := "abcdefghijklmnopqrstuvwxyz1234567890-."
  151. for _, char := range name {
  152. if !strings.Contains(charset, strings.ToLower(string(char))) {
  153. return false
  154. }
  155. }
  156. return true
  157. }
  158. // NameInNodeCharSet - name in node char set
  159. func NameInNodeCharSet(name string) bool {
  160. charset := "abcdefghijklmnopqrstuvwxyz1234567890-"
  161. for _, char := range name {
  162. if !strings.Contains(charset, strings.ToLower(string(char))) {
  163. return false
  164. }
  165. }
  166. return true
  167. }
  168. // RemoveDeletedNode - remove deleted node
  169. func RemoveDeletedNode(nodeid string) bool {
  170. return database.DeleteRecord(database.DELETED_NODES_TABLE_NAME, nodeid) == nil
  171. }
  172. // DeleteAllIntClients - delete all int clients
  173. func DeleteAllIntClients() error {
  174. err := database.DeleteAllRecords(database.INT_CLIENTS_TABLE_NAME)
  175. if err != nil {
  176. return err
  177. }
  178. return nil
  179. }
  180. // GetAllIntClients - get all int clients
  181. func GetAllIntClients() ([]models.IntClient, error) {
  182. var clients []models.IntClient
  183. collection, err := database.FetchRecords(database.INT_CLIENTS_TABLE_NAME)
  184. if err != nil {
  185. return clients, err
  186. }
  187. for _, value := range collection {
  188. var client models.IntClient
  189. err := json.Unmarshal([]byte(value), &client)
  190. if err != nil {
  191. return []models.IntClient{}, err
  192. }
  193. // add node to our array
  194. clients = append(clients, client)
  195. }
  196. return clients, nil
  197. }
  198. // GetAllExtClients - get all ext clients
  199. func GetAllExtClients() ([]models.ExtClient, error) {
  200. var extclients []models.ExtClient
  201. collection, err := database.FetchRecords(database.EXT_CLIENT_TABLE_NAME)
  202. if err != nil {
  203. return extclients, err
  204. }
  205. for _, value := range collection {
  206. var extclient models.ExtClient
  207. err := json.Unmarshal([]byte(value), &extclient)
  208. if err != nil {
  209. return []models.ExtClient{}, err
  210. }
  211. // add node to our array
  212. extclients = append(extclients, extclient)
  213. }
  214. return extclients, nil
  215. }
  216. // DeleteKey - deletes a key
  217. func DeleteKey(network models.Network, i int) {
  218. network.AccessKeys = append(network.AccessKeys[:i],
  219. network.AccessKeys[i+1:]...)
  220. if networkData, err := json.Marshal(&network); err != nil {
  221. return
  222. } else {
  223. database.Insert(network.NetID, string(networkData), database.NETWORKS_TABLE_NAME)
  224. }
  225. }