Compare commits

...

7 Commits

Author SHA1 Message Date
RoyceDa
aa17dd8d9d Тест 1
All checks were successful
Build rosetta-wss / build (push) Successful in 1m43s
2026-03-31 19:51:43 +02:00
RoyceDa
a76496204c Фикс сравнения
All checks were successful
Build rosetta-wss / build (push) Successful in 1m47s
2026-03-31 19:46:32 +02:00
RoyceDa
475f3230f3 Фикс device_id
All checks were successful
Build rosetta-wss / build (push) Successful in 1m30s
2026-03-31 19:42:35 +02:00
RoyceDa
7f09b7764b Фикс LIE
All checks were successful
Build rosetta-wss / build (push) Successful in 1m32s
2026-03-31 19:38:16 +02:00
RoyceDa
8bba69ddb6 Debug
All checks were successful
Build rosetta-wss / build (push) Successful in 1m45s
2026-03-31 18:46:40 +02:00
RoyceDa
02a8a1024b Фикс LazyInitializationException
All checks were successful
Build rosetta-wss / build (push) Successful in 2m11s
2026-03-31 18:39:31 +02:00
RoyceDa
16093fd693 Фикс LazyInitializationException
All checks were successful
Build rosetta-wss / build (push) Successful in 1m45s
2026-03-31 18:16:18 +02:00
4 changed files with 73 additions and 36 deletions

View File

@@ -0,0 +1,59 @@
package im.rosetta.database.repository;
import java.util.List;
import org.hibernate.Session;
import im.rosetta.database.HibernateUtil;
import im.rosetta.database.Repository;
import im.rosetta.database.entity.Device;
import im.rosetta.database.entity.PushToken;
public class PushTokenRepository extends Repository<PushToken> {
public PushTokenRepository() {
super(PushToken.class);
}
/**
* Найти все токены для заданного публичного ключа
* @param publicKey публичный ключ пользователя
* @return список токенов для заданного публичного ключа
*/
public List<PushToken> findTokens(String publicKey) {
try (Session session = HibernateUtil.getSessionFactory().openSession()) {
return session.createQuery("SELECT pt FROM PushToken pt JOIN pt.device d WHERE d.publicKey = :publicKey", PushToken.class)
.setParameter("publicKey", publicKey)
.getResultList();
}
}
/**
* Найти все токены для заданного списка публичных ключей
* @param publicKeys список публичных ключей пользователей
* @return список токенов для заданного списка публичных ключей
*/
public List<PushToken> findTokens(List<String> publicKeys) {
try (Session session = HibernateUtil.getSessionFactory().openSession()) {
return session.createQuery("SELECT pt FROM PushToken pt JOIN pt.device d WHERE d.publicKey IN :publicKeys", PushToken.class)
.setParameter("publicKeys", publicKeys)
.getResultList();
}
}
/**
* Найти токен для заданного устройства и токена
* @param device устройство, которому принадлежит токен
* @param token токен, который нужно найти
* @return токен для заданного устройства и токена, или null, если такой токен не найден
*/
public PushToken findToken(Device device, String token){
try (Session session = HibernateUtil.getSessionFactory().openSession()) {
return session.createQuery("SELECT pt FROM PushToken pt WHERE pt.device = :device AND pt.token = :token", PushToken.class)
.setParameter("device", device)
.setParameter("token", token)
.uniqueResult();
}
}
}

View File

