split into app svc processor
This commit is contained in:
@@ -22,9 +22,7 @@ package io.kamax.mxisd.as;
|
|||||||
|
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import io.kamax.matrix.MatrixID;
|
import io.kamax.matrix.MatrixID;
|
||||||
import io.kamax.matrix.ThreePidMedium;
|
|
||||||
import io.kamax.matrix._MatrixID;
|
import io.kamax.matrix._MatrixID;
|
||||||
import io.kamax.matrix._ThreePid;
|
|
||||||
import io.kamax.matrix.event.EventKey;
|
import io.kamax.matrix.event.EventKey;
|
||||||
import io.kamax.matrix.json.GsonUtil;
|
import io.kamax.matrix.json.GsonUtil;
|
||||||
import io.kamax.mxisd.backend.sql.synapse.Synapse;
|
import io.kamax.mxisd.backend.sql.synapse.Synapse;
|
||||||
@@ -37,7 +35,7 @@ import io.kamax.mxisd.profile.ProfileManager;
|
|||||||
import io.kamax.mxisd.storage.IStorage;
|
import io.kamax.mxisd.storage.IStorage;
|
||||||
import io.kamax.mxisd.storage.ormlite.dao.ASTransactionDao;
|
import io.kamax.mxisd.storage.ormlite.dao.ASTransactionDao;
|
||||||
import io.kamax.mxisd.util.GsonParser;
|
import io.kamax.mxisd.util.GsonParser;
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
@@ -46,7 +44,6 @@ import java.time.Instant;
|
|||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.stream.Collectors;
|
|
||||||
|
|
||||||
public class AppSvcManager {
|
public class AppSvcManager {
|
||||||
|
|
||||||
@@ -56,21 +53,18 @@ public class AppSvcManager {
|
|||||||
|
|
||||||
private MatrixConfig cfg;
|
private MatrixConfig cfg;
|
||||||
private IStorage store;
|
private IStorage store;
|
||||||
private ProfileManager profiler;
|
private Map<String, EventTypeProcessor> processors = new HashMap<>();
|
||||||
private NotificationManager notif;
|
|
||||||
private Synapse synapse;
|
|
||||||
|
|
||||||
private Map<String, CompletableFuture<String>> transactionsInProgress;
|
private Map<String, CompletableFuture<String>> transactionsInProgress;
|
||||||
|
|
||||||
public AppSvcManager(MxisdConfig cfg, IStorage store, ProfileManager profiler, NotificationManager notif, Synapse synapse) {
|
public AppSvcManager(MxisdConfig cfg, IStorage store, ProfileManager profiler, NotificationManager notif, Synapse synapse) {
|
||||||
this.cfg = cfg.getMatrix();
|
this.cfg = cfg.getMatrix();
|
||||||
this.store = store;
|
this.store = store;
|
||||||
this.profiler = profiler;
|
|
||||||
this.notif = notif;
|
|
||||||
this.synapse = synapse;
|
|
||||||
|
|
||||||
parser = new GsonParser();
|
parser = new GsonParser();
|
||||||
transactionsInProgress = new ConcurrentHashMap<>();
|
transactionsInProgress = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
|
processors.put("m.room.member", new MembershipProcessor(cfg.getMatrix(), profiler, notif, synapse));
|
||||||
}
|
}
|
||||||
|
|
||||||
public AppSvcManager withToken(String token) {
|
public AppSvcManager withToken(String token) {
|
||||||
@@ -139,7 +133,7 @@ public class AppSvcManager {
|
|||||||
return future;
|
return future;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void processTransaction(List<JsonObject> eventsJson) {
|
private void processTransaction(List<JsonObject> eventsJson) {
|
||||||
log.info("Processing transaction events: start");
|
log.info("Processing transaction events: start");
|
||||||
|
|
||||||
eventsJson.forEach(ev -> {
|
eventsJson.forEach(ev -> {
|
||||||
@@ -165,54 +159,14 @@ public class AppSvcManager {
|
|||||||
_MatrixID sender = MatrixID.asAcceptable(senderId);
|
_MatrixID sender = MatrixID.asAcceptable(senderId);
|
||||||
log.debug("Sender: {}", senderId);
|
log.debug("Sender: {}", senderId);
|
||||||
|
|
||||||
if (!StringUtils.equals("m.room.member", GsonUtil.getStringOrNull(ev, "type"))) {
|
String evType = StringUtils.defaultIfBlank(EventKey.Type.getStringOrNull(ev), "<EMPTY/MISSING>");
|
||||||
log.debug("This is not a room membership event, skipping");
|
EventTypeProcessor p = processors.get(evType);
|
||||||
|
if (Objects.isNull(p)) {
|
||||||
|
log.debug("No event processor for type {}, skipping", evType);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!StringUtils.equals("invite", GsonUtil.getStringOrNull(ev, "membership"))) {
|
p.process(ev, sender, roomId);
|
||||||
log.debug("This is not an invite event, skipping");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
String inviteeId = EventKey.StateKey.getStringOrNull(ev);
|
|
||||||
if (StringUtils.isBlank(inviteeId)) {
|
|
||||||
log.warn("Invalid event: No invitee ID, skipping");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_MatrixID invitee = MatrixID.asAcceptable(inviteeId);
|
|
||||||
if (!StringUtils.equals(invitee.getDomain(), cfg.getDomain())) {
|
|
||||||
log.debug("Ignoring invite for {}: not a local user");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
log.info("Got invite from {} to {}", senderId, inviteeId);
|
|
||||||
|
|
||||||
boolean wasSent = false;
|
|
||||||
List<_ThreePid> tpids = profiler.getThreepids(invitee).stream()
|
|
||||||
.filter(tpid -> ThreePidMedium.Email.is(tpid.getMedium()))
|
|
||||||
.collect(Collectors.toList());
|
|
||||||
log.info("Found {} email(s) in identity store for {}", tpids.size(), inviteeId);
|
|
||||||
|
|
||||||
for (_ThreePid tpid : tpids) {
|
|
||||||
log.info("Found Email to notify about room invitation: {}", tpid.getAddress());
|
|
||||||
Map<String, String> properties = new HashMap<>();
|
|
||||||
profiler.getDisplayName(sender).ifPresent(name -> properties.put("sender_display_name", name));
|
|
||||||
try {
|
|
||||||
synapse.getRoomName(roomId).ifPresent(name -> properties.put("room_name", name));
|
|
||||||
} catch (RuntimeException e) {
|
|
||||||
log.warn("Could not fetch room name", e);
|
|
||||||
log.info("Unable to fetch room name: Did you integrate your Homeserver as documented?");
|
|
||||||
}
|
|
||||||
|
|
||||||
IMatrixIdInvite inv = new MatrixIdInvite(roomId, sender, invitee, tpid.getMedium(), tpid.getAddress(), properties);
|
|
||||||
notif.sendForInvite(inv);
|
|
||||||
log.info("Notification for invite of {} sent to {}", inviteeId, tpid.getAddress());
|
|
||||||
wasSent = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
log.info("Was notification sent? {}", wasSent);
|
|
||||||
|
|
||||||
log.debug("Event {}: processing end", evId);
|
log.debug("Event {}: processing end", evId);
|
||||||
});
|
});
|
||||||
|
30
src/main/java/io/kamax/mxisd/as/EventTypeProcessor.java
Normal file
30
src/main/java/io/kamax/mxisd/as/EventTypeProcessor.java
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
/*
|
||||||
|
* mxisd - Matrix Identity Server Daemon
|
||||||
|
* Copyright (C) 2019 Kamax Sarl
|
||||||
|
*
|
||||||
|
* https://www.kamax.io/
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package io.kamax.mxisd.as;
|
||||||
|
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import io.kamax.matrix._MatrixID;
|
||||||
|
|
||||||
|
public interface EventTypeProcessor {
|
||||||
|
|
||||||
|
void process(JsonObject ev, _MatrixID sender, String roomId);
|
||||||
|
|
||||||
|
}
|
111
src/main/java/io/kamax/mxisd/as/MembershipProcessor.java
Normal file
111
src/main/java/io/kamax/mxisd/as/MembershipProcessor.java
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
/*
|
||||||
|
* mxisd - Matrix Identity Server Daemon
|
||||||
|
* Copyright (C) 2019 Kamax Sarl
|
||||||
|
*
|
||||||
|
* https://www.kamax.io/
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package io.kamax.mxisd.as;
|
||||||
|
|
||||||
|
import com.google.gson.JsonObject;
|
||||||
|
import io.kamax.matrix.MatrixID;
|
||||||
|
import io.kamax.matrix.ThreePidMedium;
|
||||||
|
import io.kamax.matrix._MatrixID;
|
||||||
|
import io.kamax.matrix._ThreePid;
|
||||||
|
import io.kamax.matrix.event.EventKey;
|
||||||
|
import io.kamax.matrix.json.GsonUtil;
|
||||||
|
import io.kamax.mxisd.backend.sql.synapse.Synapse;
|
||||||
|
import io.kamax.mxisd.config.MatrixConfig;
|
||||||
|
import io.kamax.mxisd.notification.NotificationManager;
|
||||||
|
import io.kamax.mxisd.profile.ProfileManager;
|
||||||
|
import org.apache.commons.lang.StringUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class MembershipProcessor implements EventTypeProcessor {
|
||||||
|
|
||||||
|
private final static Logger log = LoggerFactory.getLogger(MembershipProcessor.class);
|
||||||
|
|
||||||
|
private final MatrixConfig cfg;
|
||||||
|
private ProfileManager profiler;
|
||||||
|
private NotificationManager notif;
|
||||||
|
private Synapse synapse;
|
||||||
|
|
||||||
|
public MembershipProcessor(MatrixConfig cfg, ProfileManager profiler, NotificationManager notif, Synapse synapse) {
|
||||||
|
this.cfg = cfg;
|
||||||
|
this.profiler = profiler;
|
||||||
|
this.notif = notif;
|
||||||
|
this.synapse = synapse;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void process(JsonObject ev, _MatrixID sender, String roomId) {
|
||||||
|
JsonObject content = EventKey.Content.findObj(ev).orElseGet(() -> {
|
||||||
|
log.debug("No content found, falling back to full object");
|
||||||
|
return ev;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!StringUtils.equals("invite", GsonUtil.getStringOrNull(content, "membership"))) {
|
||||||
|
log.debug("This is not an invite event, skipping");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
String inviteeId = EventKey.StateKey.getStringOrNull(ev);
|
||||||
|
if (StringUtils.isBlank(inviteeId)) {
|
||||||
|
log.warn("Invalid event: No invitee ID, skipping");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_MatrixID invitee = MatrixID.asAcceptable(inviteeId);
|
||||||
|
if (!StringUtils.equals(invitee.getDomain(), cfg.getDomain())) {
|
||||||
|
log.debug("Ignoring invite for {}: not a local user");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
log.info("Got invite from {} to {}", sender.getId(), inviteeId);
|
||||||
|
|
||||||
|
boolean wasSent = false;
|
||||||
|
List<_ThreePid> tpids = profiler.getThreepids(invitee).stream()
|
||||||
|
.filter(tpid -> ThreePidMedium.Email.is(tpid.getMedium()))
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
log.info("Found {} email(s) in identity store for {}", tpids.size(), inviteeId);
|
||||||
|
|
||||||
|
for (_ThreePid tpid : tpids) {
|
||||||
|
log.info("Found Email to notify about room invitation: {}", tpid.getAddress());
|
||||||
|
Map<String, String> properties = new HashMap<>();
|
||||||
|
profiler.getDisplayName(sender).ifPresent(name -> properties.put("sender_display_name", name));
|
||||||
|
try {
|
||||||
|
synapse.getRoomName(roomId).ifPresent(name -> properties.put("room_name", name));
|
||||||
|
} catch (RuntimeException e) {
|
||||||
|
log.warn("Could not fetch room name", e);
|
||||||
|
log.info("Unable to fetch room name: Did you integrate your Homeserver as documented?");
|
||||||
|
}
|
||||||
|
|
||||||
|
IMatrixIdInvite inv = new MatrixIdInvite(roomId, sender, invitee, tpid.getMedium(), tpid.getAddress(), properties);
|
||||||
|
notif.sendForInvite(inv);
|
||||||
|
log.info("Notification for invite of {} sent to {}", inviteeId, tpid.getAddress());
|
||||||
|
wasSent = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
log.info("Was notification sent? {}", wasSent);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Reference in New Issue
Block a user