Don't allow access of draft posts. Resolved #8
This commit is contained in:
parent
2fa453a408
commit
2e0332618b
|
@ -88,11 +88,20 @@ func postHandler(repo *owl.Repository) func(http.ResponseWriter, *http.Request,
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
post, err := user.GetPost(postId)
|
post, err := user.GetPost(postId)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
println("Error getting post: ", err.Error())
|
println("Error getting post: ", err.Error())
|
||||||
notFoundHandler(repo)(w, r)
|
notFoundHandler(repo)(w, r)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_, meta := post.MarkdownData()
|
||||||
|
if meta.Draft {
|
||||||
|
println("Post is a draft")
|
||||||
|
notFoundHandler(repo)(w, r)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
html, err := owl.RenderPost(post)
|
html, err := owl.RenderPost(post)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
println("Error rendering post: ", err.Error())
|
println("Error rendering post: ", err.Error())
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
package main_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
main "h4kor/owl-blogs/cmd/owl-web"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestPostHandlerReturns404OnDrafts(t *testing.T) {
|
||||||
|
repo := getTestRepo()
|
||||||
|
user, _ := repo.CreateUser("test-1")
|
||||||
|
post, _ := user.CreateNewPost("post-1")
|
||||||
|
|
||||||
|
content := "---\n"
|
||||||
|
content += "title: test\n"
|
||||||
|
content += "draft: true\n"
|
||||||
|
content += "---\n"
|
||||||
|
content += "\n"
|
||||||
|
content += "Write your post here.\n"
|
||||||
|
os.WriteFile(post.ContentFile(), []byte(content), 0644)
|
||||||
|
|
||||||
|
// Create Request and Response
|
||||||
|
req, err := http.NewRequest("GET", post.UrlPath(), nil)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
rr := httptest.NewRecorder()
|
||||||
|
router := main.Router(&repo)
|
||||||
|
router.ServeHTTP(rr, req)
|
||||||
|
|
||||||
|
// Check the status code is what we expect.
|
||||||
|
if status := rr.Code; status != http.StatusNotFound {
|
||||||
|
t.Errorf("handler returned wrong status code: got %v want %v",
|
||||||
|
status, http.StatusNotFound)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue