2023-10-24 06:23:33 +07:00
|
|
|
package rest
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/go-chi/chi/v5"
|
|
|
|
"github.com/waku-org/go-waku/waku/v2/node"
|
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/lightpush"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
|
|
|
const routeLightPushV1Messages = "/lightpush/v1/message"
|
|
|
|
|
|
|
|
type LightpushService struct {
|
|
|
|
node *node.WakuNode
|
|
|
|
log *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewLightpushService(node *node.WakuNode, m *chi.Mux, log *zap.Logger) *LightpushService {
|
|
|
|
serv := &LightpushService{
|
|
|
|
node: node,
|
|
|
|
log: log.Named("lightpush"),
|
|
|
|
}
|
|
|
|
|
|
|
|
m.Post(routeLightPushV1Messages, serv.postMessagev1)
|
|
|
|
|
|
|
|
return serv
|
|
|
|
}
|
|
|
|
|
|
|
|
func (msg lightpushRequest) Check() error {
|
|
|
|
if msg.Message == nil {
|
|
|
|
return errors.New("waku message is required")
|
|
|
|
}
|
2024-04-15 09:36:18 -04:00
|
|
|
|
2023-10-24 06:23:33 +07:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type lightpushRequest struct {
|
2023-11-10 14:31:36 -04:00
|
|
|
PubSubTopic string `json:"pubsubTopic"`
|
|
|
|
Message *RestWakuMessage `json:"message"`
|
2023-10-24 06:23:33 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
// handled error codes are 200, 400, 500, 503
|
|
|
|
func (serv *LightpushService) postMessagev1(w http.ResponseWriter, req *http.Request) {
|
2023-11-10 14:31:36 -04:00
|
|
|
request := &lightpushRequest{}
|
2023-10-24 06:23:33 +07:00
|
|
|
decoder := json.NewDecoder(req.Body)
|
2023-11-10 14:31:36 -04:00
|
|
|
if err := decoder.Decode(request); err != nil {
|
2023-10-24 06:23:33 +07:00
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
defer req.Body.Close()
|
|
|
|
|
2023-11-10 14:31:36 -04:00
|
|
|
if err := request.Check(); err != nil {
|
2023-10-24 06:23:33 +07:00
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
|
|
|
_, err = w.Write([]byte(err.Error()))
|
|
|
|
serv.log.Error("writing response", zap.Error(err))
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if serv.node.Lightpush() == nil {
|
|
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-11-10 14:31:36 -04:00
|
|
|
message, err := request.Message.ToProto()
|
|
|
|
if err != nil {
|
|
|
|
w.WriteHeader(http.StatusBadRequest)
|
2024-04-15 09:36:18 -04:00
|
|
|
_, err = w.Write([]byte(err.Error()))
|
|
|
|
if err != nil {
|
|
|
|
serv.log.Error("writing response", zap.Error(err))
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = message.Validate(); err != nil {
|
|
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
|
|
_, err = w.Write([]byte(err.Error()))
|
|
|
|
if err != nil {
|
|
|
|
serv.log.Error("writing response", zap.Error(err))
|
|
|
|
}
|
2023-11-10 14:31:36 -04:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err = serv.node.Lightpush().Publish(req.Context(), message, lightpush.WithPubSubTopic(request.PubSubTopic))
|
2023-10-24 06:23:33 +07:00
|
|
|
if err != nil {
|
|
|
|
w.WriteHeader(http.StatusServiceUnavailable)
|
|
|
|
_, err = w.Write([]byte(err.Error()))
|
2024-04-15 08:56:03 -04:00
|
|
|
if err != nil {
|
|
|
|
serv.log.Error("writing response", zap.Error(err))
|
|
|
|
}
|
2023-10-24 06:23:33 +07:00
|
|
|
} else {
|
2023-11-07 20:26:48 +05:30
|
|
|
writeErrOrResponse(w, err, true)
|
2023-10-24 06:23:33 +07:00
|
|
|
}
|
|
|
|
}
|