2021-11-22 13:23:30 +00:00
|
|
|
package handler
|
|
|
|
|
|
|
|
|
|
import (
|
2021-12-22 11:04:24 +00:00
|
|
|
"github.com/gorilla/csrf"
|
2021-11-22 13:23:30 +00:00
|
|
|
"github.com/gorilla/mux"
|
|
|
|
|
"net/http"
|
|
|
|
|
"strconv"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func RouteInt64Param(r *http.Request, param string) int64 {
|
|
|
|
|
vars := mux.Vars(r)
|
|
|
|
|
value, err := strconv.ParseInt(vars[param], 10, 64)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
if value < 0 {
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
return value
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (h *Handler) showEditStatusView(w http.ResponseWriter, r *http.Request) {
|
2021-12-06 06:14:20 +00:00
|
|
|
protectClickJacking(w)
|
2021-11-22 13:23:30 +00:00
|
|
|
user, err := h.getUser(r)
|
|
|
|
|
if err != nil {
|
2021-12-10 17:56:41 +00:00
|
|
|
unauthorized(w, r)
|
2021-11-22 13:23:30 +00:00
|
|
|
return
|
|
|
|
|
}
|
2021-11-28 07:40:11 +00:00
|
|
|
id, err := strconv.ParseInt(r.URL.Query().Get("id"), 10, 64)
|
|
|
|
|
if err != nil {
|
|
|
|
|
serverError(w, err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
status, err := h.storage.StatusById(id)
|
2021-11-22 13:23:30 +00:00
|
|
|
if err != nil {
|
|
|
|
|
serverError(w, err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if user != status.User {
|
2021-12-10 17:56:41 +00:00
|
|
|
unauthorized(w, r)
|
2021-11-22 13:23:30 +00:00
|
|
|
return
|
|
|
|
|
}
|
2021-11-26 22:36:48 +00:00
|
|
|
session, err := h.sess.Store.Get(r, "status")
|
2021-11-22 13:23:30 +00:00
|
|
|
if err != nil {
|
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
flash := ""
|
|
|
|
|
if flashes := session.Flashes(); len(flashes) > 0 {
|
|
|
|
|
flash = flashes[0].(string)
|
|
|
|
|
}
|
|
|
|
|
session.Save(r, w)
|
|
|
|
|
h.renderLayout(w, "edit_status", map[string]interface{}{
|
2021-12-22 11:04:24 +00:00
|
|
|
"status": status,
|
|
|
|
|
"flash": flash,
|
|
|
|
|
csrf.TemplateTag: csrf.TemplateField(r),
|
2021-11-22 13:23:30 +00:00
|
|
|
}, user)
|
|
|
|
|
}
|