mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-10-29 02:22:26 -05:00
[feature] Implement cache-control and etags for static assets (#711)
* start working on etag stuff * add + use cache middleware * generate etags on the fly * remove unused field * clean up filepath * add license headers to cache files * add attachgroup function to router interface * move cache into web module * rename a couple things * remove attachStaticFS function from router * rename + tidy up a few things * mount assets filesystem * create assetsFileInfoCache * update comment * simplify hash * fix string fmt * skip last mod chk, prefer strong etags w/long cache * move base handler to its own file this matches the modules in the api folder * generate new etag if file was modified * wrap strong etag in quotation marks as per spec * clarify logic in avatar search * make hashing a little niftier
This commit is contained in:
parent
ab03318b7a
commit
c3b6a5b0f9
11 changed files with 466 additions and 164 deletions
|
|
@ -39,3 +39,10 @@ func (r *router) AttachMiddleware(middleware gin.HandlerFunc) {
|
|||
func (r *router) AttachNoRouteHandler(handler gin.HandlerFunc) {
|
||||
r.engine.NoRoute(handler)
|
||||
}
|
||||
|
||||
// AttachGroup attaches the given handlers into a group with the given relativePath as
|
||||
// base path for that group. It then returns the *gin.RouterGroup so that the caller
|
||||
// can add any extra middlewares etc specific to that group, as desired.
|
||||
func (r *router) AttachGroup(relativePath string, handlers ...gin.HandlerFunc) *gin.RouterGroup {
|
||||
return r.engine.Group(relativePath, handlers...)
|
||||
}
|
||||
|
|
|
|||
|
|
@ -47,8 +47,10 @@ type Router interface {
|
|||
AttachMiddleware(handler gin.HandlerFunc)
|
||||
// Attach 404 NoRoute handler
|
||||
AttachNoRouteHandler(handler gin.HandlerFunc)
|
||||
// Add Gin StaticFS handler
|
||||
AttachStaticFS(relativePath string, fs http.FileSystem)
|
||||
// Attach a router group, and receive that group back.
|
||||
// More middlewares and handlers can then be attached on
|
||||
// the group by the caller.
|
||||
AttachGroup(path string, handlers ...gin.HandlerFunc) *gin.RouterGroup
|
||||
// Start the router
|
||||
Start()
|
||||
// Stop the router
|
||||
|
|
@ -62,11 +64,6 @@ type router struct {
|
|||
certManager *autocert.Manager
|
||||
}
|
||||
|
||||
// Add Gin StaticFS handler
|
||||
func (r *router) AttachStaticFS(relativePath string, fs http.FileSystem) {
|
||||
r.engine.StaticFS(relativePath, fs)
|
||||
}
|
||||
|
||||
// Start starts the router nicely. It will serve two handlers if letsencrypt is enabled, and only the web/API handler if letsencrypt is not enabled.
|
||||
func (r *router) Start() {
|
||||
// listen is the server start function, by
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue