Compare commits
2 Commits
a9e9185b41
...
036e9fa4a1
Author | SHA1 | Date | |
---|---|---|---|
036e9fa4a1 | |||
262e4ec4d7 |
19
main.go
19
main.go
@ -11,8 +11,12 @@ import (
|
||||
"time"
|
||||
|
||||
"github.com/canhlinh/svg2png"
|
||||
"github.com/gofiber/fiber/v2"
|
||||
"github.com/patrickmn/go-cache"
|
||||
|
||||
"github.com/gofiber/fiber/v2"
|
||||
"github.com/gofiber/fiber/v2/middleware/compress"
|
||||
"github.com/gofiber/fiber/v2/middleware/cors"
|
||||
"github.com/gofiber/fiber/v2/middleware/logger"
|
||||
)
|
||||
|
||||
//go:embed index.html svg.tmpl
|
||||
@ -21,7 +25,11 @@ var content embed.FS
|
||||
|
||||
func main() {
|
||||
app := fiber.New()
|
||||
ch := cache.New(5*24*time.Hour, 7*24*time.Hour)
|
||||
app.Use(compress.New())
|
||||
app.Use(cors.New())
|
||||
app.Use(logger.New())
|
||||
|
||||
ch := cache.New(6*time.Hour, 24*time.Hour)
|
||||
|
||||
app.Get("/", func(c *fiber.Ctx) error {
|
||||
c.Type("html", "UTF8")
|
||||
@ -45,13 +53,14 @@ func main() {
|
||||
key := generateKey(vars)
|
||||
|
||||
png, found := ch.Get(key)
|
||||
if !found {
|
||||
if !found || len(png.([]byte)) == 0 {
|
||||
var err error
|
||||
png, err = generateImage(vars)
|
||||
if err != nil {
|
||||
return err
|
||||
fmt.Println(err)
|
||||
return c.SendStatus(500)
|
||||
}
|
||||
ch.Set(key, png, -1)
|
||||
ch.Set(key, png, 0)
|
||||
}
|
||||
|
||||
c.Type("png")
|
||||
|
19
svg.tmpl
19
svg.tmpl
@ -42,15 +42,19 @@
|
||||
font-family: 'Roboto Bold';
|
||||
margin: 0;
|
||||
position: fixed;
|
||||
top: 80px;
|
||||
top: 100px;
|
||||
left: 50px;
|
||||
height: 300px;
|
||||
width: 800px;
|
||||
font-size: 70px;
|
||||
font-size: 80px;
|
||||
font-weight: 900;
|
||||
line-height: 70px;
|
||||
line-height: 75px;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
display: -webkit-box !important;
|
||||
-webkit-line-clamp: 4;
|
||||
-webkit-box-orient: vertical;
|
||||
white-space: normal;
|
||||
}
|
||||
h2 {
|
||||
font-family: 'Roboto Medium';
|
||||
@ -58,6 +62,7 @@
|
||||
position: fixed;
|
||||
top: 50px;
|
||||
left: 50px;
|
||||
font-size: 40px;
|
||||
font-weight: 900;
|
||||
}
|
||||
#profilePic {
|
||||
@ -70,11 +75,11 @@
|
||||
.tags {
|
||||
position: fixed;
|
||||
left: 50px;
|
||||
top: 400px;
|
||||
top: 420px;
|
||||
width: 800px;
|
||||
height: 25px;
|
||||
line-height: 25px;
|
||||
font-size: 15px;
|
||||
font-size: 25px;
|
||||
font-weight: 200;
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
@ -90,7 +95,7 @@
|
||||
bottom: 25px;
|
||||
height: 25px;
|
||||
line-height: 25px;
|
||||
font-size: 15px;
|
||||
font-size: 20px;
|
||||
font-weight: 200;
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
@ -99,7 +104,7 @@
|
||||
fill: var(--foreground-color);
|
||||
}
|
||||
.social span {
|
||||
margin: 0 3px;
|
||||
margin: 0 5px;
|
||||
}
|
||||
.social svg:not(:first-of-type) {
|
||||
margin-left: 20px;
|
||||
|
Loading…
Reference in New Issue
Block a user