@@ -7,6 +7,7 @@ import im.rosetta.client.tags.ECIAuthentificate;
import im.rosetta.database.entity.Device;
import im.rosetta.database.entity.PushToken;
import im.rosetta.database.repository.DeviceRepository;
import im.rosetta.database.repository.PushTokenRepository;
import im.rosetta.packet.Packet16PushNotification;
import im.rosetta.packet.runtime.NetworkNotificationAction;
import im.rosetta.service.services.DeviceService;
@@ -19,6 +20,7 @@ public class Executor16PushNotification extends PacketExecutor<Packet16PushNotif
private final DeviceRepository deviceRepository = new DeviceRepository();
private final DeviceService deviceService = new DeviceService(deviceRepository);
private final PushTokenRepository pushTokenRepository = new PushTokenRepository();
@Override
public void onPacketReceived(Packet16PushNotification packet, Client client) throws Exception, ProtocolException {
@@ -46,7 +48,7 @@ public class Executor16PushNotification extends PacketExecutor<Packet16PushNotif
client.disconnect();
return;
}
PushToken pushToken = this.findToken(device, notificationToken);
PushToken pushToken = this.pushTokenRepository.findToken(device, notificationToken);
if(packet.getAction() == NetworkNotificationAction.SUBSCRIBE && pushToken == null){
/**
@@ -56,28 +58,16 @@ public class Executor16PushNotification extends PacketExecutor<Packet16PushNotif
token.setToken(notificationToken);
token.setDevice(device);
token.setType(packet.getTokenType());
device.addToken(token);
this.deviceRepository.save(device);
this.pushTokenRepository.save(token);
}
if(packet.getAction() == NetworkNotificationAction.UNSUBSCRIBE && pushToken != null){
/**
* Отписка от токена только если токен уже подписан
*/
device.removeToken(pushToken);
this.deviceRepository.save(device);
this.pushTokenRepository.delete(pushToken);
}
}
private PushToken findToken(Device device, String token) {
List<PushToken> tokens = device.getTokens();
for(PushToken pushToken : tokens){
if(pushToken.getToken().equals(token)){
return pushToken;
}
}
return null;
}
private Device findDevice(String publicKey, String deviceId) {
List<Device> devices = this.deviceService.getDevicesByPK(publicKey);
if(devices.size() == 0){

View File

@@ -5,19 +5,16 @@ import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import im.rosetta.database.entity.Device;
import im.rosetta.database.entity.PushToken;
import im.rosetta.database.repository.DeviceRepository;
import im.rosetta.database.repository.PushTokenRepository;
import im.rosetta.packet.runtime.TokenType;
import im.rosetta.service.dispatch.push.dispatchers.FCM;
import im.rosetta.service.dispatch.push.dispatchers.VoIPApns;
import im.rosetta.service.services.DeviceService;
public class PushNotifyDispatcher {
private DeviceRepository deviceRepository = new DeviceRepository();
private DeviceService deviceService = new DeviceService(deviceRepository);
private final ExecutorService executor = Executors.newFixedThreadPool(10);
private final PushTokenRepository pushTokenRepository = new PushTokenRepository();
private final HashMap<TokenType, Pusher> pushers = new HashMap<>() {{
put(TokenType.FCM, new FCM());
@@ -28,24 +25,15 @@ public class PushNotifyDispatcher {
private Pusher findPusher(TokenType tokenType){
return this.pushers.get(tokenType);
}
private List<PushToken> findPushTokens(String publicKey) {
List<Device> devices = this.deviceService.getDevicesByPK(publicKey);
List<PushToken> pushTokens = new java.util.ArrayList<>();
for(Device device : devices){
pushTokens.addAll(device.getTokens());
}
return pushTokens;
}
/**
* Отправить уведомление пользователю с publicKey, используя все его токены для отправки уведомления, если таковые имеются
* @param publicKey публичный ключ пользователя, которому нужно отправить уведомление
* @param data данные уведомления
*/
public void sendPush(String publicKey, HashMap<String, String> data) {
List<PushToken> pushTokens = this.pushTokenRepository.findTokens(publicKey);
executor.execute(() -> {
List<PushToken> pushTokens = this.findPushTokens(publicKey);
for(PushToken pushToken : pushTokens){
Pusher pusher = this.findPusher(pushToken.getType());
if(pusher != null){
@@ -61,17 +49,16 @@ public class PushNotifyDispatcher {
* @param data данные уведомления
*/
public void sendPush(List<String> publicKeys, HashMap<String, String> data) {
List<PushToken> pushTokens = this.pushTokenRepository.findTokens(publicKeys);
executor.execute(() -> {
for(String publicKey : publicKeys){
List<PushToken> pushTokens = this.findPushTokens(publicKey);
for(PushToken pushToken : pushTokens){
Pusher pusher = this.findPusher(pushToken.getType());
for(PushToken pushToken : pushTokens){
Pusher pusher = this.findPusher(pushToken.getType());
if(pusher != null){
pusher.sendPush(pushToken.getToken(), data);
}
}
}
});
);
}

View File

@@ -150,6 +150,7 @@ public class Server extends WebSocketServer {
}
} catch (Exception e) {
client.disconnect(ServerFailures.BAD_PACKET);
e.printStackTrace();
}
}