/* * Copyright (c) [2016] [ <ether.camp> ] * This file is part of the ethereumJ library. * * The ethereumJ library is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * The ethereumJ library 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with the ethereumJ library. If not, see <http://www.gnu.org/licenses/>. */ package org.ethereum.net.shh; import org.ethereum.crypto.ECIESCoder; import org.ethereum.crypto.ECKey; import org.ethereum.util.RLP; import org.ethereum.util.RLPDump; import org.ethereum.util.RLPTest; import org.junit.Assert; import org.junit.Test; import org.spongycastle.crypto.InvalidCipherTextException; import org.spongycastle.util.encoders.Hex; import java.io.IOException; import java.util.Arrays; import java.util.Collections; /** * Created by Anton Nashatyrev on 25.09.2015. */ public class EnvelopeTest { @Test public void testBroadcast1() { WhisperMessage msg1 = new WhisperMessage() .setTopics(Topic.createTopics("Topic1", "Topic2")) .setPayload("Hello"); WhisperMessage msg2 = new WhisperMessage() .setTopics(Topic.createTopics("Topic1", "Topic3")) .setPayload("Hello again"); ShhEnvelopeMessage envelope = new ShhEnvelopeMessage(msg1, msg2); byte[] bytes = envelope.getEncoded(); ShhEnvelopeMessage inbound = new ShhEnvelopeMessage(bytes); Assert.assertEquals(2, inbound.getMessages().size()); WhisperMessage inMsg1 = inbound.getMessages().get(0); boolean b = inMsg1.decrypt(Collections.EMPTY_LIST, Arrays.asList(Topic.createTopics("Topic2", "Topic3"))); Assert.assertTrue(b); Assert.assertEquals("Hello", new String(inMsg1.getPayload())); WhisperMessage inMsg2 = inbound.getMessages().get(1); b = inMsg2.decrypt(Collections.EMPTY_LIST, Arrays.asList(Topic.createTopics("Topic1", "Topic3"))); Assert.assertTrue(b); Assert.assertEquals("Hello again", new String(inMsg2.getPayload())); } @Test public void testPow1() { ECKey from = new ECKey(); ECKey to = new ECKey(); System.out.println("From: " + Hex.toHexString(from.getPrivKeyBytes())); System.out.println("To: " + Hex.toHexString(to.getPrivKeyBytes())); WhisperMessage msg1 = new WhisperMessage() .setTopics(Topic.createTopics("Topic1", "Topic2")) .setPayload("Hello") .setFrom(from) .setTo(WhisperImpl.toIdentity(to)) .setWorkToProve(1000); WhisperMessage msg2 = new WhisperMessage() .setTopics(Topic.createTopics("Topic1", "Topic3")) .setPayload("Hello again") .setWorkToProve(500); ShhEnvelopeMessage envelope = new ShhEnvelopeMessage(msg1, msg2); byte[] bytes = envelope.getEncoded(); // System.out.println(RLPTest.dump(RLP.decode2(bytes), 0)); ShhEnvelopeMessage inbound = new ShhEnvelopeMessage(bytes); Assert.assertEquals(2, inbound.getMessages().size()); WhisperMessage inMsg1 = inbound.getMessages().get(0); boolean b = inMsg1.decrypt(Collections.singleton(to), Arrays.asList(Topic.createTopics("Topic2", "Topic3"))); Assert.assertTrue(b); Assert.assertEquals("Hello", new String(inMsg1.getPayload())); Assert.assertEquals(msg1.getTo(), inMsg1.getTo()); Assert.assertEquals(msg1.getFrom(), inMsg1.getFrom()); // System.out.println(msg1.nonce + ": " + inMsg1.nonce + ", " + inMsg1.getPow()); Assert.assertTrue(inMsg1.getPow() > 10); WhisperMessage inMsg2 = inbound.getMessages().get(1); b = inMsg2.decrypt(Collections.EMPTY_LIST, Arrays.asList(Topic.createTopics("Topic2", "Topic3"))); Assert.assertTrue(b); Assert.assertEquals("Hello again", new String(inMsg2.getPayload())); // System.out.println(msg2.nonce + ": " + inMsg2.getPow()); Assert.assertTrue(inMsg2.getPow() > 8); } @Test public void testCpp1() throws Exception { byte[] cipherText1 = Hex.decode("0469e324b8ab4a8e2bf0440548498226c9864d1210248ebf76c3396dd1748f0b04d347728b683993e4061998390c2cc8d6d09611da6df9769ebec888295f9be99e86ddad866f994a494361a5658d2b48d1140d73f71a382a4dc7ee2b0b5487091b0c25a3f0e6"); ECKey priv = ECKey.fromPrivate(Hex.decode("d0b043b4c5d657670778242d82d68a29d25d7d711127d17b8e299f156dad361a")); ECKey pub = ECKey.fromPublicOnly(Hex.decode("04bd27a63c91fe3233c5777e6d3d7b39204d398c8f92655947eb5a373d46e1688f022a1632d264725cbc7dc43ee1cfebde42fa0a86d08b55d2acfbb5e9b3b48dc5")); byte[] plain1 = ECIESCoder.decryptSimple(priv.getPrivKey(), cipherText1); byte[] cipherText2 = ECIESCoder.encryptSimple(pub.getPubKeyPoint(), plain1); // System.out.println("Cipher1: " + Hex.toHexString(cipherText1)); // System.out.println("Cipher2: " + Hex.toHexString(cipherText2)); byte[] plain2 = ECIESCoder.decryptSimple(priv.getPrivKey(), cipherText2); Assert.assertArrayEquals(plain1, plain2); } }