sqlite.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package database
  2. import (
  3. "context"
  4. "database/sql"
  5. "errors"
  6. "github.com/gravitl/netmaker/db"
  7. "time"
  8. _ "github.com/mattn/go-sqlite3" // need to blank import this package
  9. )
  10. // SqliteDB is the db object for sqlite database connections
  11. var SqliteDB *sql.DB
  12. // SQLITE_FUNCTIONS - contains a map of the functions for sqlite
  13. var SQLITE_FUNCTIONS = map[string]interface{}{
  14. INIT_DB: initSqliteDB,
  15. CREATE_TABLE: sqliteCreateTable,
  16. INSERT: sqliteInsert,
  17. INSERT_PEER: sqliteInsertPeer,
  18. DELETE: sqliteDeleteRecord,
  19. DELETE_ALL: sqliteDeleteAllRecords,
  20. FETCH_ALL: sqliteFetchRecords,
  21. CLOSE_DB: sqliteCloseDB,
  22. isConnected: sqliteConnected,
  23. }
  24. func initSqliteDB() error {
  25. gormDB := db.FromContext(db.WithContext(context.TODO()))
  26. var dbOpenErr error
  27. SqliteDB, dbOpenErr = gormDB.DB()
  28. if dbOpenErr != nil {
  29. return dbOpenErr
  30. }
  31. SqliteDB.SetMaxOpenConns(5)
  32. SqliteDB.SetConnMaxLifetime(time.Hour)
  33. return nil
  34. }
  35. func sqliteCreateTable(tableName string) error {
  36. statement, err := SqliteDB.Prepare("CREATE TABLE IF NOT EXISTS " + tableName + " (key TEXT NOT NULL UNIQUE PRIMARY KEY, value TEXT)")
  37. if err != nil {
  38. return err
  39. }
  40. defer statement.Close()
  41. _, err = statement.Exec()
  42. if err != nil {
  43. return err
  44. }
  45. return nil
  46. }
  47. func sqliteInsert(key string, value string, tableName string) error {
  48. if key != "" && value != "" {
  49. insertSQL := "INSERT OR REPLACE INTO " + tableName + " (key, value) VALUES (?, ?)"
  50. statement, err := SqliteDB.Prepare(insertSQL)
  51. if err != nil {
  52. return err
  53. }
  54. defer statement.Close()
  55. _, err = statement.Exec(key, value)
  56. if err != nil {
  57. return err
  58. }
  59. return nil
  60. }
  61. return errors.New("invalid insert " + key + " : " + value)
  62. }
  63. func sqliteInsertPeer(key string, value string) error {
  64. if key != "" && value != "" {
  65. err := sqliteInsert(key, value, PEERS_TABLE_NAME)
  66. if err != nil {
  67. return err
  68. }
  69. return nil
  70. }
  71. return errors.New("invalid peer insert " + key + " : " + value)
  72. }
  73. func sqliteDeleteRecord(tableName string, key string) error {
  74. deleteSQL := "DELETE FROM " + tableName + " WHERE key = \"" + key + "\""
  75. statement, err := SqliteDB.Prepare(deleteSQL)
  76. if err != nil {
  77. return err
  78. }
  79. defer statement.Close()
  80. if _, err = statement.Exec(); err != nil {
  81. return err
  82. }
  83. return nil
  84. }
  85. func sqliteDeleteAllRecords(tableName string) error {
  86. deleteSQL := "DELETE FROM " + tableName
  87. statement, err := SqliteDB.Prepare(deleteSQL)
  88. if err != nil {
  89. return err
  90. }
  91. defer statement.Close()
  92. if _, err = statement.Exec(); err != nil {
  93. return err
  94. }
  95. return nil
  96. }
  97. func sqliteFetchRecords(tableName string) (map[string]string, error) {
  98. row, err := SqliteDB.Query("SELECT * FROM " + tableName + " ORDER BY key")
  99. if err != nil {
  100. return nil, err
  101. }
  102. records := make(map[string]string)
  103. defer row.Close()
  104. for row.Next() { // Iterate and fetch the records from result cursor
  105. var key string
  106. var value string
  107. row.Scan(&key, &value)
  108. records[key] = value
  109. }
  110. if len(records) == 0 {
  111. return nil, errors.New(NO_RECORDS)
  112. }
  113. return records, nil
  114. }
  115. func sqliteCloseDB() {
  116. //SqliteDB.Close()
  117. }
  118. func sqliteConnected() bool {
  119. stats := SqliteDB.Stats()
  120. return stats.OpenConnections > 0
  121. }