2017-04-20 23:40:52 +01:00
|
|
|
// Copyright 2017 Vector Creations Ltd
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2017-03-15 13:36:26 +00:00
|
|
|
package producers
|
|
|
|
|
|
|
|
import (
|
2017-09-13 13:37:50 +01:00
|
|
|
"context"
|
|
|
|
|
2017-03-15 13:36:26 +00:00
|
|
|
"github.com/matrix-org/dendrite/roomserver/api"
|
|
|
|
"github.com/matrix-org/gomatrixserverlib"
|
|
|
|
)
|
|
|
|
|
|
|
|
// RoomserverProducer produces events for the roomserver to consume.
|
|
|
|
type RoomserverProducer struct {
|
2020-05-01 10:48:17 +01:00
|
|
|
RsAPI api.RoomserverInternalAPI
|
2017-03-15 13:36:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewRoomserverProducer creates a new RoomserverProducer
|
2020-05-01 10:48:17 +01:00
|
|
|
func NewRoomserverProducer(rsAPI api.RoomserverInternalAPI) *RoomserverProducer {
|
2017-03-15 13:36:26 +00:00
|
|
|
return &RoomserverProducer{
|
2020-05-01 10:48:17 +01:00
|
|
|
RsAPI: rsAPI,
|
2017-07-18 13:40:03 +01:00
|
|
|
}
|
2017-03-15 13:36:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// SendEvents writes the given events to the roomserver input log. The events are written with KindNew.
|
2017-09-13 13:37:50 +01:00
|
|
|
func (c *RoomserverProducer) SendEvents(
|
2020-03-27 16:28:22 +00:00
|
|
|
ctx context.Context, events []gomatrixserverlib.HeaderedEvent, sendAsServer gomatrixserverlib.ServerName,
|
2017-12-04 18:07:52 +00:00
|
|
|
txnID *api.TransactionID,
|
2018-05-26 12:03:35 +01:00
|
|
|
) (string, error) {
|
2017-03-15 13:36:26 +00:00
|
|
|
ires := make([]api.InputRoomEvent, len(events))
|
2017-05-25 16:08:28 +01:00
|
|
|
for i, event := range events {
|
|
|
|
ires[i] = api.InputRoomEvent{
|
2017-12-04 18:07:52 +00:00
|
|
|
Kind: api.KindNew,
|
2020-03-27 16:28:22 +00:00
|
|
|
Event: event,
|
2017-12-04 18:07:52 +00:00
|
|
|
AuthEventIDs: event.AuthEventIDs(),
|
|
|
|
SendAsServer: string(sendAsServer),
|
|
|
|
TransactionID: txnID,
|
2017-03-15 13:36:26 +00:00
|
|
|
}
|
|
|
|
}
|
2017-09-13 13:37:50 +01:00
|
|
|
return c.SendInputRoomEvents(ctx, ires)
|
2017-03-15 13:36:26 +00:00
|
|
|
}
|
|
|
|
|
2017-05-25 16:08:28 +01:00
|
|
|
// SendEventWithState writes an event with KindNew to the roomserver input log
|
2020-05-06 18:03:25 +01:00
|
|
|
// with the state at the event as KindOutlier before it. Will not send any event that is
|
|
|
|
// marked as `true` in haveEventIDs
|
2017-09-13 13:37:50 +01:00
|
|
|
func (c *RoomserverProducer) SendEventWithState(
|
2020-05-06 18:03:25 +01:00
|
|
|
ctx context.Context, state *gomatrixserverlib.RespState, event gomatrixserverlib.HeaderedEvent, haveEventIDs map[string]bool,
|
2017-09-13 13:37:50 +01:00
|
|
|
) error {
|
2017-05-25 16:08:28 +01:00
|
|
|
outliers, err := state.Events()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-03-27 16:28:22 +00:00
|
|
|
var ires []api.InputRoomEvent
|
|
|
|
for _, outlier := range outliers {
|
2020-05-06 18:03:25 +01:00
|
|
|
if haveEventIDs[outlier.EventID()] {
|
|
|
|
continue
|
|
|
|
}
|
2020-03-27 16:28:22 +00:00
|
|
|
ires = append(ires, api.InputRoomEvent{
|
2017-05-25 16:08:28 +01:00
|
|
|
Kind: api.KindOutlier,
|
2020-03-27 16:28:22 +00:00
|
|
|
Event: outlier.Headered(event.RoomVersion),
|
2017-07-07 14:11:32 +01:00
|
|
|
AuthEventIDs: outlier.AuthEventIDs(),
|
2020-03-27 16:28:22 +00:00
|
|
|
})
|
2017-05-25 16:08:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
stateEventIDs := make([]string, len(state.StateEvents))
|
|
|
|
for i := range state.StateEvents {
|
|
|
|
stateEventIDs[i] = state.StateEvents[i].EventID()
|
|
|
|
}
|
|
|
|
|
2020-03-27 16:28:22 +00:00
|
|
|
ires = append(ires, api.InputRoomEvent{
|
2017-05-25 16:08:28 +01:00
|
|
|
Kind: api.KindNew,
|
2020-03-27 16:28:22 +00:00
|
|
|
Event: event,
|
2017-07-07 14:11:32 +01:00
|
|
|
AuthEventIDs: event.AuthEventIDs(),
|
2017-05-25 16:08:28 +01:00
|
|
|
HasState: true,
|
|
|
|
StateEventIDs: stateEventIDs,
|
2020-03-27 16:28:22 +00:00
|
|
|
})
|
2017-05-25 16:08:28 +01:00
|
|
|
|
2018-05-26 12:03:35 +01:00
|
|
|
_, err = c.SendInputRoomEvents(ctx, ires)
|
|
|
|
return err
|
2017-05-25 16:08:28 +01:00
|
|
|
}
|
|
|
|
|
2017-08-23 15:13:47 +01:00
|
|
|
// SendInputRoomEvents writes the given input room events to the roomserver input API.
|
2018-05-26 12:03:35 +01:00
|
|
|
func (c *RoomserverProducer) SendInputRoomEvents(
|
|
|
|
ctx context.Context, ires []api.InputRoomEvent,
|
|
|
|
) (eventID string, err error) {
|
2017-07-18 13:40:03 +01:00
|
|
|
request := api.InputRoomEventsRequest{InputRoomEvents: ires}
|
|
|
|
var response api.InputRoomEventsResponse
|
2020-05-01 10:48:17 +01:00
|
|
|
err = c.RsAPI.InputRoomEvents(ctx, &request, &response)
|
2018-05-26 12:03:35 +01:00
|
|
|
eventID = response.EventID
|
|
|
|
return
|
2017-03-15 13:36:26 +00:00
|
|
|
}
|
2017-08-23 15:13:47 +01:00
|
|
|
|
|
|
|
// SendInvite writes the invite event to the roomserver input API.
|
2017-09-12 16:54:37 +01:00
|
|
|
// This should only be needed for invite events that occur outside of a known room.
|
|
|
|
// If we are in the room then the event should be sent using the SendEvents method.
|
2018-05-26 12:03:35 +01:00
|
|
|
func (c *RoomserverProducer) SendInvite(
|
2020-04-03 14:29:06 +01:00
|
|
|
ctx context.Context, inviteEvent gomatrixserverlib.HeaderedEvent,
|
|
|
|
inviteRoomState []gomatrixserverlib.InviteV2StrippedState,
|
2020-04-24 16:30:25 +01:00
|
|
|
sendAsServer gomatrixserverlib.ServerName, txnID *api.TransactionID,
|
2018-05-26 12:03:35 +01:00
|
|
|
) error {
|
2017-08-23 15:13:47 +01:00
|
|
|
request := api.InputRoomEventsRequest{
|
2020-03-17 11:01:25 +00:00
|
|
|
InputInviteEvents: []api.InputInviteEvent{{
|
2020-04-03 14:29:06 +01:00
|
|
|
Event: inviteEvent,
|
|
|
|
InviteRoomState: inviteRoomState,
|
|
|
|
RoomVersion: inviteEvent.RoomVersion,
|
2020-04-24 16:30:25 +01:00
|
|
|
SendAsServer: string(sendAsServer),
|
|
|
|
TransactionID: txnID,
|
2020-03-17 11:01:25 +00:00
|
|
|
}},
|
2017-08-23 15:13:47 +01:00
|
|
|
}
|
|
|
|
var response api.InputRoomEventsResponse
|
2020-05-01 10:48:17 +01:00
|
|
|
return c.RsAPI.InputRoomEvents(ctx, &request, &response)
|
2017-08-23 15:13:47 +01:00
|
|
|
}
|