mirror of
https://github.com/aljazceru/njump.git
synced 2025-12-17 14:24:27 +01:00
it's working! even on twitter.
This commit is contained in:
@@ -7,6 +7,7 @@
|
|||||||
<meta property="og:title" content="{{.title}}" />
|
<meta property="og:title" content="{{.title}}" />
|
||||||
{{ if .metadata.Picture }}
|
{{ if .metadata.Picture }}
|
||||||
<meta property="og:image" content="{{.metadata.Picture}}" />
|
<meta property="og:image" content="{{.metadata.Picture}}" />
|
||||||
|
<meta property="twitter:image" content="{{.proxy}}{{.metadata.Picture}}" />
|
||||||
{{end}} {{ if .metadata.About }}
|
{{end}} {{ if .metadata.About }}
|
||||||
<meta property="og:description" content="{{.metadata.About}}" />
|
<meta property="og:description" content="{{.metadata.About}}" />
|
||||||
{{end}}
|
{{end}}
|
||||||
@@ -29,7 +30,7 @@
|
|||||||
<meta property="twitter:card" content="summary" />
|
<meta property="twitter:card" content="summary" />
|
||||||
{{ if .image }}
|
{{ if .image }}
|
||||||
<meta property="og:image" content="{{.image}}" />
|
<meta property="og:image" content="{{.image}}" />
|
||||||
<meta name="twitter:image" content="{{.image}}" />
|
<meta name="twitter:image" content="{{.proxy}}{{.image}}" />
|
||||||
{{end}} {{ if .video }}
|
{{end}} {{ if .video }}
|
||||||
<meta property="og:video" content="{{.video}}" />
|
<meta property="og:video" content="{{.video}}" />
|
||||||
<meta property="og:video:secure_url" content="{{.video}}" />
|
<meta property="og:video:secure_url" content="{{.video}}" />
|
||||||
|
|||||||
3
image.go
3
image.go
@@ -23,7 +23,8 @@ func generate(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lines := normalizeText(event.Content)
|
lines := normalizeText(event.Content)
|
||||||
img, err := drawImage(lines)
|
|
||||||
|
img, err := drawImage(lines, getPreviewStyle(r))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("error writing image: %s", err)
|
log.Printf("error writing image: %s", err)
|
||||||
http.Error(w, "error writing image!", 500)
|
http.Error(w, "error writing image!", 500)
|
||||||
|
|||||||
1
main.go
1
main.go
@@ -8,6 +8,7 @@ import (
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
http.HandleFunc("/image/", generate)
|
http.HandleFunc("/image/", generate)
|
||||||
|
http.HandleFunc("/proxy/", proxy)
|
||||||
http.HandleFunc("/", render)
|
http.HandleFunc("/", render)
|
||||||
|
|
||||||
port := os.Getenv("PORT")
|
port := os.Getenv("PORT")
|
||||||
|
|||||||
32
proxy.go
Normal file
32
proxy.go
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httputil"
|
||||||
|
"net/url"
|
||||||
|
)
|
||||||
|
|
||||||
|
func proxy(w http.ResponseWriter, r *http.Request) {
|
||||||
|
fmt.Println(r.URL.Path, ":~", r.Header.Get("user-agent"))
|
||||||
|
|
||||||
|
src := r.URL.Query().Get("src")
|
||||||
|
urlParsed, err := url.Parse(src)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, "Invalid URL", http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if urlParsed.Scheme != "http" && urlParsed.Scheme != "https" {
|
||||||
|
http.Error(w, "The URL scheme is neither HTTP nor HTTPS", http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
proxy := httputil.ReverseProxy{
|
||||||
|
Director: func(r *http.Request) {
|
||||||
|
r.URL = urlParsed
|
||||||
|
r.Host = urlParsed.Host
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
proxy.ServeHTTP(w, r)
|
||||||
|
}
|
||||||
@@ -19,6 +19,7 @@ var eventHTML string
|
|||||||
var tmpl = template.Must(template.New("event").Parse(eventHTML))
|
var tmpl = template.Must(template.New("event").Parse(eventHTML))
|
||||||
|
|
||||||
func render(w http.ResponseWriter, r *http.Request) {
|
func render(w http.ResponseWriter, r *http.Request) {
|
||||||
|
fmt.Println(r.URL.Path, ":~", r.Header.Get("user-agent"))
|
||||||
w.Header().Set("Content-Type", "text/html")
|
w.Header().Set("Content-Type", "text/html")
|
||||||
|
|
||||||
code := r.URL.Path[1:]
|
code := r.URL.Path[1:]
|
||||||
@@ -65,7 +66,6 @@ func render(w http.ResponseWriter, r *http.Request) {
|
|||||||
if len(imageMatch) > 0 {
|
if len(imageMatch) > 0 {
|
||||||
image = imageMatch[0]
|
image = imageMatch[0]
|
||||||
}
|
}
|
||||||
fmt.Println("IMAGE", image)
|
|
||||||
|
|
||||||
videoMatch := regexp.MustCompile(`https:\/\/[^ ]*\.(mp4|webm)`).FindStringSubmatch(event.Content)
|
videoMatch := regexp.MustCompile(`https:\/\/[^ ]*\.(mp4|webm)`).FindStringSubmatch(event.Content)
|
||||||
var video string
|
var video string
|
||||||
@@ -170,6 +170,7 @@ func render(w http.ResponseWriter, r *http.Request) {
|
|||||||
"videoType": videoType,
|
"videoType": videoType,
|
||||||
"image": image,
|
"image": image,
|
||||||
"video": video,
|
"video": video,
|
||||||
|
"proxy": "https://" + hostname + "/proxy?src=",
|
||||||
"eventJSON": string(eventJSON),
|
"eventJSON": string(eventJSON),
|
||||||
}
|
}
|
||||||
if err := tmpl.ExecuteTemplate(w, "event", params); err != nil {
|
if err := tmpl.ExecuteTemplate(w, "event", params); err != nil {
|
||||||
|
|||||||
18
text.go
18
text.go
@@ -27,10 +27,18 @@ func normalizeText(t string) []string {
|
|||||||
return lines
|
return lines
|
||||||
}
|
}
|
||||||
|
|
||||||
func drawImage(lines []string) (image.Image, error) {
|
func drawImage(lines []string, style string) (image.Image, error) {
|
||||||
|
width, height, paddingLeft := 700, 525, 0
|
||||||
|
switch style {
|
||||||
|
case "twitter":
|
||||||
|
height = 366
|
||||||
|
case "telegram":
|
||||||
|
paddingLeft = 15
|
||||||
|
}
|
||||||
|
|
||||||
// get the physical image ready with colors/size
|
// get the physical image ready with colors/size
|
||||||
fg, bg := image.Black, image.White
|
fg, bg := image.Black, image.White
|
||||||
rgba := image.NewRGBA(image.Rect(0, 0, 700, 525))
|
rgba := image.NewRGBA(image.Rect(0, 0, width, height))
|
||||||
|
|
||||||
// draw the empty image
|
// draw the empty image
|
||||||
draw.Draw(rgba, rgba.Bounds(), bg, image.ZP, draw.Src)
|
draw.Draw(rgba, rgba.Bounds(), bg, image.ZP, draw.Src)
|
||||||
@@ -51,7 +59,7 @@ func drawImage(lines []string) (image.Image, error) {
|
|||||||
// draw each line separately
|
// draw each line separately
|
||||||
var count float64 = 1
|
var count float64 = 1
|
||||||
for _, line := range lines {
|
for _, line := range lines {
|
||||||
if err := drawText(c, line, count); err != nil {
|
if err := drawText(c, line, count, paddingLeft); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
count++
|
count++
|
||||||
@@ -60,12 +68,12 @@ func drawImage(lines []string) (image.Image, error) {
|
|||||||
return rgba, nil
|
return rgba, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func drawText(c *freetype.Context, text string, line float64) error {
|
func drawText(c *freetype.Context, text string, line float64, paddingLeft int) error {
|
||||||
// We need an offset because we need to know where exactly on the
|
// We need an offset because we need to know where exactly on the
|
||||||
// image to place the text. The `line` is how much of an offset
|
// image to place the text. The `line` is how much of an offset
|
||||||
// that we need to provide (which line the text is going on).
|
// that we need to provide (which line the text is going on).
|
||||||
offsetY := 10 + int(c.PointToFix32(FONT_SIZE*line)>>8)
|
offsetY := 10 + int(c.PointToFix32(FONT_SIZE*line)>>8)
|
||||||
|
|
||||||
_, err := c.DrawString(text, freetype.Pt(10, offsetY))
|
_, err := c.DrawString(text, freetype.Pt(10+paddingLeft, offsetY))
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user