From a9164c708767256727461655e9daefb6c4f1d999 Mon Sep 17 00:00:00 2001 From: RoyceDa Date: Sat, 4 Apr 2026 18:01:52 +0200 Subject: [PATCH] =?UTF-8?q?=D0=A4=D0=B8=D0=BA=D1=81=20=D0=BE=D0=B1=D0=BC?= =?UTF-8?q?=D0=B5=D0=BD=D0=B0=20=D0=BA=D0=BB=D1=8E=D1=87=D0=B0=D0=BC=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/providers/CallProvider/CallProvider.tsx | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/app/providers/CallProvider/CallProvider.tsx b/app/providers/CallProvider/CallProvider.tsx index e998021..860a343 100644 --- a/app/providers/CallProvider/CallProvider.tsx +++ b/app/providers/CallProvider/CallProvider.tsx @@ -292,9 +292,7 @@ export function CallProvider(props : CallProviderProps) { if(signalType == SignalType.KEY_EXCHANGE){ console.info("EXCHANGE SIGNAL RECEIVED, CALLEE ROLE"); /** - * Мы отправили свою публичную часть ключа другой стороне, - * теперь мы получили ее публичную часть и можем создать общую - * секретную сессию для шифрования звонка + * Другая сторона отправила нам ключи, теперь отправляем ей свои для генерации общего секрета */ const keys = generateSessionKeys(); const sharedPublic = packet.getSharedPublic(); @@ -302,12 +300,14 @@ export function CallProvider(props : CallProviderProps) { info("Received key exchange signal without shared public key"); return; } + const signalPacket = new PacketSignalPeer(); signalPacket.setSrc(publicKey); signalPacket.setDst(activeCall); signalPacket.setSignalType(SignalType.KEY_EXCHANGE); signalPacket.setSharedPublic(Buffer.from(keys.publicKey).toString('hex')); - send(signalPacket); + send(signalPacket); + const computedSharedSecret = nacl.box.before(Buffer.from(sharedPublic, 'hex'), keys.secretKey); sharedSecretRef.current = Buffer.from(computedSharedSecret).toString('hex'); info("Generated shared secret for call session: " + sharedSecretRef.current);