2020-07-12 14:53:33 -07:00
|
|
|
package chat
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
2020-10-15 17:57:32 -07:00
|
|
|
_ "github.com/mattn/go-sqlite3"
|
2020-10-06 01:07:09 +08:00
|
|
|
"github.com/owncast/owncast/config"
|
|
|
|
"github.com/owncast/owncast/models"
|
|
|
|
"github.com/owncast/owncast/utils"
|
2020-07-12 14:53:33 -07:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _db *sql.DB
|
|
|
|
|
2020-07-15 17:20:47 -07:00
|
|
|
func setupPersistence() {
|
|
|
|
file := config.Config.ChatDatabaseFilePath
|
2020-07-12 14:53:33 -07:00
|
|
|
// Create empty DB file if it doesn't exist.
|
|
|
|
if !utils.DoesFileExists(file) {
|
2020-07-15 17:20:47 -07:00
|
|
|
log.Traceln("Creating new chat history database at", file)
|
2020-07-12 14:53:33 -07:00
|
|
|
|
|
|
|
_, err := os.Create(file)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err.Error())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sqliteDatabase, _ := sql.Open("sqlite3", file)
|
|
|
|
_db = sqliteDatabase
|
|
|
|
createTable(sqliteDatabase)
|
|
|
|
}
|
|
|
|
|
|
|
|
func createTable(db *sql.DB) {
|
|
|
|
createTableSQL := `CREATE TABLE IF NOT EXISTS messages (
|
|
|
|
"id" string NOT NULL PRIMARY KEY,
|
|
|
|
"author" TEXT,
|
|
|
|
"body" TEXT,
|
|
|
|
"messageType" TEXT,
|
|
|
|
"visible" INTEGER,
|
|
|
|
"timestamp" DATE
|
|
|
|
);`
|
|
|
|
|
|
|
|
stmt, err := _db.Prepare(createTableSQL)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
stmt.Exec()
|
|
|
|
}
|
|
|
|
|
|
|
|
func addMessage(message models.ChatMessage) {
|
|
|
|
tx, err := _db.Begin()
|
2020-10-16 15:04:31 -07:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2020-10-14 13:47:39 +02:00
|
|
|
stmt, err := tx.Prepare("INSERT INTO messages(id, author, body, messageType, visible, timestamp) values(?, ?, ?, ?, ?, ?)")
|
2020-07-12 14:53:33 -07:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2020-10-14 13:47:39 +02:00
|
|
|
_, err = stmt.Exec(message.ID, message.Author, message.Body, message.MessageType, 1, message.Timestamp)
|
2020-07-12 14:53:33 -07:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
tx.Commit()
|
|
|
|
|
|
|
|
defer stmt.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func getChatHistory() []models.ChatMessage {
|
|
|
|
history := make([]models.ChatMessage, 0)
|
|
|
|
|
2020-07-15 22:06:24 -07:00
|
|
|
// Get all messages sent within the past day
|
2020-10-16 17:50:00 -07:00
|
|
|
rows, err := _db.Query("SELECT * FROM messages WHERE visible = 1 AND messageType != 'SYSTEM' AND datetime(timestamp) >=datetime('now', '-1 Day')")
|
2020-07-12 14:53:33 -07:00
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
for rows.Next() {
|
|
|
|
var id string
|
|
|
|
var author string
|
|
|
|
var body string
|
|
|
|
var messageType string
|
|
|
|
var visible int
|
|
|
|
var timestamp time.Time
|
|
|
|
|
2020-10-14 13:47:39 +02:00
|
|
|
err = rows.Scan(&id, &author, &body, &messageType, &visible, ×tamp)
|
2020-07-12 14:53:33 -07:00
|
|
|
if err != nil {
|
2020-10-15 17:57:32 -07:00
|
|
|
log.Debugln(err)
|
2020-10-16 13:57:23 -07:00
|
|
|
log.Error("There is a problem with the chat database. Please delete chat.db and restart Owncast.")
|
2020-10-15 17:57:32 -07:00
|
|
|
break
|
2020-07-12 14:53:33 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
message := models.ChatMessage{}
|
|
|
|
message.ID = id
|
|
|
|
message.Author = author
|
|
|
|
message.Body = body
|
|
|
|
message.MessageType = messageType
|
|
|
|
message.Visible = visible == 1
|
|
|
|
message.Timestamp = timestamp
|
|
|
|
|
|
|
|
history = append(history, message)
|
|
|
|
}
|
|
|
|
|
|
|
|
return history
|
|
|
|
}
|