mirror of
https://codeberg.org/Codeberg/pages-server.git
synced 2025-01-19 17:07:54 +00:00
break into own func and fix
This commit is contained in:
parent
40478215d0
commit
4a2a14272b
1 changed files with 30 additions and 15 deletions
|
@ -153,12 +153,7 @@ func (client *Client) ServeRawContent(targetOwner, targetRepo, ref, resource str
|
||||||
mimeType := client.getMimeTypeByExtension(resource)
|
mimeType := client.getMimeTypeByExtension(resource)
|
||||||
resp.Response.Header.Set(contentTypeHeader, mimeType)
|
resp.Response.Header.Set(contentTypeHeader, mimeType)
|
||||||
|
|
||||||
contentLeng, err2 := strconv.ParseInt(resp.Header.Get(contentLengthHeader), 20, 64)
|
if !shouldRespBeSavedToCache(resp.Response) {
|
||||||
if err2 != nil {
|
|
||||||
log.Error().Err(err2).Msg("could not parse content length")
|
|
||||||
}
|
|
||||||
if contentLeng <= 0 && contentLeng > fileCacheSizeLimit {
|
|
||||||
// if content to big or could not be determined we return now
|
|
||||||
return reader, resp.Response, err
|
return reader, resp.Response, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,16 +165,17 @@ func (client *Client) ServeRawContent(targetOwner, targetRepo, ref, resource str
|
||||||
// TODO: cache is half-empty if request is cancelled - does the ctx.Err() below do the trick?
|
// TODO: cache is half-empty if request is cancelled - does the ctx.Err() below do the trick?
|
||||||
// err = res.BodyWriteTo(io.MultiWriter(ctx.Response().BodyWriter(), &cacheBodyWriter))
|
// err = res.BodyWriteTo(io.MultiWriter(ctx.Response().BodyWriter(), &cacheBodyWriter))
|
||||||
*/
|
*/
|
||||||
body, err := io.ReadAll(io.LimitReader(reader, contentLeng))
|
body, err := io.ReadAll(io.LimitReader(reader, fileCacheSizeLimit))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err := client.responseCache.Set(cacheKey, FileResponse{
|
log.Error().Err(err).Msg("not expected")
|
||||||
Exists: true,
|
}
|
||||||
ETag: resp.Header.Get(eTagHeader),
|
if err := client.responseCache.Set(cacheKey, FileResponse{
|
||||||
MimeType: mimeType,
|
Exists: true,
|
||||||
Body: body,
|
ETag: resp.Header.Get(eTagHeader),
|
||||||
}, fileCacheTimeout); err != nil {
|
MimeType: mimeType,
|
||||||
log.Error().Err(err).Msg("could not save content in cache")
|
Body: body,
|
||||||
}
|
}, fileCacheTimeout); err != nil {
|
||||||
|
log.Error().Err(err).Msg("could not save content in cache")
|
||||||
}
|
}
|
||||||
return io.NopCloser(bytes.NewReader(body)), resp.Response, nil
|
return io.NopCloser(bytes.NewReader(body)), resp.Response, nil
|
||||||
}
|
}
|
||||||
|
@ -259,3 +255,22 @@ func (client *Client) getMimeTypeByExtension(resource string) string {
|
||||||
}
|
}
|
||||||
return mimeType
|
return mimeType
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func shouldRespBeSavedToCache(resp *http.Response) bool {
|
||||||
|
if resp == nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
contentLengRaw := resp.Header.Get(contentLengthHeader)
|
||||||
|
if contentLengRaw == "" {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
contentLeng, err := strconv.ParseInt(contentLengRaw, 10, 64)
|
||||||
|
if err != nil {
|
||||||
|
log.Error().Err(err).Msg("could not parse content length")
|
||||||
|
}
|
||||||
|
|
||||||
|
// if content to big or could not be determined we not cache it
|
||||||
|
return contentLeng > 0 && contentLeng < fileCacheSizeLimit
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue