sqlite.go 3.0 KB

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