SQLite boilerplate

This commit is contained in:
Quad 2022-04-13 17:14:13 +02:00
parent 44cbd19a8d
commit 88cbeee562
6 changed files with 63 additions and 3 deletions

3
.gitignore vendored
View File

@ -3,3 +3,6 @@
# Binary name built by nimble # Binary name built by nimble
nimblog nimblog
# Database
blog.db

View File

@ -1,6 +1,6 @@
# nimblog # nimblog
Placeholder text Basic blog written in nim, mostly for learning purposes.
## How to run ## How to run

15
schema.sql Normal file
View File

@ -0,0 +1,15 @@
CREATE TABLE users (
id INTEGER PRIMARY KEY AUTOINCREMENT,
displayname TEXT NOT NULL,
username TEXT UNIQUE NOT NULL,
password TEXT NOT NULL
);
CREATE TABLE posts (
id INTEGER PRIMARY KEY AUTOINCREMENT,
author_id INTEGER NOT NULL,
created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
title TEXT NOT NULL,
body TEXT NOT NULL,
FOREIGN KEY (author_id) REFERENCES users (id)
);

View File

@ -2,7 +2,7 @@ import prologue
import prologue/middlewares/staticfile import prologue/middlewares/staticfile
import views import views
proc runWebsite(settings: Table) = proc runWebsite(settings: Table[string, bool], dbSettings: Table[string, string]) =
let prologueSettings = newSettings( let prologueSettings = newSettings(
debug = settings["debug"] debug = settings["debug"]
) )

32
src/modules/db.nim Normal file
View File

@ -0,0 +1,32 @@
import tables
import std/[os, db_sqlite, strutils, streams]
proc createDb(dbSettings: Table): bool =
if not fileExists(dbSettings["path"]):
var userConsent: bool = false
while userConsent != true:
stdout.write "Did not find database. Create one now? (y/n) "
stdout.flushFile()
var userInput = readChar(stdin)
stdin.flushFile()
case userInput
of 'y', 'Y':
userConsent = true
of 'n', 'N':
return false
else:
discard
let
schema = readFile(dbSettings["schema_path"])
db = open(dbSettings["path"], "", "", "")
for command in schema.split(";"):
# Skip "command" if it's just a blank line
if command == "\c\n" or command == "\n":
continue
db.exec(sql(command.strip))
echo "Ran command: " & command.strip
db.close()
return true
export createDb

View File

@ -2,14 +2,24 @@ when isMainModule:
import tables import tables
import modules/blog import modules/blog
import modules/env import modules/env
import modules/db
let settings = { let settings = {
"debug": boolEnvOrDefault("DEBUG", false), "debug": boolEnvOrDefault("DEBUG", false),
"logging": boolEnvOrDefault("NIMBLOG_LOG", true) "logging": boolEnvOrDefault("NIMBLOG_LOG", true)
}.toTable() }.toTable()
let dbSettings = {
"path": "blog.db",
"schema_path": "schema.sql"
}.toTable()
if not createDb(dbSettings):
echo "Failed to prepare database"
quit(QuitFailure)
try: try:
echo "Starting website" echo "Starting website"
runWebsite(settings) runWebsite(settings=settings, dbSettings=dbSettings)
except: except:
echo "Could not run website" echo "Could not run website"