cli #1
97
internal/cache/cache.go
vendored
Normal file
97
internal/cache/cache.go
vendored
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
package cache
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/sha1"
|
||||||
|
"encoding/hex"
|
||||||
|
"errors"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/labstack/echo/v4"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Cache struct {
|
||||||
|
CacheDir string
|
||||||
|
Disabled bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func getCacheDir() (string, error) {
|
||||||
|
baseDir, err := os.UserCacheDir()
|
||||||
|
if err != nil {
|
||||||
|
baseDir = "/tmp"
|
||||||
|
}
|
||||||
|
cacheDir := filepath.Join(baseDir, "startpage")
|
||||||
|
err = os.MkdirAll(cacheDir, 0o755)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return cacheDir, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func getProfileCacheDir(profile string) (string, error) {
|
||||||
|
var profileCacheDir string
|
||||||
|
|
||||||
|
cacheDir, err := getCacheDir()
|
||||||
|
if err != nil {
|
||||||
|
return profileCacheDir, err
|
||||||
|
}
|
||||||
|
|
||||||
|
profileCacheDir = filepath.Join(cacheDir, profile)
|
||||||
|
err = os.MkdirAll(cacheDir, 0o755)
|
||||||
|
return profileCacheDir, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewCache(profile string) Cache {
|
||||||
|
cacheDir, err := getProfileCacheDir(profile)
|
||||||
|
|
||||||
|
return Cache{
|
||||||
|
CacheDir: cacheDir,
|
||||||
|
Disabled: err != nil,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const baseCacheUrl = "cache"
|
||||||
|
|
||||||
|
func (c Cache) StartStaticServer(e *echo.Echo) error {
|
||||||
|
e.Static("/"+baseCacheUrl, c.CacheDir)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func hashUrl(url string) string {
|
||||||
|
h := sha1.New()
|
||||||
|
io.WriteString(h, url)
|
||||||
|
return hex.EncodeToString(h.Sum(nil))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Cache) CacheUrl(urlString string) (string, error) {
|
||||||
|
filename := hashUrl(urlString) + filepath.Ext(urlString)
|
||||||
|
targetPath := filepath.Join(c.CacheDir, filename)
|
||||||
|
|
||||||
|
// if the file was already downloaded it doesn't need to be downloaded again
|
||||||
|
if _, err := os.Stat(targetPath); errors.Is(err, os.ErrNotExist) {
|
||||||
|
resp, err := http.Get(urlString)
|
||||||
|
if !errors.Is(err, os.ErrNotExist) {
|
||||||
|
return urlString, err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
file, err := os.Create(targetPath)
|
||||||
|
if err != nil {
|
||||||
|
return urlString, err
|
||||||
|
}
|
||||||
|
defer file.Close()
|
||||||
|
|
||||||
|
_, err = io.Copy(file, resp.Body)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return urlString, err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return url.JoinPath(baseCacheUrl, filename)
|
||||||
|
}
|
||||||
|
|
||||||
|
return url.JoinPath(baseCacheUrl, filename)
|
||||||
|
}
|
@ -138,12 +138,3 @@ func (rc *Config) LoadConfigFile(file string) error {
|
|||||||
|
|
||||||
return toml.Unmarshal(content, rc)
|
return toml.Unmarshal(content, rc)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Config) Init() error {
|
|
||||||
log.Println("downloading website icons...")
|
|
||||||
for i := range c.Template.Websites {
|
|
||||||
c.Template.Websites[i].Cache()
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
|
"gitea.elara.ws/Hazel/transfem-startpage/internal/cache"
|
||||||
"gitea.elara.ws/Hazel/transfem-startpage/internal/rendering"
|
"gitea.elara.ws/Hazel/transfem-startpage/internal/rendering"
|
||||||
"github.com/labstack/echo/v4"
|
"github.com/labstack/echo/v4"
|
||||||
)
|
)
|
||||||
@ -17,11 +18,6 @@ func Start(profile string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = Config.Init()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
err = Config.FetchDiyHrt()
|
err = Config.FetchDiyHrt()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println(err)
|
log.Println(err)
|
||||||
@ -30,11 +26,19 @@ func Start(profile string) error {
|
|||||||
e := echo.New()
|
e := echo.New()
|
||||||
|
|
||||||
// statically serve the file
|
// statically serve the file
|
||||||
cacheDir, err := rendering.GetCacheDir()
|
cache := cache.NewCache(profile)
|
||||||
if err == nil {
|
if !cache.Disabled {
|
||||||
e.Static("/cache", cacheDir)
|
cache.StartStaticServer(e)
|
||||||
} else {
|
|
||||||
log.Println("didn't enable cache dir", err)
|
log.Println("downloading website icons...")
|
||||||
|
for i, w := range Config.Template.Websites {
|
||||||
|
u, err := cache.CacheUrl(w.ImageUrl)
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
}
|
||||||
|
Config.Template.Websites[i].ImageUrl = u
|
||||||
|
Config.Template.Websites[i].IsFetched = true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://echo.labstack.com/docs/cookbook/embed-resources
|
// https://echo.labstack.com/docs/cookbook/embed-resources
|
||||||
|
Loading…
x
Reference in New Issue
Block a user