Compare commits
3 Commits
affe71d6dd
..
master
| Author | SHA1 | Date | |
|---|---|---|---|
| f45a94622e | |||
| 9b59c36974 | |||
| 031d3006d8 |
@@ -0,0 +1,14 @@
|
||||
root = "."
|
||||
tmp_dir = "tmp"
|
||||
|
||||
[build]
|
||||
cmd = "go build -o ./tmp/main ./src"
|
||||
bin = "./tmp/main"
|
||||
include_ext = ["go", "html", "sql", "css", "js"]
|
||||
include_dir = ["src", "templates", "static"]
|
||||
exclude_dir = ["tmp", "scrap", ".git", ".vscode"]
|
||||
delay = 1000
|
||||
stop_on_error = true
|
||||
|
||||
[misc]
|
||||
clean_on_exit = true
|
||||
@@ -11,3 +11,6 @@ scrap/
|
||||
*.sqlite3
|
||||
*.db
|
||||
init.sql
|
||||
.prettierignore
|
||||
.vscode/
|
||||
query.sql
|
||||
|
||||
+8
-1
@@ -1,10 +1,17 @@
|
||||
FROM golang:alpine AS builder
|
||||
|
||||
# go-sqlite3 is a cgo package, so it needs a C toolchain
|
||||
RUN apk add --no-cache gcc musl-dev
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
COPY go.mod go.sum ./
|
||||
COPY *.go ./
|
||||
RUN go mod download
|
||||
|
||||
COPY src/*.go ./
|
||||
COPY src/seed.sql ./
|
||||
|
||||
ENV CGO_ENABLED=1
|
||||
RUN go build -o server .
|
||||
|
||||
FROM alpine:latest
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
services:
|
||||
website:
|
||||
env_file: .env
|
||||
environment:
|
||||
DB_PATH: /app/data/zum.db
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
@@ -8,4 +10,6 @@ services:
|
||||
container_name: acidarchon.com
|
||||
ports:
|
||||
- 8088:8080
|
||||
volumes:
|
||||
- /dockers/acidarchon:/app/data
|
||||
restart: unless-stopped
|
||||
|
||||
@@ -3,6 +3,6 @@ module acidburnmonkey/acidarchon
|
||||
go 1.26.2
|
||||
|
||||
require (
|
||||
github.com/joho/godotenv v1.5.1 // indirect
|
||||
github.com/mattn/go-sqlite3 v1.14.44 // indirect
|
||||
github.com/joho/godotenv v1.5.1
|
||||
github.com/mattn/go-sqlite3 v1.14.44
|
||||
)
|
||||
|
||||
@@ -0,0 +1,46 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
_ "embed"
|
||||
"time"
|
||||
|
||||
_ "github.com/mattn/go-sqlite3"
|
||||
)
|
||||
|
||||
//go:embed seed.sql
|
||||
var seedSQL string
|
||||
|
||||
// logs level=('debug', 'info', 'warning', 'error')
|
||||
type logs struct {
|
||||
level string
|
||||
ip string
|
||||
traceback string
|
||||
date time.Time
|
||||
}
|
||||
|
||||
type dbStruct struct {
|
||||
db *sql.DB
|
||||
}
|
||||
|
||||
// Seed runs the schema in seed.sql. Idempotent via CREATE TABLE IF NOT EXISTS,
|
||||
func (app *dbStruct) Seed() error {
|
||||
_, err := app.db.Exec(seedSQL)
|
||||
return err
|
||||
}
|
||||
|
||||
// InsertLog() : database method, only inserts level + traceback
|
||||
func (app *dbStruct) InsertLog(lg logs) error {
|
||||
query := `INSERT INTO logs (level, traceback) VALUES (?, ?)`
|
||||
|
||||
_, err := app.db.Exec(query, lg.level, lg.traceback)
|
||||
return err
|
||||
}
|
||||
|
||||
// LogIp() : database method, logs level + Ip
|
||||
func (app *dbStruct) LogIp(lg logs) error {
|
||||
query := `INSERT INTO logs (level, ip) VALUES (?, ?)`
|
||||
|
||||
_, err := app.db.Exec(query, lg.level, lg.ip)
|
||||
return err
|
||||
}
|
||||
+32
-4
@@ -1,6 +1,7 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"database/sql"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"io"
|
||||
@@ -48,14 +49,32 @@ type TemolateData struct {
|
||||
}
|
||||
|
||||
func main() {
|
||||
godotenv.Load()
|
||||
mux := http.NewServeMux()
|
||||
|
||||
godotenv.Load()
|
||||
dbPath := os.Getenv("DB_PATH")
|
||||
if dbPath == "" {
|
||||
dbPath = "zum.db"
|
||||
}
|
||||
|
||||
db, err := sql.Open("sqlite3", dbPath)
|
||||
if err != nil {
|
||||
slog.Error("err opening db")
|
||||
return
|
||||
}
|
||||
defer db.Close()
|
||||
|
||||
database := &dbStruct{db: db}
|
||||
|
||||
if err := database.Seed(); err != nil {
|
||||
slog.Error("seeding db", "err", err)
|
||||
return
|
||||
}
|
||||
|
||||
// routes
|
||||
mux.HandleFunc("/", handleRoot)
|
||||
mux.HandleFunc("/", database.handleRoot)
|
||||
mux.HandleFunc("/robots.txt", serveRobots)
|
||||
mux.HandleFunc("/*", handleRoot)
|
||||
mux.HandleFunc("/*", database.handleRoot)
|
||||
|
||||
mux.Handle("/static/", http.StripPrefix("/static/", http.FileServer(http.Dir("static"))))
|
||||
|
||||
@@ -64,10 +83,15 @@ func main() {
|
||||
}
|
||||
|
||||
// Routes
|
||||
func handleRoot(w http.ResponseWriter, r *http.Request) {
|
||||
|
||||
// handleRoot() : part of dbStruct
|
||||
func (app *dbStruct) handleRoot(w http.ResponseWriter, r *http.Request) {
|
||||
templ, err := template.ParseFiles("templates/home.html")
|
||||
if err != nil {
|
||||
http.Error(w, "template not found", http.StatusInternalServerError)
|
||||
if logErr := app.InsertLog(logs{level: "error", traceback: "template not found"}); logErr != nil {
|
||||
slog.Error("failed to write log", "err", logErr)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
@@ -85,6 +109,10 @@ func handleRoot(w http.ResponseWriter, r *http.Request) {
|
||||
dox := callApi(host)
|
||||
dox2 := secondApi(host)
|
||||
|
||||
if logErr := app.LogIp(logs{level: "info", ip: dox.IP}); logErr != nil {
|
||||
slog.Error("failed to write log", "err", logErr)
|
||||
}
|
||||
|
||||
templ.Execute(w, TemolateData{Ip: dox, IP2: *dox2})
|
||||
}
|
||||
|
||||
@@ -3,6 +3,5 @@ CREATE TABLE IF NOT EXISTS logs (
|
||||
level TEXT NOT NULL CHECK(level IN ('debug', 'info', 'warning', 'error')),
|
||||
ip TEXT,
|
||||
traceback TEXT,
|
||||
date DATETIME,
|
||||
repeating INTEGER
|
||||
);
|
||||
date DATETIME DEFAULT (datetime('now', 'localtime'))
|
||||
);
|
||||
Reference in New Issue
Block a user