mirror of
https://github.com/ChronosX88/Influence-Bootstrap-Node.git
synced 2024-11-21 23:02:19 +00:00
Added creating FreePastry bootstrap node
This commit is contained in:
parent
6f0da1e336
commit
9d53bdd7e6
@ -24,6 +24,7 @@ repositories {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
|
implementation fileTree(include: ['*.jar'], dir: 'libs')
|
||||||
implementation 'net.tomp2p:tomp2p-all:5.0-Beta8'
|
implementation 'net.tomp2p:tomp2p-all:5.0-Beta8'
|
||||||
implementation 'org.slf4j:slf4j-log4j12:+'
|
implementation 'org.slf4j:slf4j-log4j12:+'
|
||||||
}
|
}
|
||||||
|
BIN
libs/FreePastry-2.1.jar
Normal file
BIN
libs/FreePastry-2.1.jar
Normal file
Binary file not shown.
BIN
libs/commons-jxpath-1.1.jar
Normal file
BIN
libs/commons-jxpath-1.1.jar
Normal file
Binary file not shown.
BIN
libs/commons-logging.jar
Normal file
BIN
libs/commons-logging.jar
Normal file
Binary file not shown.
@ -1,6 +1,8 @@
|
|||||||
package io.github.chronosx88.dhtBootstrap;
|
package io.github.chronosx88.dhtBootstrap;
|
||||||
|
|
||||||
import net.tomp2p.connection.*;
|
import net.tomp2p.connection.ChannelClientConfiguration;
|
||||||
|
import net.tomp2p.connection.ChannelServerConfiguration;
|
||||||
|
import net.tomp2p.connection.RSASignatureFactory;
|
||||||
import net.tomp2p.dht.PeerBuilderDHT;
|
import net.tomp2p.dht.PeerBuilderDHT;
|
||||||
import net.tomp2p.dht.PeerDHT;
|
import net.tomp2p.dht.PeerDHT;
|
||||||
import net.tomp2p.nat.PeerBuilderNAT;
|
import net.tomp2p.nat.PeerBuilderNAT;
|
||||||
@ -9,6 +11,12 @@ import net.tomp2p.peers.Number160;
|
|||||||
import net.tomp2p.relay.RelayType;
|
import net.tomp2p.relay.RelayType;
|
||||||
import net.tomp2p.relay.tcp.TCPRelayServerConfig;
|
import net.tomp2p.relay.tcp.TCPRelayServerConfig;
|
||||||
import net.tomp2p.replication.IndirectReplication;
|
import net.tomp2p.replication.IndirectReplication;
|
||||||
|
import rice.environment.Environment;
|
||||||
|
import rice.pastry.NodeIdFactory;
|
||||||
|
import rice.pastry.PastryNode;
|
||||||
|
import rice.pastry.PastryNodeFactory;
|
||||||
|
import rice.pastry.socket.internet.InternetPastryNodeFactory;
|
||||||
|
import rice.pastry.standard.RandomNodeIdFactory;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
import java.io.FileInputStream;
|
||||||
@ -20,6 +28,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
public class Main {
|
public class Main {
|
||||||
private static PeerDHT peerDHT;
|
private static PeerDHT peerDHT;
|
||||||
|
private static PastryNode pastryNode;
|
||||||
private static Number160 peerID;
|
private static Number160 peerID;
|
||||||
private static Properties props;
|
private static Properties props;
|
||||||
private static final String DATA_DIR_PATH = System.getProperty("user.home") + "/.local/share/Influence-Bootstrap/";
|
private static final String DATA_DIR_PATH = System.getProperty("user.home") + "/.local/share/Influence-Bootstrap/";
|
||||||
@ -68,6 +77,7 @@ public class Main {
|
|||||||
.addRelayServerConfiguration(RelayType.OPENTCP, new TCPRelayServerConfig())
|
.addRelayServerConfiguration(RelayType.OPENTCP, new TCPRelayServerConfig())
|
||||||
.start();
|
.start();
|
||||||
new IndirectReplication(peerDHT).start();
|
new IndirectReplication(peerDHT).start();
|
||||||
|
createNewPastryBootstrapNode();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@ -84,4 +94,51 @@ public class Main {
|
|||||||
channelServerConfiguration.signatureFactory(new RSASignatureFactory());
|
channelServerConfiguration.signatureFactory(new RSASignatureFactory());
|
||||||
return channelServerConfiguration;
|
return channelServerConfiguration;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void createNewPastryBootstrapNode() {
|
||||||
|
Environment env = new Environment();
|
||||||
|
env.getParameters().setString("probe_for_external_address","true");
|
||||||
|
env.getParameters().setString("nat_search_policy","never");
|
||||||
|
// Generate the NodeIds Randomly
|
||||||
|
NodeIdFactory nidFactory = new RandomNodeIdFactory(env);
|
||||||
|
|
||||||
|
// construct the PastryNodeFactory, this is how we use rice.pastry.socket
|
||||||
|
PastryNodeFactory factory = null;
|
||||||
|
try {
|
||||||
|
factory = new InternetPastryNodeFactory(nidFactory, 7244, env);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// construct a node, but this does not cause it to boot
|
||||||
|
PastryNode node = null;
|
||||||
|
try {
|
||||||
|
node = factory.newNode();
|
||||||
|
pastryNode = node;
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// in later tutorials, we will register applications before calling boot
|
||||||
|
node.boot(new InetSocketAddress(7244));
|
||||||
|
|
||||||
|
// the node may require sending several messages to fully boot into the ring
|
||||||
|
synchronized(node) {
|
||||||
|
while(!node.isReady() && !node.joinFailed()) {
|
||||||
|
// delay so we don't busy-wait
|
||||||
|
try {
|
||||||
|
node.wait(500);
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// abort if can't join
|
||||||
|
if (node.joinFailed()) {
|
||||||
|
System.out.println("[Pastry] Could not join the FreePastry ring. Reason:"+node.joinFailedReason());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("[Pastry] Finished creating new bootstrap node "+node);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user