Try to reduce duplication in the router.

This commit is contained in:
Azareal 2019-07-12 18:33:25 +10:00
parent ad4dacb447
commit 483ff06775
5 changed files with 101 additions and 40 deletions

View File

@ -621,15 +621,15 @@ func NewWriterIntercept(w http.ResponseWriter) *WriterIntercept {
var wiMaxAge = "max-age=" + strconv.Itoa(int(c.Day)) var wiMaxAge = "max-age=" + strconv.Itoa(int(c.Day))
func (writ *WriterIntercept) WriteHeader(code int) { func (writ *WriterIntercept) WriteHeader(code int) {
if code == 200 { if code == 200 {
writ.ResponseWriter.Header().Set("Cache-Control", wiMaxAge) h := writ.ResponseWriter.Header()
writ.ResponseWriter.Header().Set("Vary", "Accept-Encoding") h.Set("Cache-Control", wiMaxAge)
h.Set("Vary", "Accept-Encoding")
} }
writ.ResponseWriter.WriteHeader(code) writ.ResponseWriter.WriteHeader(code)
} }
// HTTPSRedirect is a connection handler which redirects all HTTP requests to HTTPS // HTTPSRedirect is a connection handler which redirects all HTTP requests to HTTPS
type HTTPSRedirect struct { type HTTPSRedirect struct {}
}
func (red *HTTPSRedirect) ServeHTTP(w http.ResponseWriter, req *http.Request) { func (red *HTTPSRedirect) ServeHTTP(w http.ResponseWriter, req *http.Request) {
w.Header().Set("Connection", "close") w.Header().Set("Connection", "close")

View File

@ -386,15 +386,15 @@ func NewWriterIntercept(w http.ResponseWriter) *WriterIntercept {
var wiMaxAge = "max-age=" + strconv.Itoa(int(c.Day)) var wiMaxAge = "max-age=" + strconv.Itoa(int(c.Day))
func (writ *WriterIntercept) WriteHeader(code int) { func (writ *WriterIntercept) WriteHeader(code int) {
if code == 200 { if code == 200 {
writ.ResponseWriter.Header().Set("Cache-Control", wiMaxAge) h := writ.ResponseWriter.Header()
writ.ResponseWriter.Header().Set("Vary", "Accept-Encoding") h.Set("Cache-Control", wiMaxAge)
h.Set("Vary", "Accept-Encoding")
} }
writ.ResponseWriter.WriteHeader(code) writ.ResponseWriter.WriteHeader(code)
} }
// HTTPSRedirect is a connection handler which redirects all HTTP requests to HTTPS // HTTPSRedirect is a connection handler which redirects all HTTP requests to HTTPS
type HTTPSRedirect struct { type HTTPSRedirect struct {}
}
func (red *HTTPSRedirect) ServeHTTP(w http.ResponseWriter, req *http.Request) { func (red *HTTPSRedirect) ServeHTTP(w http.ResponseWriter, req *http.Request) {
w.Header().Set("Connection", "close") w.Header().Set("Connection", "close")

View File

@ -1,5 +1,7 @@
package main package main
import "strings"
type RouteGroup struct { type RouteGroup struct {
Path string Path string
RouteList []*RouteImpl RouteList []*RouteImpl
@ -9,17 +11,17 @@ type RouteGroup struct {
} }
func newRouteGroup(path string, routes ...*RouteImpl) *RouteGroup { func newRouteGroup(path string, routes ...*RouteImpl) *RouteGroup {
group := &RouteGroup{Path: path} g := &RouteGroup{Path: path}
for _, route := range routes { for _, route := range routes {
route.Parent = group route.Parent = g
group.RouteList = append(group.RouteList, route) g.RouteList = append(g.RouteList, route)
} }
return group return g
} }
func (group *RouteGroup) Not(path ...string) *RouteSubset { func (g *RouteGroup) Not(path ...string) *RouteSubset {
routes := make([]*RouteImpl, len(group.RouteList)) routes := make([]*RouteImpl, len(g.RouteList))
copy(routes, group.RouteList) copy(routes, g.RouteList)
for i, route := range routes { for i, route := range routes {
if inStringList(route.Path, path) { if inStringList(route.Path, path) {
routes = append(routes[:i], routes[i+1:]...) routes = append(routes[:i], routes[i+1:]...)
@ -37,29 +39,47 @@ func inStringList(needle string, list []string) bool {
return false return false
} }
func (group *RouteGroup) NoHeader() *RouteGroup { func (g *RouteGroup) NoHeader() *RouteGroup {
group.NoHead = true g.NoHead = true
return group return g
} }
func (group *RouteGroup) Before(lines ...string) *RouteGroup { func (g *RouteGroup) Before(lines ...string) *RouteGroup {
for _, line := range lines { for _, line := range lines {
group.RunBefore = append(group.RunBefore, Runnable{line, false}) g.RunBefore = append(g.RunBefore, Runnable{line, false})
} }
return group return g
} }
func (group *RouteGroup) LitBefore(lines ...string) *RouteGroup { func (g *RouteGroup) LitBefore(lines ...string) *RouteGroup {
for _, line := range lines { for _, line := range lines {
group.RunBefore = append(group.RunBefore, Runnable{line, true}) g.RunBefore = append(g.RunBefore, Runnable{line, true})
} }
return group return g
} }
func (group *RouteGroup) Routes(routes ...*RouteImpl) *RouteGroup { /*func (g *RouteGroup) Routes(routes ...*RouteImpl) *RouteGroup {
for _, route := range routes { for _, route := range routes {
route.Parent = group route.Parent = g
group.RouteList = append(group.RouteList, route) g.RouteList = append(g.RouteList, route)
} }
return group return g
}*/
func (g *RouteGroup) Routes(routes ...interface{}) *RouteGroup {
for _, route := range routes {
switch r := route.(type) {
case *RouteImpl:
r.Parent = g
g.RouteList = append(g.RouteList, r)
case RouteSet:
for _, rr := range r.Items {
rr.Name = r.Name + rr.Name
rr.Path = strings.TrimSuffix(r.Path, "/") + "/" + strings.TrimPrefix(rr.Path, "/")
rr.Parent = g
g.RouteList = append(g.RouteList, rr)
}
}
}
return g
} }

View File

@ -85,6 +85,14 @@ func View(fname string, path string, args ...string) *RouteImpl {
return route(fname, path, false, false, args...) return route(fname, path, false, false, args...)
} }
func MView(fname string, path string, args ...string) *RouteImpl {
route := route(fname, path, false, false, args...)
if !route.hasBefore("SuperModOnly", "AdminOnly") {
route.Before("MemberOnly")
}
return route
}
func MemberView(fname string, path string, args ...string) *RouteImpl { func MemberView(fname string, path string, args ...string) *RouteImpl {
route := route(fname, path, false, false, args...) route := route(fname, path, false, false, args...)
if !route.hasBefore("SuperModOnly", "AdminOnly") { if !route.hasBefore("SuperModOnly", "AdminOnly") {
@ -139,3 +147,13 @@ func (action *uploadAction) MaxSizeVar(varName string) *RouteImpl {
action.Route.Before("NoUploadSessionMismatch") action.Route.Before("NoUploadSessionMismatch")
return action.Route return action.Route
} }
type RouteSet struct {
Name string
Path string
Items []*RouteImpl
}
func Set(name string, path string, routes ...*RouteImpl) RouteSet {
return RouteSet{name, path, routes}
}

View File

@ -28,7 +28,7 @@ func routes(r *Router) {
topicGroup := newRouteGroup("/topics/", topicGroup := newRouteGroup("/topics/",
View("routes.TopicList", "/topics/"), View("routes.TopicList", "/topics/"),
View("routes.TopicListMostViewed", "/topics/most-viewed/"), View("routes.TopicListMostViewed", "/topics/most-viewed/"),
MemberView("routes.CreateTopic", "/topics/create/", "extraData"), MView("routes.CreateTopic", "/topics/create/", "extraData"),
) )
r.AddGroup(topicGroup) r.AddGroup(topicGroup)
@ -49,24 +49,47 @@ func userRoutes() *RouteGroup {
return newRouteGroup("/user/").Routes( return newRouteGroup("/user/").Routes(
View("routes.ViewProfile", "/user/").LitBefore("req.URL.Path += extraData"), View("routes.ViewProfile", "/user/").LitBefore("req.URL.Path += extraData"),
MemberView("routes.AccountEdit", "/user/edit/"), Set("routes.AccountEdit","/user/edit",
MemberView("routes.AccountEditPassword", "/user/edit/password/"), MView("", "/"),
MView("Password", "/password/"),
Action("PasswordSubmit", "/password/submit/"), // TODO: Full test this
UploadAction("AvatarSubmit", "/avatar/submit/").MaxSizeVar("int(c.Config.MaxRequestSize)"),
Action("RevokeAvatarSubmit", "/avatar/revoke/submit/"),
Action("UsernameSubmit", "/username/submit/"), // TODO: Full test this
MView("MFA", "/mfa/"),
MView("MFASetup", "/mfa/setup/"),
Action("MFASetupSubmit", "/mfa/setup/submit/"),
Action("MFADisableSubmit", "/mfa/disable/submit/"),
MView("Email", "/email/"),
View("EmailTokenSubmit", "/token/", "extraData").NoHeader(),
),
/*MView("routes.AccountEdit", "/user/edit/"),
MView("routes.AccountEditPassword", "/user/edit/password/"),
Action("routes.AccountEditPasswordSubmit", "/user/edit/password/submit/"), // TODO: Full test this Action("routes.AccountEditPasswordSubmit", "/user/edit/password/submit/"), // TODO: Full test this
UploadAction("routes.AccountEditAvatarSubmit", "/user/edit/avatar/submit/").MaxSizeVar("int(c.Config.MaxRequestSize)"), UploadAction("routes.AccountEditAvatarSubmit", "/user/edit/avatar/submit/").MaxSizeVar("int(c.Config.MaxRequestSize)"),
Action("routes.AccountEditRevokeAvatarSubmit", "/user/edit/avatar/revoke/submit/"), Action("routes.AccountEditRevokeAvatarSubmit", "/user/edit/avatar/revoke/submit/"),
Action("routes.AccountEditUsernameSubmit", "/user/edit/username/submit/"), // TODO: Full test this Action("routes.AccountEditUsernameSubmit", "/user/edit/username/submit/"), // TODO: Full test this
MemberView("routes.AccountEditMFA", "/user/edit/mfa/"), MView("routes.AccountEditMFA", "/user/edit/mfa/"),
MemberView("routes.AccountEditMFASetup", "/user/edit/mfa/setup/"), MView("routes.AccountEditMFASetup", "/user/edit/mfa/setup/"),
Action("routes.AccountEditMFASetupSubmit", "/user/edit/mfa/setup/submit/"), Action("routes.AccountEditMFASetupSubmit", "/user/edit/mfa/setup/submit/"),
Action("routes.AccountEditMFADisableSubmit", "/user/edit/mfa/disable/submit/"), Action("routes.AccountEditMFADisableSubmit", "/user/edit/mfa/disable/submit/"),
MemberView("routes.AccountEditEmail", "/user/edit/email/"), MView("routes.AccountEditEmail", "/user/edit/email/"),
View("routes.AccountEditEmailTokenSubmit", "/user/edit/token/", "extraData").NoHeader(), View("routes.AccountEditEmailTokenSubmit", "/user/edit/token/", "extraData").NoHeader(),*/
MemberView("routes.AccountLogins", "/user/edit/logins/"), MView("routes.AccountLogins", "/user/edit/logins/"),
MemberView("routes.LevelList", "/user/levels/"), MView("routes.LevelList", "/user/levels/"),
//MemberView("routes.LevelRankings", "/user/rankings/"), //MView("routes.LevelRankings", "/user/rankings/"),
//MemberView("routes.Alerts", "/user/alerts/"), //MView("routes.Alerts", "/user/alerts/"),
/*MView("routes.Convos", "/user/convos/"),
MView("routes.ConvosCreate", "/user/convos/create/"),
MView("routes.Convo", "/user/convo/","extraData"),
Action("routes.ConvosCreateSubmit", "/user/convos/create/submit/"),
Action("routes.ConvosDeleteSubmit", "/user/convos/delete/submit/","extraData"),
Action("routes.ConvosCreateReplySubmit", "/user/convo/create/submit/"),
Action("routes.ConvosDeleteReplySubmit", "/user/convo/delete/submit/"),*/
) )
} }
@ -76,7 +99,7 @@ func usersRoutes() *RouteGroup {
Action("routes.BanUserSubmit", "/users/ban/submit/", "extraData"), Action("routes.BanUserSubmit", "/users/ban/submit/", "extraData"),
Action("routes.UnbanUser", "/users/unban/", "extraData"), Action("routes.UnbanUser", "/users/unban/", "extraData"),
Action("routes.ActivateUser", "/users/activate/", "extraData"), Action("routes.ActivateUser", "/users/activate/", "extraData"),
MemberView("routes.IPSearch", "/users/ips/"), // TODO: .Perms("ViewIPs")? MView("routes.IPSearch", "/users/ips/"), // TODO: .Perms("ViewIPs")?
) )
} }