aboutsummaryrefslogtreecommitdiff
path: root/cmd/http
diff options
context:
space:
mode:
authorAlex Scerba <alex@scerba.org>2024-11-09 23:21:53 -0500
committerAlex Scerba <alex@scerba.org>2024-11-09 23:21:53 -0500
commit545ebd7cebd891f6099d3a62f219d49303af0fca (patch)
treedb8295d8e084d93c9a2f48831e2f5a2de284304e /cmd/http
parent5ec772029d4ea4b4f4ed2c78b4416afd9dab71cd (diff)
Move to dynamic blog system
Diffstat (limited to 'cmd/http')
-rw-r--r--cmd/http/handle.go73
-rw-r--r--cmd/http/load.go73
-rw-r--r--cmd/http/main.go12
-rw-r--r--cmd/http/render.go61
4 files changed, 141 insertions, 78 deletions
diff --git a/cmd/http/handle.go b/cmd/http/handle.go
index ce0e8c0..f5ee67a 100644
--- a/cmd/http/handle.go
+++ b/cmd/http/handle.go
@@ -17,7 +17,7 @@ func (app *application) home(w http.ResponseWriter, r *http.Request) {
app.serverError(w, err)
} */
- err := renderTemplate(w, "index", nil)
+ err := renderPage(w, "index")
if err != nil {
app.serverError(w, err)
}
@@ -29,51 +29,82 @@ func (app *application) page(w http.ResponseWriter, r *http.Request) {
path := strings.Split(r.URL.Path, "/")
- /* Redirect paths like /about/sth/oeusth to /about */
+ // Redirect paths like /about/sth/oeusth to /about
if len(path) > 2 {
http.Redirect(w, r, "/"+path[1], http.StatusFound)
}
- err := renderTemplate(w, path[1], nil)
+ err := renderPage(w, path[1])
if err != nil {
app.serverError(w, err)
}
}
-/*
func (app *application) blog(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "text/html; charset=utf-8")
path := strings.Split(r.URL.Path, "/")
- if path[1] != "blog" {
- app.notFound(w)
- } else {
- err := renderTemplate(w, "blog", nil)
+
+ // Setup redirects for trailing / and extraneous path elements
+ if len(path) > 3 {
+ // Redirect to /blog/article
+ http.Redirect(w, r, "/"+path[1]+"/"+path[2], http.StatusFound)
+ } else if len(path) == 3 && path[2] == "" {
+ // Redirect to /blog
+ http.Redirect(w, r, "/"+path[1], http.StatusFound)
+ } else if len(path) == 2 {
+ p, err := app.aggregate("html/blog")
if err != nil {
app.serverError(w, err)
+ return
+ }
+ a, err := app.aggregate("html/archive")
+ if err != nil {
+ app.serverError(w, err)
+ return
}
- }
- if len(path) > 4 {
- app.notFound(w)
- } else if len(path) == 4 && path[3] == "" {
- http.Redirect(w, r, "/"+path[1]+"/"+path[2], http.StatusFound)
- } else {
- post, err := app.readFile("html" + strings.TrimSuffix(r.URL.Path, "/") + ".tmpl.html")
+ err = renderBlog(w, "blog2", p, a)
if err != nil {
+ app.serverError(w, err)
+ return
+ }
+ } else if len(path) == 3 {
+ if !app.fileExists("html/" + path[1] + "/" + path[2] + ".tmpl.html") {
app.notFound(w)
return
}
+ post := app.parseFileName(path[2])
- var posts []*Post
- posts = append(posts, post)
- p := &Posts{Contents: posts}
-
- err = renderTemplate(w, path[1]+"/"+path[2], p)
+ err := renderPost(w, path[2], post)
if err != nil {
app.serverError(w, err)
}
}
+}
+
+func (app *application) archive(w http.ResponseWriter, r *http.Request) {
+ w.Header().Set("Content-Type", "text/html; charset=utf-8")
+
+ path := strings.Split(r.URL.Path, "/")
+
+ // Setup redirects for trailing / and extraneous path elements
+ if len(path) > 3 {
+ // Redirect to /archive/article
+ http.Redirect(w, r, "/"+path[1]+"/"+path[2], http.StatusFound)
+ } else if len(path) == 3 && path[2] == "" {
+ // Redirect to /blog
+ http.Redirect(w, r, "/blog", http.StatusFound)
+ } else if len(path) == 3 {
+ if !app.fileExists("html/" + path[1] + "/" + path[2] + ".tmpl.html") {
+ app.notFound(w)
+ return
+ }
+ post := app.parseFileName(path[2])
+ err := renderArchivePost(w, path[2], post)
+ if err != nil {
+ app.serverError(w, err)
+ }
+ }
}
-*/
diff --git a/cmd/http/load.go b/cmd/http/load.go
index d63d7ce..6ab2eba 100644
--- a/cmd/http/load.go
+++ b/cmd/http/load.go
@@ -1,24 +1,23 @@
package main
import (
+ "errors"
"os"
- "regexp"
"sort"
"strings"
)
// Post struct contains necessary data for a post
type Post struct {
- FileName string
- Title string
- Date string
- Tags []string
- Image string
+ File string
+ Title string
+ Date string
+ Tags []string
}
// Posts stuct contains a collection of type Post
type Posts struct {
- Contents []*Post
+ Collection []*Post
}
// Read all found files and load them into a stuct
@@ -33,10 +32,7 @@ func (app *application) aggregate(location string) (p *Posts, err error) {
// Loop over every file in the directory and read the contents.
for _, file := range files {
if !file.IsDir() && strings.HasSuffix(file.Name(), ".tmpl.html") {
- newPost, err := app.readFile(location + "/" + file.Name())
- if err != nil {
- return nil, err
- }
+ newPost := app.parseFileName(strings.TrimSuffix(file.Name(), ".tmpl.html"))
posts = append(posts, newPost)
}
@@ -46,35 +42,32 @@ func (app *application) aggregate(location string) (p *Posts, err error) {
return posts[i].Date > posts[j].Date
})
- return &Posts{Contents: posts}, nil
+ return &Posts{Collection: posts}, nil
}
-func (app *application) readFile(location string) (p *Post, err error) {
- fileContent, err := os.ReadFile(location)
- if err != nil {
- return nil, err
- }
-
+func (app *application) parseFileName(file string) (p *Post) {
var post *Post = new(Post)
- fileName := strings.TrimSuffix(strings.Split(location, "/")[2], ".tmpl.html")
-
- // title
- title := strings.ReplaceAll(fileName, "_", " ")
+ svList := strings.Split(file, "+")
+ usvLength := len(svList)
// date
- datePattern := regexp.MustCompile(`{{define "uploaded-on"}}(\d{4}-\d{2}-\d{2}){{end}}`)
+ /*datePattern := regexp.MustCompile(`{{define "uploaded-on"}}(\d{4}-\d{2}-\d{2}){{end}}`)
dateMatching := datePattern.FindStringSubmatch(string(fileContent))
- var date string
+ //var date string
if len(dateMatching) > 1 {
date = dateMatching[1]
} else {
date = ""
- }
+ }*/
+ date := svList[0]
+
+ // title
+ title := strings.ReplaceAll(svList[1], "_", " ")
// tags
- tagsPattern := regexp.MustCompile(`{{define "keywords"}}([\w\s]+){{end}}`)
+ /*tagsPattern := regexp.MustCompile(`{{define "keywords"}}([\w\s]+){{end}}`)
matchingTags := tagsPattern.FindStringSubmatch(string(fileContent))
var tags []string
@@ -82,25 +75,29 @@ func (app *application) readFile(location string) (p *Post, err error) {
tags = strings.Fields(matchingTags[1])
} else {
tags = []string{}
- }
-
- // thumbnail image
- imagePattern := regexp.MustCompile(`<img src="(.+)" class="mainImage"( alt="(.+)")* />`)
- matchingImage := imagePattern.FindStringSubmatch(string(fileContent))
+ }*/
- var image string
- if len(matchingImage) > 1 {
- image = matchingImage[0]
+ var tags []string
+ if usvLength > 2 {
+ for i := 2; i < usvLength; i++ {
+ tags = append(tags, svList[i])
+ }
} else {
- image = ""
+ tags = []string{}
}
- post.FileName = fileName
+ post.File = file
post.Title = title
post.Date = date
post.Tags = tags
- post.Image = image
- return post, nil
+ return post
+
+}
+func (app *application) fileExists(file string) bool {
+ if _, err := os.Stat(file); errors.Is(err, os.ErrNotExist) {
+ return false
+ }
+ return true
}
diff --git a/cmd/http/main.go b/cmd/http/main.go
index a75ccfc..951c02f 100644
--- a/cmd/http/main.go
+++ b/cmd/http/main.go
@@ -18,7 +18,7 @@ type application struct {
infoLog *log.Logger
}
-func (app *application) httpsRedirect(w http.ResponseWriter, req *http.Request) {
+/*func (app *application) httpsRedirect(w http.ResponseWriter, req *http.Request) {
// remove/add not default ports from req.Host
target := "https://" + req.Host + req.URL.Path
if len(req.URL.RawQuery) > 0 {
@@ -28,12 +28,12 @@ func (app *application) httpsRedirect(w http.ResponseWriter, req *http.Request)
http.Redirect(w, req, target,
// see comments below and consider the codes 308, 302, or 301
http.StatusMovedPermanently)
-}
+}*/
func (app *application) wwwRedirect(h http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if !strings.HasPrefix(r.Host, "www.") {
- http.Redirect(w, r, "https://www."+r.Host+r.RequestURI, 302)
+ http.Redirect(w, r, "https://www."+r.Host+r.RequestURI, http.StatusFound)
return
}
@@ -66,8 +66,10 @@ func main() {
mux.HandleFunc("/gallery/", app.page)
mux.HandleFunc("/links", app.page)
mux.HandleFunc("/links/", app.page)
- mux.HandleFunc("/blog", app.page)
- mux.HandleFunc("/blog/", app.page)
+ mux.HandleFunc("/blog", app.blog)
+ mux.HandleFunc("/blog/", app.blog)
+ mux.HandleFunc("/archive", app.archive)
+ mux.HandleFunc("/archive/", app.archive)
mux.HandleFunc("/", app.home)
if *addr == ":443" {
diff --git a/cmd/http/render.go b/cmd/http/render.go
index 585ba31..deaa68e 100644
--- a/cmd/http/render.go
+++ b/cmd/http/render.go
@@ -2,32 +2,65 @@ package main
import (
"net/http"
- //"strings"
"text/template"
)
-func renderTemplate(w http.ResponseWriter, page string, p *Posts) (err error) {
+func renderPage(w http.ResponseWriter, page string) (err error) {
t, err := template.ParseFiles("html/master.tmpl.html", "html/"+page+".tmpl.html")
if err != nil {
return err
}
- //splitPath := strings.Split(page, "/")
+ err = t.Execute(w, nil)
+ if err != nil {
+ return err
+ }
+
+ return nil
+}
+
+func renderBlog(w http.ResponseWriter, page string, p *Posts, a *Posts) (err error) {
+ t, err := template.ParseFiles("html/master.tmpl.html", "html/"+page+".tmpl.html")
+ if err != nil {
+ return err
+ }
- //data := make(map[string]interface{})
+ data := make(map[string]interface{})
- // If were loading the index, set page to 'Index' and pass through all posts.
- // Otherwise, set page to 'Projects' and pass through the first post (should only be one
- // coming in)
- /* if splitPath[0] == "index" {
- data["Page"] = "Index"
+ if page == "blog2" {
data["Posts"] = p
- } else {
- data["Page"] = "Project"
- data["Post"] = p.Contents[0]
- } */
+ data["Archive"] = a
+ }
- err = t.Execute(w, nil)
+ err = t.Execute(w, data)
+ if err != nil {
+ return err
+ }
+
+ return nil
+}
+
+func renderPost(w http.ResponseWriter, page string, p *Post) (err error) {
+ t, err := template.ParseFiles("html/master.tmpl.html", "html/post.tmpl.html", "html/blog/"+page+".tmpl.html")
+ if err != nil {
+ return err
+ }
+
+ err = t.Execute(w, p)
+ if err != nil {
+ return err
+ }
+
+ return nil
+}
+
+func renderArchivePost(w http.ResponseWriter, page string, p *Post) (err error) {
+ t, err := template.ParseFiles("html/master.tmpl.html", "html/post.tmpl.html", "html/archive/"+page+".tmpl.html")
+ if err != nil {
+ return err
+ }
+
+ err = t.Execute(w, p)
if err != nil {
return err
}