diff options
Diffstat (limited to 'internal/api')
| -rw-r--r-- | internal/api/fileserver.go | 36 | ||||
| -rw-r--r-- | internal/api/fileserver/servefile.go | 5 | ||||
| -rw-r--r-- | internal/api/model/content.go | 5 | 
3 files changed, 23 insertions, 23 deletions
| diff --git a/internal/api/fileserver.go b/internal/api/fileserver.go index 042936551..b1ebae045 100644 --- a/internal/api/fileserver.go +++ b/internal/api/fileserver.go @@ -31,31 +31,25 @@ type Fileserver struct {  	fileserver *fileserver.Module  } -// maxAge returns an appropriate max-age value for the -// storage method that's being used. -// -// The default max-age is very long to reflect that we -// never host different files at the same URL (since -// ULIDs are generated per piece of media), so we can -// easily prevent clients having to fetch files repeatedly. -// -// If we're using non-proxying s3, however, the max age is -// significantly shorter, to ensure that clients don't -// cache redirect responses to expired pre-signed URLs. -func maxAge() string { -	if config.GetStorageBackend() == "s3" && !config.GetStorageS3Proxy() { -		return "max-age=86400" // 24h -	} - -	return "max-age=604800" // 7d -} -  func (f *Fileserver) Route(r router.Router, m ...gin.HandlerFunc) {  	fileserverGroup := r.AttachGroup("fileserver") -	// attach middlewares appropriate for this group +	// Attach middlewares appropriate for this group.  	fileserverGroup.Use(m...) -	fileserverGroup.Use(middleware.CacheControl("private", maxAge())) +	// If we're using local storage or proxying s3, we can set a +	// long max-age on all file requests to reflect that we +	// never host different files at the same URL (since +	// ULIDs are generated per piece of media), so we can +	// easily prevent clients having to fetch files repeatedly. +	// +	// If we *are* using non-proxying s3, however, the max age +	// must be set dynamically within the request handler, +	// based on how long the signed URL has left to live before +	// it expires. This ensures that clients won't cache expired +	// links. This is done within fileserver/servefile.go. +	if config.GetStorageBackend() == "local" || config.GetStorageS3Proxy() { +		fileserverGroup.Use(middleware.CacheControl("private", "max-age=604800")) // 7d +	}  	f.fileserver.Route(fileserverGroup.Handle)  } diff --git a/internal/api/fileserver/servefile.go b/internal/api/fileserver/servefile.go index df3c83fe7..ec70ef9ae 100644 --- a/internal/api/fileserver/servefile.go +++ b/internal/api/fileserver/servefile.go @@ -24,6 +24,7 @@ import (  	"net/http"  	"strconv"  	"strings" +	"time"  	"codeberg.org/gruf/go-fastcopy"  	"github.com/gin-gonic/gin" @@ -89,6 +90,10 @@ func (m *Module) ServeFile(c *gin.Context) {  	if content.URL != nil {  		// This is a non-local, non-proxied S3 file we're redirecting to. +		// Derive the max-age value from how long the link has left until +		// it expires. +		maxAge := int(time.Until(content.URL.Expiry).Seconds()) +		c.Header("Cache-Control", "private,max-age="+strconv.Itoa(maxAge))  		c.Redirect(http.StatusFound, content.URL.String())  		return  	} diff --git a/internal/api/model/content.go b/internal/api/model/content.go index 4c0151c2c..0f8f73f1d 100644 --- a/internal/api/model/content.go +++ b/internal/api/model/content.go @@ -20,8 +20,9 @@ package model  import (  	"io" -	"net/url"  	"time" + +	"github.com/superseriousbusiness/gotosocial/internal/storage"  )  // Content wraps everything needed to serve a blob of content (some kind of media) through the API. @@ -35,7 +36,7 @@ type Content struct {  	// Actual content  	Content io.ReadCloser  	// Resource URL to forward to if the file can be fetched from the storage directly (e.g signed S3 URL) -	URL *url.URL +	URL *storage.PresignedURL  }  // GetContentRequestForm describes a piece of content desired by the caller of the fileserver API. | 
