summaryrefslogtreecommitdiff
path: root/srv
diff options
context:
space:
mode:
Diffstat (limited to 'srv')
-rw-r--r--srv/src/api/api.go7
-rw-r--r--srv/src/api/posts.go28
2 files changed, 34 insertions, 1 deletions
diff --git a/srv/src/api/api.go b/srv/src/api/api.go
index a6fc779..fc6f6a2 100644
--- a/srv/src/api/api.go
+++ b/srv/src/api/api.go
@@ -213,7 +213,12 @@ func (a *api) handler() http.Handler {
v2Mux := http.NewServeMux()
v2Mux.Handle("/follow.html", a.renderDumbTplHandler("follow.html"))
v2Mux.Handle("/posts/", http.StripPrefix("/posts",
- a.renderPostHandler(),
+ apiutil.MethodMux(map[string]http.Handler{
+ "GET": a.renderPostHandler(),
+ "DELETE": authMiddleware(auther,
+ formMiddleware(a.deletePostHandler()),
+ ),
+ }),
))
v2Mux.Handle("/assets/", http.StripPrefix("/assets",
apiutil.MethodMux(map[string]http.Handler{
diff --git a/srv/src/api/posts.go b/srv/src/api/posts.go
index 68754a3..a906f14 100644
--- a/srv/src/api/posts.go
+++ b/srv/src/api/posts.go
@@ -137,3 +137,31 @@ func (a *api) renderPostsIndexHandler() http.Handler {
executeTemplate(rw, r, tpl, tplPayload)
})
}
+
+func (a *api) deletePostHandler() http.Handler {
+
+ return http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) {
+
+ id := filepath.Base(r.URL.Path)
+
+ if id == "" {
+ apiutil.BadRequest(rw, r, errors.New("id is required"))
+ return
+ }
+
+ err := a.params.PostStore.Delete(id)
+
+ if errors.Is(err, post.ErrPostNotFound) {
+ http.Error(rw, "Post not found", 404)
+ return
+ } else if err != nil {
+ apiutil.InternalServerError(
+ rw, r, fmt.Errorf("deleting post with id %q: %w", id, err),
+ )
+ return
+ }
+
+ a.executeRedirectTpl(rw, r, "posts/")
+
+ })
+}