sqlite.go 3.4 KB

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