GoBlog/posts.go

83 lines
2.0 KiB
Go
Raw Normal View History

2020-07-28 19:17:07 +00:00
package main
import (
"context"
2020-07-28 19:17:07 +00:00
"database/sql"
"errors"
"net/http"
)
var postNotFound = errors.New("post not found")
type post struct {
2020-07-29 16:28:51 +00:00
path string
content string
published string
updated string
parameters map[string]string
2020-07-28 19:17:07 +00:00
}
2020-07-29 14:41:36 +00:00
func servePost(w http.ResponseWriter, r *http.Request) {
2020-07-29 20:45:26 +00:00
path := SlashTrimmedPath(r)
post, err := getPost(path, r.Context())
2020-07-28 19:17:07 +00:00
if err == postNotFound {
2020-07-29 14:41:36 +00:00
http.NotFound(w, r)
return
2020-07-28 19:17:07 +00:00
} else if err != nil {
2020-07-29 14:41:36 +00:00
http.Error(w, err.Error(), http.StatusInternalServerError)
return
2020-07-28 19:17:07 +00:00
}
2020-07-28 19:38:12 +00:00
htmlContent, err := renderMarkdown(post.content)
if err != nil {
2020-07-29 14:41:36 +00:00
http.Error(w, err.Error(), http.StatusInternalServerError)
return
2020-07-28 19:38:12 +00:00
}
w.Header().Set("Content-Type", "text/html")
2020-07-29 14:41:36 +00:00
_, _ = w.Write(htmlContent)
2020-07-28 19:17:07 +00:00
}
func getPost(path string, context context.Context) (*post, error) {
2020-07-28 19:17:07 +00:00
queriedPost := &post{}
row := appDb.QueryRowContext(context, "select path, COALESCE(content, ''), COALESCE(published, ''), COALESCE(updated, '') from posts where path=?", path)
2020-07-28 19:17:07 +00:00
err := row.Scan(&queriedPost.path, &queriedPost.content, &queriedPost.published, &queriedPost.updated)
if err == sql.ErrNoRows {
return nil, postNotFound
} else if err != nil {
return nil, err
}
2020-07-29 16:28:51 +00:00
err = queriedPost.fetchParameters(context)
if err != nil {
return nil, err
}
2020-07-28 19:17:07 +00:00
return queriedPost, nil
}
2020-07-29 16:28:51 +00:00
func (p *post) fetchParameters(context context.Context) error {
rows, err := appDb.QueryContext(context, "select parameter, COALESCE(value, '') from post_parameters where path=?", p.path)
if err != nil {
return err
}
p.parameters = make(map[string]string)
for rows.Next() {
var parameter string
var value string
_ = rows.Scan(&parameter, &value)
p.parameters[parameter] = value
}
return nil
}
func allPostPaths() ([]string, error) {
var postPaths []string
rows, err := appDb.Query("select path from posts")
if err != nil {
return nil, err
}
for rows.Next() {
var path string
_ = rows.Scan(&path)
postPaths = append(postPaths, path)
}
return postPaths, nil
}