diff options
author | Wim <wim@42.be> | 2017-02-18 23:10:22 +0100 |
---|---|---|
committer | Wim <wim@42.be> | 2017-02-18 23:13:46 +0100 |
commit | 73f01ad8d813505c6309fe568d0abc597cff8790 (patch) | |
tree | 426bc1779c1abcf2afe56e2dc2a2f43d70aae278 /bridge/api | |
parent | 930b639cc9cd2d2873302f30303378c0e53816a8 (diff) | |
download | matterbridge-msglm-73f01ad8d813505c6309fe568d0abc597cff8790.tar.gz matterbridge-msglm-73f01ad8d813505c6309fe568d0abc597cff8790.tar.bz2 matterbridge-msglm-73f01ad8d813505c6309fe568d0abc597cff8790.zip |
Add REST API support
Diffstat (limited to 'bridge/api')
-rw-r--r-- | bridge/api/api.go | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/bridge/api/api.go b/bridge/api/api.go new file mode 100644 index 00000000..4870ee6a --- /dev/null +++ b/bridge/api/api.go @@ -0,0 +1,91 @@ +package api + +import ( + "github.com/42wim/matterbridge/bridge/config" + log "github.com/Sirupsen/logrus" + "github.com/labstack/echo" + "github.com/zfjagann/golang-ring" + "net/http" + "sync" +) + +type Api struct { + Config *config.Protocol + Remote chan config.Message + Account string + Messages ring.Ring + sync.RWMutex +} + +type ApiMessage struct { + Text string `json:"text"` + Username string `json:"username"` + Avatar string `json:"avatar"` +} + +var flog *log.Entry +var protocol = "api" + +func init() { + flog = log.WithFields(log.Fields{"module": protocol}) +} + +func New(cfg config.Protocol, account string, c chan config.Message) *Api { + b := &Api{} + e := echo.New() + b.Messages = ring.Ring{} + b.Messages.SetCapacity(cfg.Buffer) + b.Config = &cfg + b.Account = account + b.Remote = c + e.GET("/api/messages", b.handleMessages) + e.POST("/api/message", b.handlePostMessage) + go func() { + flog.Fatal(e.Start(cfg.BindAddress)) + }() + return b +} + +func (b *Api) Connect() error { + return nil +} +func (b *Api) Disconnect() error { + return nil + +} +func (b *Api) JoinChannel(channel string) error { + return nil + +} + +func (b *Api) Send(msg config.Message) error { + b.Lock() + defer b.Unlock() + b.Messages.Enqueue(&msg) + return nil +} + +func (b *Api) handlePostMessage(c echo.Context) error { + message := &ApiMessage{} + if err := c.Bind(message); err != nil { + return err + } + b.Remote <- config.Message{ + Text: message.Text, + Username: message.Username, + Channel: "api", + Avatar: message.Avatar, + Account: b.Account, + } + return c.JSON(http.StatusOK, message) +} + +func (b *Api) handleMessages(c echo.Context) error { + b.Lock() + defer b.Unlock() + for _, msg := range b.Messages.Values() { + c.JSONPretty(http.StatusOK, msg, " ") + } + b.Messages = ring.Ring{} + return nil +} |