diff --git a/mvc/controllers/controllers_pages/post.go b/mvc/controllers/controllers_pages/post.go index 54445fd..889e3b1 100644 --- a/mvc/controllers/controllers_pages/post.go +++ b/mvc/controllers/controllers_pages/post.go @@ -4,6 +4,7 @@ import ( "main/mvc/models" "main/mvc/models/models_pages" "net/http" + "strings" ) // Обработчик главной страницы @@ -11,18 +12,27 @@ func PostPageHandler(app *models.App) http.HandlerFunc { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { 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 { - 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) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } - app.PagesCache.Set(r.URL.Path, pageData) + app.PagesCache.Set(postLink, pageData) } sendPostPage(w, pageData.([]byte))