Add archive functionality: database schema, API endpoint, and helper functions
This commit is contained in:
@@ -26,18 +26,19 @@ export function getDatabase() {
|
||||
db = new Database(dbPath)
|
||||
|
||||
// Create tables if they don't exist
|
||||
db.exec(`
|
||||
CREATE TABLE IF NOT EXISTS sermons (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
slug TEXT UNIQUE NOT NULL,
|
||||
title TEXT NOT NULL,
|
||||
date TEXT NOT NULL,
|
||||
bible_references TEXT NOT NULL,
|
||||
personal_appliance TEXT NOT NULL,
|
||||
pastors_challenge TEXT NOT NULL,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
|
||||
)
|
||||
`)
|
||||
db.exec(`
|
||||
CREATE TABLE IF NOT EXISTS sermons (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
slug TEXT UNIQUE NOT NULL,
|
||||
title TEXT NOT NULL,
|
||||
date TEXT NOT NULL,
|
||||
bible_references TEXT NOT NULL,
|
||||
personal_appliance TEXT NOT NULL,
|
||||
pastors_challenge TEXT NOT NULL,
|
||||
archived INTEGER DEFAULT 0,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
|
||||
)
|
||||
`)
|
||||
|
||||
db.exec(`
|
||||
CREATE TABLE IF NOT EXISTS users (
|
||||
@@ -58,12 +59,24 @@ export function getDatabase() {
|
||||
return db
|
||||
}
|
||||
|
||||
export function getAllSermons(limit?: number) {
|
||||
export function getAllSermons(limit?: number, includeArchived: boolean = true) {
|
||||
const db = getDatabase()
|
||||
const whereClause = includeArchived ? '' : 'WHERE archived = 0'
|
||||
|
||||
if (limit) {
|
||||
return db.prepare('SELECT * FROM sermons ORDER BY date DESC LIMIT ?').all(limit) as Sermon[]
|
||||
return db.prepare(`SELECT * FROM sermons ${whereClause} ORDER BY date DESC LIMIT ?`).all(limit) as Sermon[]
|
||||
}
|
||||
return db.prepare('SELECT * FROM sermons ORDER BY date DESC').all() as Sermon[]
|
||||
return db.prepare(`SELECT * FROM sermons ${whereClause} ORDER BY date DESC`).all() as Sermon[]
|
||||
}
|
||||
|
||||
export function getArchivedSermons() {
|
||||
const db = getDatabase()
|
||||
return db.prepare('SELECT * FROM sermons WHERE archived = 1 ORDER BY date DESC').all() as Sermon[]
|
||||
}
|
||||
|
||||
export function archiveSermon(id: number) {
|
||||
const db = getDatabase()
|
||||
return db.prepare('UPDATE sermons SET archived = 1 WHERE id = ?').run(id)
|
||||
}
|
||||
|
||||
export function getSermonBySlug(slug: string) {
|
||||
|
||||
Reference in New Issue
Block a user