Merge pull request #88 from ev2-1/main

fix cache & make faster
master
HimbeerserverDE 2022-04-21 21:12:54 +02:00 committed by GitHub
commit 978a609684
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 26 deletions

View File

@ -231,17 +231,10 @@ func handleContent(cc *contentConn) {
case *mt.ToCltAnnounceMedia:
var filenames []string
RequestLoop:
for _, f := range cmd.Files {
switch len(f.Base64SHA1) % 4 {
case 2:
f.Base64SHA1 += "=="
case 3:
f.Base64SHA1 += "="
}
if cc.fromCache(f.Name, f.Base64SHA1) {
break
continue
}
filenames = append(filenames, f.Name)
@ -249,7 +242,7 @@ func handleContent(cc *contentConn) {
for i, mf := range cc.media {
if mf.name == f.Name {
cc.media[i].base64SHA1 = f.Base64SHA1
continue RequestLoop
continue
}
}

View File

@ -2,23 +2,24 @@ package proxy
import (
"crypto/sha1"
"encoding/hex"
"encoding/base64"
"os"
"strings"
)
func (cc *contentConn) fromCache(filename, base64SHA1 string) bool {
os.Mkdir(Path("cache"), 0777)
hash, err := b64.DecodeString(base64SHA1)
if err != nil {
cc.log("<-", base64SHA1, ": ", err)
return false
}
// convert to filename safe b64
base64SHA1Filesafe := strings.Replace(base64SHA1, "/", "_", -1)
base64SHA1Filesafe = strings.Replace(base64SHA1Filesafe, "+", "-", -1)
hexSHA1 := hex.EncodeToString(hash)
data, err := os.ReadFile(Path("cache/", hexSHA1))
data, err := os.ReadFile(Path("cache/", base64SHA1Filesafe))
if err != nil {
if !os.IsNotExist(err) {
cc.log("->", "cache", err)
}
return false
}
@ -35,20 +36,17 @@ func (cc *contentConn) updateCache() {
os.Mkdir(Path("cache"), 0777)
for _, f := range cc.media {
hash, err := b64.DecodeString(f.base64SHA1)
if err != nil {
cc.log("<-", f.base64SHA1, ": ", err)
continue
}
// convert to filename safe b64
base64SHA1Filesafe := strings.Replace(f.base64SHA1, "/", "_", -1)
base64SHA1Filesafe = strings.Replace(base64SHA1Filesafe, "+", "-", -1)
hexSHA1 := hex.EncodeToString(hash)
os.WriteFile(Path("cache/", hexSHA1), f.data, 0666)
os.WriteFile(Path("cache/", base64SHA1Filesafe), f.data, 0666)
}
}
func cacheMedia(f mediaFile) {
hash := sha1.Sum(f.data)
sum := hex.EncodeToString(hash[:])
sum := base64.RawStdEncoding.EncodeToString(hash[:])
os.WriteFile(Path("cache/", sum), f.data, 0666)
}