Browse Source

Finish Guggy integration

pull/75/head
Luke Barnard 8 years ago
parent
commit
4a61575253
  1. 1
      src/github.com/matrix-org/go-neb/goneb.go
  2. 66
      src/github.com/matrix-org/go-neb/services/guggy/guggy.go

1
src/github.com/matrix-org/go-neb/goneb.go

@ -9,6 +9,7 @@ import (
_ "github.com/matrix-org/go-neb/realms/jira" _ "github.com/matrix-org/go-neb/realms/jira"
"github.com/matrix-org/go-neb/server" "github.com/matrix-org/go-neb/server"
_ "github.com/matrix-org/go-neb/services/echo" _ "github.com/matrix-org/go-neb/services/echo"
_ "github.com/matrix-org/go-neb/services/guggy"
_ "github.com/matrix-org/go-neb/services/giphy" _ "github.com/matrix-org/go-neb/services/giphy"
_ "github.com/matrix-org/go-neb/services/github" _ "github.com/matrix-org/go-neb/services/github"
_ "github.com/matrix-org/go-neb/services/jira" _ "github.com/matrix-org/go-neb/services/jira"

66
src/github.com/matrix-org/go-neb/services/guggy/guggy.go

@ -2,30 +2,16 @@ package services
import ( import (
"encoding/json" "encoding/json"
"errors"
"bytes"
"math"
log "github.com/Sirupsen/logrus" log "github.com/Sirupsen/logrus"
"github.com/matrix-org/go-neb/matrix" "github.com/matrix-org/go-neb/matrix"
"github.com/matrix-org/go-neb/plugin" "github.com/matrix-org/go-neb/plugin"
"github.com/matrix-org/go-neb/types" "github.com/matrix-org/go-neb/types"
"net/http" "net/http"
"net/url"
"strconv" "strconv"
"strings" "strings"
) )
type result struct {
Slug string `json:"slug"`
Images struct {
Original struct {
URL string `json:"url"`
// guggy returns ints as strings..
Width string `json:"width"`
Height string `json:"height"`
Size string `json:"size"`
} `json:"original"`
} `json:"images"`
}
type guggyQuery struct { type guggyQuery struct {
// "mp4" of "gif" // "mp4" of "gif"
Format string `json:"format"` Format string `json:"format"`
@ -33,14 +19,17 @@ type guggyQuery struct {
Sentence string `json:"sentence"` Sentence string `json:"sentence"`
} }
type guggySearch struct {
Data []result
type guggyGifResult struct {
ReqID string `json:"reqId"`
GIF string `json:"gif"`
Width float64 `json:"width"`
Height float64 `json:"height"`
} }
type guggyService struct { type guggyService struct {
id string id string
serviceUserID string serviceUserID string
APIKey string // key is Cb7aEsJIdjD37c3
APIKey string
} }
func (s *guggyService) ServiceUserID() string { return s.serviceUserID } func (s *guggyService) ServiceUserID() string { return s.serviceUserID }
@ -70,45 +59,43 @@ func (s *guggyService) cmdGuggy(client *matrix.Client, roomID, userID string, ar
if err != nil { if err != nil {
return nil, err return nil, err
} }
mxc, err := client.UploadLink(gifResult.Images.Original.URL)
mxc, err := client.UploadLink(gifResult.GIF)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return matrix.ImageMessage{ return matrix.ImageMessage{
MsgType: "m.image", MsgType: "m.image",
Body: gifResult.Slug,
Body: gifResult.ReqID,
URL: mxc, URL: mxc,
Info: matrix.ImageInfo{ Info: matrix.ImageInfo{
Height: asInt(gifResult.Images.Original.Height),
Width: asInt(gifResult.Images.Original.Width),
Height: uint(math.Floor(gifResult.Height)),
Width: uint(math.Floor(gifResult.Width)),
Mimetype: "image/gif", Mimetype: "image/gif",
Size: asInt(gifResult.Images.Original.Size),
}, },
}, nil }, nil
} }
// text2gifGuggy returns info about a gif // text2gifGuggy returns info about a gif
func (s *guggyService) text2gifGuggy(querySentence string) (*result, error) {
func (s *guggyService) text2gifGuggy(querySentence string) (*guggyGifResult, error) {
log.Info("Transforming to GIF query ", querySentence) log.Info("Transforming to GIF query ", querySentence)
u, err := url.Parse("http://text2gif.guggy.com/guggify")
if err != nil {
return nil, err
}
client := &http.Client{ } client := &http.Client{ }
var query guggyQuery var query guggyQuery
query.format = "gif"
query.sentence = querySentence
query.Format = "gif"
query.Sentence = querySentence
var reqBody bytes.Buffer
if json.NewEncoder(reqBody).Encode(query); err != nil {
reqBody, err := json.Marshal(query);
if err != nil {
return nil, err return nil, err
} }
req, err := http.NewRequest("POST", u, reqBody)
reader := bytes.NewReader(reqBody)
req, err := http.NewRequest("POST", "http://text2gif.guggy.com/guggify", reader)
if err != nil { if err != nil {
log.Error(err)
return nil, err return nil, err
} }
req.Header.Add("Content-Type", "application/json") req.Header.Add("Content-Type", "application/json")
@ -119,16 +106,15 @@ func (s *guggyService) text2gifGuggy(querySentence string) (*result, error) {
defer res.Body.Close() defer res.Body.Close()
} }
if err != nil { if err != nil {
log.Error(err)
return nil, err return nil, err
} }
var search guggySearch
if err := json.NewDecoder(res.Body).Decode(&search); err != nil {
var result guggyGifResult
if err := json.NewDecoder(res.Body).Decode(&result); err != nil {
return nil, err return nil, err
} }
if len(search.Data) == 0 {
return nil, errors.New("No results")
}
return &search.Data[0], nil
return &result, nil
} }
func asInt(strInt string) uint { func asInt(strInt string) uint {

Loading…
Cancel
Save