Skip to content

Commit

Permalink
feat: post messenger
Browse files Browse the repository at this point in the history
  • Loading branch information
xhofe committed Jul 1, 2022
1 parent a6e5edc commit e389124
Show file tree
Hide file tree
Showing 6 changed files with 120 additions and 4 deletions.
1 change: 1 addition & 0 deletions internal/bootstrap/data/data.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,6 @@ func InitData() {
initSettings()
if args.Dev {
initDevData()
initDevDo()
}
}
22 changes: 22 additions & 0 deletions internal/bootstrap/data/dev.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ package data

import (
"context"
"github.com/alist-org/alist/v3/cmd/args"
"github.com/alist-org/alist/v3/internal/db"
"github.com/alist-org/alist/v3/internal/message"
"github.com/alist-org/alist/v3/internal/model"
"github.com/alist-org/alist/v3/internal/operations"
log "github.com/sirupsen/logrus"
Expand Down Expand Up @@ -30,3 +32,23 @@ func initDevData() {
log.Fatalf("failed to create user: %+v", err)
}
}

func initDevDo() {
if args.Dev {
go func() {
err := message.GetMessenger().WaitSend(map[string]string{
"type": "dev",
"msg": "dev mode",
}, 10)
if err != nil {
log.Debugf("%+v", err)
}
m, err := message.GetMessenger().WaitReceive(10)
if err != nil {
log.Debugf("%+v", err)
} else {
log.Debugf("received: %+v", m)
}
}()
}
}
12 changes: 8 additions & 4 deletions internal/message/message.go
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
package message

type Messenger interface {
Send(string, interface{}) error
WaitSend(string, interface{}) error
Receive(string) (string, error)
WaitReceive(string) (string, error)
Send(interface{}) error
Receive() (string, error)
WaitSend(interface{}, int) error
WaitReceive(int) (string, error)
}

func GetMessenger() Messenger {
return PostInstance
}
81 changes: 81 additions & 0 deletions internal/message/post.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
package message

import (
"github.com/alist-org/alist/v3/server/common"
"github.com/gin-gonic/gin"
"github.com/pkg/errors"
"time"
)

type Post struct {
Received chan string // received messages from web
ToSend chan interface{} // messages to send to web
}

type Req struct {
Message string `json:"message" form:"message"`
}

func (p *Post) GetHandle(c *gin.Context) {
select {
case message := <-p.ToSend:
common.SuccessResp(c, message)
default:
common.ErrorStrResp(c, "no message", 404)
}
}

func (p *Post) SendHandle(c *gin.Context) {
var req Req
if err := c.ShouldBind(&req); err != nil {
common.ErrorResp(c, err, 400)
return
}
select {
case p.Received <- req.Message:
common.SuccessResp(c)
default:
common.ErrorStrResp(c, "send failed", 500)
}
}

func (p *Post) Send(data interface{}) error {
select {
case p.ToSend <- data:
return nil
default:
return errors.New("send failed")
}
}

func (p *Post) Receive() (string, error) {
select {
case message := <-p.Received:
return message, nil
default:
return "", errors.New("receive failed")
}
}

func (p *Post) WaitSend(data interface{}, d int) error {
select {
case p.ToSend <- data:
return nil
case <-time.After(time.Duration(d) * time.Second):
return errors.New("send timeout")
}
}

func (p *Post) WaitReceive(d int) (string, error) {
select {
case message := <-p.Received:
return message, nil
case <-time.After(time.Duration(d) * time.Second):
return "", errors.New("receive timeout")
}
}

var PostInstance = &Post{
Received: make(chan string),
ToSend: make(chan interface{}),
}
3 changes: 3 additions & 0 deletions internal/message/ws.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package message

// TODO websocket implementation
5 changes: 5 additions & 0 deletions server/router.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package server

import (
"github.com/alist-org/alist/v3/internal/conf"
"github.com/alist-org/alist/v3/internal/message"
"github.com/alist-org/alist/v3/server/common"
"github.com/alist-org/alist/v3/server/controllers"
"github.com/alist-org/alist/v3/server/middlewares"
Expand Down Expand Up @@ -68,6 +69,10 @@ func Init(r *gin.Engine) {
task.GET("/copy/done", controllers.DoneCopyTask)
task.POST("/copy/cancel", controllers.CancelCopyTask)

ms := admin.Group("/message")
ms.GET("/get", message.PostInstance.GetHandle)
ms.POST("/send", message.PostInstance.SendHandle)

// guest can
public := api.Group("/public")
public.GET("/settings", controllers.PublicSettings)
Expand Down

0 comments on commit e389124

Please sign in to comment.