Restore the library since we're not actually rolling out education yet

This commit is contained in:
Ben Visness 2022-09-10 12:54:26 -05:00
parent 19d79a2a77
commit 168b210c5b
7 changed files with 48 additions and 13 deletions

View File

@ -700,6 +700,13 @@ func (c *UrlContext) BuildBlogPostReply(threadId int, postId int) string {
var RegexLibraryAny = regexp.MustCompile(`^/library`) var RegexLibraryAny = regexp.MustCompile(`^/library`)
var RegexLibrary = regexp.MustCompile(`^/library$`)
func BuildLibrary() string {
defer CatchPanic()
return Url("/library", nil)
}
/* /*
* Episode Guide * Episode Guide
*/ */

View File

@ -84,7 +84,10 @@
<div class="root-item"> <div class="root-item">
<a>Resources <div class="dib svgicon ml1">{{ svg "chevron-down-thick" }}</div></a> <a>Resources <div class="dib svgicon ml1">{{ svg "chevron-down-thick" }}</div></a>
<div class="submenu b--theme-dark"> <div class="submenu b--theme-dark">
<a href="{{ .Header.LibraryUrl }}">Library</a>
{{ if and .User .User.IsEduTester }}
<a href="{{ .Header.EducationUrl }}">Education</a> <a href="{{ .Header.EducationUrl }}">Education</a>
{{ end }}
</div> </div>
</div> </div>
</div> </div>

View File

@ -52,6 +52,7 @@ type Header struct {
FishbowlUrl string FishbowlUrl string
ForumsUrl string ForumsUrl string
ConferencesUrl string ConferencesUrl string
LibraryUrl string
EducationUrl string EducationUrl string
Project *ProjectHeader Project *ProjectHeader

View File

@ -75,6 +75,7 @@ func getBaseData(c *RequestContext, title string, breadcrumbs []templates.Breadc
FishbowlUrl: hmnurl.BuildFishbowlIndex(), FishbowlUrl: hmnurl.BuildFishbowlIndex(),
ForumsUrl: hmnurl.HMNProjectContext.BuildForum(nil, 1), ForumsUrl: hmnurl.HMNProjectContext.BuildForum(nil, 1),
ConferencesUrl: hmnurl.BuildConferences(), ConferencesUrl: hmnurl.BuildConferences(),
LibraryUrl: hmnurl.BuildLibrary(),
EducationUrl: hmnurl.BuildEducationIndex(), EducationUrl: hmnurl.BuildEducationIndex(),
}, },
Footer: templates.Footer{ Footer: templates.Footer{

9
src/website/library.go Normal file
View File

@ -0,0 +1,9 @@
package website
func LibraryNotPortedYet(c *RequestContext) ResponseData {
baseData := getBaseData(c, "Library", nil)
var res ResponseData
res.MustWriteTemplate("library_not_ported_yet.html", baseData, c.Perf)
return res
}

View File

@ -75,6 +75,16 @@ func adminsOnly(h Handler) Handler {
} }
} }
func educationBetaTestersOnly(h Handler) Handler {
return func(c *RequestContext) ResponseData {
if c.CurrentUser == nil || !c.CurrentUser.CanSeeUnpublishedEducationContent() {
return FourOhFour(c)
}
return h(c)
}
}
func educationAuthorsOnly(h Handler) Handler { func educationAuthorsOnly(h Handler) Handler {
return func(c *RequestContext) ResponseData { return func(c *RequestContext) ResponseData {
if c.CurrentUser == nil || !c.CurrentUser.CanAuthorEducation() { if c.CurrentUser == nil || !c.CurrentUser.CanAuthorEducation() {

View File

@ -117,21 +117,25 @@ func NewWebsiteRoutes(conn *pgxpool.Pool) http.Handler {
hmnOnly.GET(hmnurl.RegexFishbowlIndex, FishbowlIndex) hmnOnly.GET(hmnurl.RegexFishbowlIndex, FishbowlIndex)
hmnOnly.GET(hmnurl.RegexFishbowl, Fishbowl) hmnOnly.GET(hmnurl.RegexFishbowl, Fishbowl)
hmnOnly.GET(hmnurl.RegexEducationIndex, EducationIndex) educationPrerelease := hmnOnly.WithMiddleware(educationBetaTestersOnly)
hmnOnly.GET(hmnurl.RegexEducationGlossary, EducationGlossary) {
hmnOnly.GET(hmnurl.RegexEducationArticleNew, educationAuthorsOnly(EducationArticleNew)) educationPrerelease.GET(hmnurl.RegexEducationIndex, EducationIndex)
hmnOnly.POST(hmnurl.RegexEducationArticleNew, educationAuthorsOnly(EducationArticleNewSubmit)) educationPrerelease.GET(hmnurl.RegexEducationGlossary, EducationGlossary)
hmnOnly.GET(hmnurl.RegexEducationArticle, EducationArticle) // Article stuff must be last so `/glossary` and others do not match as an article slug educationPrerelease.GET(hmnurl.RegexEducationArticleNew, educationAuthorsOnly(EducationArticleNew))
hmnOnly.GET(hmnurl.RegexEducationArticleEdit, educationAuthorsOnly(EducationArticleEdit)) educationPrerelease.POST(hmnurl.RegexEducationArticleNew, educationAuthorsOnly(EducationArticleNewSubmit))
hmnOnly.POST(hmnurl.RegexEducationArticleEdit, educationAuthorsOnly(EducationArticleEditSubmit)) educationPrerelease.GET(hmnurl.RegexEducationArticle, EducationArticle) // Article stuff must be last so `/glossary` and others do not match as an article slug
hmnOnly.GET(hmnurl.RegexEducationArticleDelete, educationAuthorsOnly(EducationArticleDelete)) educationPrerelease.GET(hmnurl.RegexEducationArticleEdit, educationAuthorsOnly(EducationArticleEdit))
hmnOnly.POST(hmnurl.RegexEducationArticleDelete, educationAuthorsOnly(csrfMiddleware(EducationArticleDeleteSubmit))) educationPrerelease.POST(hmnurl.RegexEducationArticleEdit, educationAuthorsOnly(EducationArticleEditSubmit))
educationPrerelease.GET(hmnurl.RegexEducationArticleDelete, educationAuthorsOnly(EducationArticleDelete))
educationPrerelease.POST(hmnurl.RegexEducationArticleDelete, educationAuthorsOnly(csrfMiddleware(EducationArticleDeleteSubmit)))
}
hmnOnly.POST(hmnurl.RegexAPICheckUsername, csrfMiddleware(APICheckUsername)) hmnOnly.POST(hmnurl.RegexAPICheckUsername, csrfMiddleware(APICheckUsername))
hmnOnly.GET(hmnurl.RegexLibraryAny, func(c *RequestContext) ResponseData { hmnOnly.GET(hmnurl.RegexLibraryAny, LibraryNotPortedYet)
return c.Redirect(hmnurl.BuildEducationIndex(), http.StatusFound) // hmnOnly.GET(hmnurl.RegexLibraryAny, func(c *RequestContext) ResponseData {
}) // return c.Redirect(hmnurl.BuildEducationIndex(), http.StatusFound)
// })
// Project routes can appear either at the root (e.g. hero.handmade.network/edit) // Project routes can appear either at the root (e.g. hero.handmade.network/edit)
// or on a personal project path (e.g. handmade.network/p/123/hero/edit). So, we // or on a personal project path (e.g. handmade.network/p/123/hero/edit). So, we