mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-03-01 16:20:59 +00:00
[feature] Use ETag for robots.txt to prevent mishaps (#3829)
* [feature] Use ETag for robots.txt to prevent mishaps * check incoming if-none-match header
This commit is contained in:
parent
c9de6c9a1e
commit
fd670c6a27
3 changed files with 26 additions and 1 deletions
|
@ -39,7 +39,7 @@ func (rb *Robots) Route(r *router.Router, m ...gin.HandlerFunc) {
|
|||
// https://www.rfc-editor.org/rfc/rfc9309.html#section-2.4
|
||||
robotsGroup.Use(
|
||||
middleware.CacheControl(middleware.CacheControlConfig{
|
||||
Directives: []string{"public", "max-age=86400"},
|
||||
Directives: []string{"public", "no-cache"},
|
||||
Vary: []string{"Accept-Encoding"},
|
||||
}),
|
||||
)
|
||||
|
|
|
@ -49,9 +49,29 @@ func (m *Module) Route(attachHandler func(method string, path string, f ...gin.H
|
|||
}
|
||||
|
||||
func (m *Module) robotsGETHandler(c *gin.Context) {
|
||||
const ETag = "\"" + apiutil.RobotsTxtETag + "\""
|
||||
c.Header("ETag", ETag)
|
||||
|
||||
if c.Request.Header.Get("If-None-Match") == ETag {
|
||||
// Cached.
|
||||
c.AbortWithStatus(http.StatusNotModified)
|
||||
return
|
||||
}
|
||||
|
||||
// Not cached, serve.
|
||||
c.String(http.StatusOK, apiutil.RobotsTxt)
|
||||
}
|
||||
|
||||
func (m *Module) robotsGETHandlerDisallowNodeInfo(c *gin.Context) {
|
||||
const ETag = "\"" + apiutil.RobotsTxtDisallowNodeInfoETag + "\""
|
||||
c.Header("ETag", ETag)
|
||||
|
||||
if c.Request.Header.Get("If-None-Match") == ETag {
|
||||
// Cached.
|
||||
c.AbortWithStatus(http.StatusNotModified)
|
||||
return
|
||||
}
|
||||
|
||||
// Not cached, serve.
|
||||
c.String(http.StatusOK, apiutil.RobotsTxtDisallowNodeInfo)
|
||||
}
|
||||
|
|
|
@ -130,4 +130,9 @@ Disallow: /.well-known/webfinger
|
|||
Disallow: /.well-known/nodeinfo
|
||||
Disallow: /nodeinfo/
|
||||
`
|
||||
|
||||
// MD5 hash of basic robots.txt.
|
||||
RobotsTxtETag = `ce6729aacbb16fae3628210c04b462b7`
|
||||
// MD5 hash of robots.txt with NodeInfo disallowed.
|
||||
RobotsTxtDisallowNodeInfoETag = `a1e4ce6342978bc8d6c3e3dfab07cab4`
|
||||
)
|
||||
|
|
Loading…
Reference in a new issue