sqlite.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package database
  2. import (
  3. "database/sql"
  4. "errors"
  5. "log"
  6. "os"
  7. "path/filepath"
  8. _ "github.com/mattn/go-sqlite3"
  9. )
  10. // == sqlite ==
  11. const dbFilename = "netmaker.db"
  12. var SqliteDB *sql.DB
  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. }
  23. func initSqliteDB() error {
  24. // == create db file if not present ==
  25. if _, err := os.Stat("data"); os.IsNotExist(err) {
  26. log.Println("Could not find data directory, creating it.")
  27. os.Mkdir("data", 0644)
  28. }
  29. dbFilePath := filepath.Join("data", dbFilename)
  30. if _, err := os.Stat(dbFilePath); os.IsNotExist(err) {
  31. log.Println("Could not get database file, creating it.")
  32. os.Create(dbFilePath)
  33. }
  34. // == "connect" the database ==
  35. var dbOpenErr error
  36. SqliteDB, dbOpenErr = sql.Open("sqlite3", dbFilePath)
  37. if dbOpenErr != nil {
  38. return dbOpenErr
  39. }
  40. return nil
  41. }
  42. func sqliteCreateTable(tableName string) error {
  43. statement, err := SqliteDB.Prepare("CREATE TABLE IF NOT EXISTS " + tableName + " (key TEXT NOT NULL UNIQUE PRIMARY KEY, value TEXT)")
  44. if err != nil {
  45. return err
  46. }
  47. _, err = statement.Exec()
  48. if err != nil {
  49. return err
  50. }
  51. log.Println(tableName, "table created")
  52. return nil
  53. }
  54. func sqliteInsert(key string, value string, tableName string) error {
  55. if key != "" && value != "" && IsJSONString(value) {
  56. insertSQL := "INSERT OR REPLACE INTO " + tableName + " (key, value) VALUES (?, ?)"
  57. statement, err := SqliteDB.Prepare(insertSQL)
  58. if err != nil {
  59. return err
  60. }
  61. _, err = statement.Exec(key, value)
  62. if err != nil {
  63. return err
  64. }
  65. log.Println("inserted", key, ":", value, "into ", tableName)
  66. return nil
  67. } else {
  68. return errors.New("invalid insert " + key + " : " + value)
  69. }
  70. }
  71. func sqliteInsertPeer(key string, value string) error {
  72. if key != "" && value != "" && IsJSONString(value) {
  73. err := sqliteInsert(key, value, PEERS_TABLE_NAME)
  74. if err != nil {
  75. return err
  76. }
  77. return nil
  78. } else {
  79. return errors.New("invalid peer insert " + key + " : " + value)
  80. }
  81. }
  82. func sqliteDeleteRecord(tableName string, key string) error {
  83. deleteSQL := "DELETE FROM " + tableName + " WHERE key = \"" + key + "\""
  84. statement, err := SqliteDB.Prepare(deleteSQL)
  85. if err != nil {
  86. return err
  87. }
  88. if _, err = statement.Exec(); err != nil {
  89. return err
  90. }
  91. return nil
  92. }
  93. func sqliteDeleteAllRecords(tableName string) error {
  94. deleteSQL := "DELETE FROM " + tableName
  95. statement, err := SqliteDB.Prepare(deleteSQL)
  96. if err != nil {
  97. return err
  98. }
  99. if _, err = statement.Exec(); err != nil {
  100. return err
  101. }
  102. return nil
  103. }
  104. func sqliteFetchRecords(tableName string) (map[string]string, error) {
  105. row, err := SqliteDB.Query("SELECT * FROM " + tableName + " ORDER BY key")
  106. if err != nil {
  107. return nil, err
  108. }
  109. records := make(map[string]string)
  110. defer row.Close()
  111. for row.Next() { // Iterate and fetch the records from result cursor
  112. var key string
  113. var value string
  114. row.Scan(&key, &value)
  115. records[key] = value
  116. }
  117. if len(records) == 0 {
  118. return nil, errors.New(NO_RECORDS)
  119. }
  120. return records, nil
  121. }
  122. func sqliteCloseDB() {
  123. SqliteDB.Close()
  124. }