post link bug fixed
parent
3150c70e1c
commit
f616d45278
|
@ -4,6 +4,7 @@ import (
|
||||||
"main/mvc/models"
|
"main/mvc/models"
|
||||||
"main/mvc/models/models_pages"
|
"main/mvc/models/models_pages"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Обработчик главной страницы
|
// Обработчик главной страницы
|
||||||
|
@ -11,18 +12,27 @@ func PostPageHandler(app *models.App) http.HandlerFunc {
|
||||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
|
postLink := r.URL.Path
|
||||||
|
|
||||||
|
// Ссылки на посты имеют вид postLink = /link/, а если прилетело что то типо /link/123123,
|
||||||
|
// то надо оставить только часть /link/
|
||||||
|
secondSlash := strings.IndexByte(postLink[1:], '/')
|
||||||
|
if secondSlash != -1 {
|
||||||
|
postLink = postLink[:secondSlash+2]
|
||||||
|
}
|
||||||
|
|
||||||
// Страничка рендерится только если ее нет в кэше
|
// Страничка рендерится только если ее нет в кэше
|
||||||
pageData, ok := app.PagesCache.Get(r.URL.Path)
|
pageData, ok := app.PagesCache.Get(postLink)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
|
||||||
post := app.Posts[models_pages.PostLink(r.URL.Path)]
|
post := app.Posts[models_pages.PostLink(postLink)]
|
||||||
|
|
||||||
pageData, err = models_pages.RenderPostPage(app.Templates, app.Version, post.Data)
|
pageData, err = models_pages.RenderPostPage(app.Templates, app.Version, post.Data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
http.Error(w, err.Error(), http.StatusInternalServerError)
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
app.PagesCache.Set(r.URL.Path, pageData)
|
app.PagesCache.Set(postLink, pageData)
|
||||||
}
|
}
|
||||||
|
|
||||||
sendPostPage(w, pageData.([]byte))
|
sendPostPage(w, pageData.([]byte))
|
||||||
|
|
Loading…
Reference in New Issue