aboutsummaryrefslogtreecommitdiff
path: root/federationsender/internal/api.go
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2020-05-01 13:01:50 +0100
committerGitHub <noreply@github.com>2020-05-01 13:01:50 +0100
commit908108c23e47df5fbf0d6629b676e105abd2a564 (patch)
tree5fe328d0e339fb2149dd44ba9054878b5a86f075 /federationsender/internal/api.go
parent17e046f18fc182731c112e1dd653cc7021ebd422 (diff)
Rename FS queue package to internal (#997)
Diffstat (limited to 'federationsender/internal/api.go')
-rw-r--r--federationsender/internal/api.go97
1 files changed, 97 insertions, 0 deletions
diff --git a/federationsender/internal/api.go b/federationsender/internal/api.go
new file mode 100644
index 00000000..89a1fda4
--- /dev/null
+++ b/federationsender/internal/api.go
@@ -0,0 +1,97 @@
+package internal
+
+import (
+ "encoding/json"
+ "net/http"
+
+ "github.com/matrix-org/dendrite/common"
+ "github.com/matrix-org/dendrite/common/config"
+ "github.com/matrix-org/dendrite/federationsender/api"
+ "github.com/matrix-org/dendrite/federationsender/producers"
+ "github.com/matrix-org/dendrite/federationsender/storage"
+ "github.com/matrix-org/gomatrixserverlib"
+ "github.com/matrix-org/util"
+)
+
+// FederationSenderInternalAPI is an implementation of api.FederationSenderInternalAPI
+type FederationSenderInternalAPI struct {
+ api.FederationSenderInternalAPI
+ db storage.Database
+ cfg *config.Dendrite
+ producer *producers.RoomserverProducer
+ federation *gomatrixserverlib.FederationClient
+ keyRing *gomatrixserverlib.KeyRing
+}
+
+func NewFederationSenderInternalAPI(
+ db storage.Database, cfg *config.Dendrite,
+ producer *producers.RoomserverProducer,
+ federation *gomatrixserverlib.FederationClient,
+ keyRing *gomatrixserverlib.KeyRing,
+) *FederationSenderInternalAPI {
+ return &FederationSenderInternalAPI{
+ db: db,
+ cfg: cfg,
+ producer: producer,
+ federation: federation,
+ keyRing: keyRing,
+ }
+}
+
+// SetupHTTP adds the FederationSenderInternalAPI handlers to the http.ServeMux.
+func (f *FederationSenderInternalAPI) SetupHTTP(servMux *http.ServeMux) {
+ servMux.Handle(
+ api.FederationSenderQueryJoinedHostsInRoomPath,
+ common.MakeInternalAPI("QueryJoinedHostsInRoom", func(req *http.Request) util.JSONResponse {
+ var request api.QueryJoinedHostsInRoomRequest
+ var response api.QueryJoinedHostsInRoomResponse
+ if err := json.NewDecoder(req.Body).Decode(&request); err != nil {
+ return util.ErrorResponse(err)
+ }
+ if err := f.QueryJoinedHostsInRoom(req.Context(), &request, &response); err != nil {
+ return util.ErrorResponse(err)
+ }
+ return util.JSONResponse{Code: http.StatusOK, JSON: &response}
+ }),
+ )
+ servMux.Handle(
+ api.FederationSenderQueryJoinedHostServerNamesInRoomPath,
+ common.MakeInternalAPI("QueryJoinedHostServerNamesInRoom", func(req *http.Request) util.JSONResponse {
+ var request api.QueryJoinedHostServerNamesInRoomRequest
+ var response api.QueryJoinedHostServerNamesInRoomResponse
+ if err := json.NewDecoder(req.Body).Decode(&request); err != nil {
+ return util.ErrorResponse(err)
+ }
+ if err := f.QueryJoinedHostServerNamesInRoom(req.Context(), &request, &response); err != nil {
+ return util.ErrorResponse(err)
+ }
+ return util.JSONResponse{Code: http.StatusOK, JSON: &response}
+ }),
+ )
+ servMux.Handle(api.FederationSenderPerformJoinRequestPath,
+ common.MakeInternalAPI("PerformJoinRequest", func(req *http.Request) util.JSONResponse {
+ var request api.PerformJoinRequest
+ var response api.PerformJoinResponse
+ if err := json.NewDecoder(req.Body).Decode(&request); err != nil {
+ return util.MessageResponse(http.StatusBadRequest, err.Error())
+ }
+ if err := f.PerformJoin(req.Context(), &request, &response); err != nil {
+ return util.ErrorResponse(err)
+ }
+ return util.JSONResponse{Code: http.StatusOK, JSON: &response}
+ }),
+ )
+ servMux.Handle(api.FederationSenderPerformLeaveRequestPath,
+ common.MakeInternalAPI("PerformLeaveRequest", func(req *http.Request) util.JSONResponse {
+ var request api.PerformLeaveRequest
+ var response api.PerformLeaveResponse
+ if err := json.NewDecoder(req.Body).Decode(&request); err != nil {
+ return util.MessageResponse(http.StatusBadRequest, err.Error())
+ }
+ if err := f.PerformLeave(req.Context(), &request, &response); err != nil {
+ return util.ErrorResponse(err)
+ }
+ return util.JSONResponse{Code: http.StatusOK, JSON: &response}
+ }),
+ )
+}