Compare commits

...

7 Commits

Author SHA1 Message Date
Bel LaPointe
e8b76d07e2 add logs 2022-01-13 09:10:18 -05:00
Bel LaPointe
63ef1f206b gitignore binary 2022-01-13 01:34:38 -05:00
Bel LaPointe
373e9ff3c3 todo 2022-01-13 01:12:26 -05:00
Bel LaPointe
d3fff1519b figured out image upload to matrix but now jpeg is hard coded 2022-01-13 01:12:12 -05:00
Bel LaPointe
2b6acc51fb try naming form for link to img, no dice 2022-01-13 01:08:13 -05:00
Bel LaPointe
fade4467d6 try png over jpeg for element, no dice 2022-01-13 00:55:40 -05:00
Bel LaPointe
c8800c010e todo 2022-01-13 00:29:24 -05:00
6 changed files with 29 additions and 8 deletions

1
.gitignore vendored
View File

@@ -3,3 +3,4 @@ todo-server-yaml
cmd/cmd
cmd/cli
cmd/pttodo/pttodo
/truckstop

View File

@@ -12,7 +12,7 @@
"RefreshURI": "https://api.imgur.com/oauth2/token",
"RefreshFormat": "refresh_token=%s\u0026client_id=%s\u0026client_secret=%s\u0026grant_type=refresh_token",
"RefreshMethod": "POST",
"UploadURI": "https://api.imgur.com/3/image",
"UploadURI": "https://api.imgur.com/3/image?name=something.jpeg",
"UploadMethod": "POST"
},
"Maps": {
@@ -74,7 +74,7 @@
"Room": "!WbawbZxHqnxxfhvcSj:synapse.home.blapointe.com"
}
},
"Once": false,
"Once": true,
"Brokers": {
"NTG": {
"Mock": true,

View File

@@ -259,14 +259,17 @@ func once() error {
if err != nil {
return err
}
log.Printf("once: all jobs: %+v", alljobs)
newjobs, err := dropStaleJobs(alljobs)
if err != nil {
return err
}
log.Printf("once: new jobs: %+v", newjobs)
jobs, err := dropBanlistJobs(newjobs)
if err != nil {
return err
}
log.Printf("once: sending jobs: %+v", jobs)
for i := range jobs {
if err := sendJob(jobs[i]); err != nil {
return err
@@ -318,6 +321,7 @@ func dropBanlistJobs(jobs []broker.Job) ([]broker.Job, error) {
func sendJob(job broker.Job) error {
sender := message.NewMatrix()
payload := job.FormatMultilineText()
log.Printf("once: send job %s if nonzero: %s", job.String(), payload)
if len(payload) == 0 {
return nil
}

View File

@@ -7,8 +7,10 @@ import (
"fmt"
"io/ioutil"
"local/truckstop/config"
"log"
"mime/multipart"
"net/http"
"net/url"
"time"
)
@@ -30,9 +32,17 @@ func refreshToken() error {
}
func uploadImage(b []byte) (string, error) {
images := config.Get().Images
buff := bytes.NewBuffer(nil)
writer := multipart.NewWriter(buff)
part, err := writer.CreateFormFile("image", "name")
name := "name"
if u, err := url.Parse(images.UploadURI); err != nil {
} else if s, ok := u.Query()["name"]; !ok {
} else {
name = s[0]
log.Printf("found name in upload uri: %s", name)
}
part, err := writer.CreateFormFile("image", name)
if err != nil {
return "", err
}
@@ -43,7 +53,6 @@ func uploadImage(b []byte) (string, error) {
}
writer.Close()
images := config.Get().Images
request, err := http.NewRequest(
images.UploadMethod,
images.UploadURI,

View File

@@ -1,6 +1,7 @@
package message
import (
"bytes"
"fmt"
"io/ioutil"
"local/truckstop/config"
@@ -129,14 +130,15 @@ func (m Matrix) SendImage(uri string) error {
if err != nil {
return err
}
publicURI, err := UploadImage(b)
if err != nil {
return err
}
c, err := m.getclient()
if err != nil {
return err
}
mediaUpload, err := c.UploadToContentRepo(bytes.NewReader(b), "image/jpeg", int64(len(b)))
if err != nil {
return err
}
publicURI := mediaUpload.ContentURI
resp, err := c.SendImage(m.room, "img", publicURI)
log.Printf("sent image %s => %s: %+v", uri, publicURI, resp)
return err

View File

@@ -1,4 +1,9 @@
todo:
- no hard code jpeg or have it in multiple places
- todo: switch house to selfhosted for rate limit
tags: now
- mark consumed;; save scroll id for matrix
- TEST its falling apart
- test each !command callbacks to matrix
- change matrix so I test my custom logic even if I dont fetch remote
- warn/err/etc. on clobbering ids.matrix since clients can mess with one another