|
|
|
@ -89,28 +89,28 @@ public class ClientP2P {
|
|
|
|
|
final ServerPortRange serverPortRange = new ServerPortRange();
|
|
|
|
|
final TrackerPortRange trackerPortRange = new TrackerPortRange();
|
|
|
|
|
|
|
|
|
|
if ((args.length != 6) && (args.length != 0)){
|
|
|
|
|
if ((args.length != 6) && (args.length != 0)) {
|
|
|
|
|
ClientP2P.printUsage(serverPortRange, trackerPortRange);
|
|
|
|
|
System.exit(1);
|
|
|
|
|
}
|
|
|
|
|
else if(args.length == 6){
|
|
|
|
|
else if (args.length == 6) {
|
|
|
|
|
protocolClient = args[1];
|
|
|
|
|
hostnameServer = args[2];
|
|
|
|
|
portServer = Integer.valueOf(Integer.parseInt(args[3]));
|
|
|
|
|
hostnameTracker = args[4];
|
|
|
|
|
portTracker = Integer.valueOf(Integer.parseInt(args[5]));
|
|
|
|
|
} else{
|
|
|
|
|
} else {
|
|
|
|
|
System.out.println("Client, wich transport protocol do you want to use (default = TCP): ");
|
|
|
|
|
protocolClient = scanner.nextLine();
|
|
|
|
|
System.out.println("server side, enter hostname to bind (default = localhost): ");
|
|
|
|
|
hostnameServer = scanner.nextLine();
|
|
|
|
|
if(hostnameServer.equals("")){
|
|
|
|
|
if (hostnameServer.equals("")) {
|
|
|
|
|
hostnameServer = defaultHostname;
|
|
|
|
|
System.out.println("using default hostname : " + hostnameServer);
|
|
|
|
|
}
|
|
|
|
|
System.out.println("enter port (default = " + serverPortRange.getDefaultPort() +"): ");
|
|
|
|
|
String portServerStr = scanner.nextLine();
|
|
|
|
|
if(portServerStr.equals("")){
|
|
|
|
|
if (portServerStr.equals("")) {
|
|
|
|
|
portServer = serverPortRange.getDefaultPort();
|
|
|
|
|
System.out.println("using default port : " + portServer);
|
|
|
|
|
} else {
|
|
|
|
@ -118,13 +118,13 @@ public class ClientP2P {
|
|
|
|
|
}
|
|
|
|
|
System.out.println("enter hostname of tracker (default = localhost): ");
|
|
|
|
|
hostnameTracker = scanner.nextLine();
|
|
|
|
|
if(hostnameTracker.equals("")){
|
|
|
|
|
if (hostnameTracker.equals("")) {
|
|
|
|
|
hostnameTracker = defaultHostname;
|
|
|
|
|
System.out.println("tracker default hostname : " + hostnameTracker);
|
|
|
|
|
}
|
|
|
|
|
System.out.println("enter tracker's port (default = "+trackerPortRange.getDefaultPort() + "): ");
|
|
|
|
|
String portTrackerStr = scanner.nextLine();
|
|
|
|
|
if(portTrackerStr.equals("")){
|
|
|
|
|
if (portTrackerStr.equals("")) {
|
|
|
|
|
portTracker = trackerPortRange.getDefaultPort();
|
|
|
|
|
System.out.println("using default port : " + portTracker);
|
|
|
|
|
} else {
|
|
|
|
@ -132,63 +132,66 @@ public class ClientP2P {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (serverPortRange.isPortInRange(portServer)){
|
|
|
|
|
if(trackerPortRange.isPortInRange(portTracker)){
|
|
|
|
|
System.out.println("using hostname : " + hostnameServer);
|
|
|
|
|
System.out.println("using port : " + portServer);
|
|
|
|
|
System.out.println("tracker hostname : " + hostnameTracker);
|
|
|
|
|
System.out.println("tracker port : " + portTracker);
|
|
|
|
|
ClientP2P c = new ClientP2P(hostnameServer, portServer, hostnameTracker, portTracker);
|
|
|
|
|
ServerManagementUDP smudp = new ServerManagementUDP(c.directories.getDataHomeDirectory(), c.server, c.tracker, c.loggerServer);
|
|
|
|
|
ServerManagementTCP smtcp = new ServerManagementTCP(c.directories.getDataHomeDirectory(), c.server, c.tracker, c.loggerServer);
|
|
|
|
|
Thread tudp = new Thread(smudp);
|
|
|
|
|
tudp.setName("server UDP P2P-JAVA-PROJECT");
|
|
|
|
|
tudp.start();
|
|
|
|
|
Thread ttcp = new Thread(smtcp);
|
|
|
|
|
ttcp.setName("server TCP P2P-JAVA-PROJECT");
|
|
|
|
|
ttcp.start();
|
|
|
|
|
boolean serverInRange = serverPortRange.isPortInRange(portServer);
|
|
|
|
|
boolean trackerInRange = trackerPortRange.isPortInRange(portTracker);
|
|
|
|
|
|
|
|
|
|
// Wait a bit before printing client interface
|
|
|
|
|
// This is not required, but allow to have a cleaner interface
|
|
|
|
|
try {
|
|
|
|
|
Thread.sleep(200);
|
|
|
|
|
} catch(InterruptedException e) {
|
|
|
|
|
Thread.currentThread().interrupt();
|
|
|
|
|
}
|
|
|
|
|
if (serverInRange && trackerInRange) {
|
|
|
|
|
System.out.println("using hostname : " + hostnameServer);
|
|
|
|
|
System.out.println("using port : " + portServer);
|
|
|
|
|
System.out.println("tracker hostname : " + hostnameTracker);
|
|
|
|
|
System.out.println("tracker port : " + portTracker);
|
|
|
|
|
ClientP2P c = new ClientP2P(hostnameServer, portServer, hostnameTracker, portTracker);
|
|
|
|
|
ServerManagementUDP smudp = new ServerManagementUDP(c.directories.getDataHomeDirectory(), c.server, c.tracker, c.loggerServer);
|
|
|
|
|
ServerManagementTCP smtcp = new ServerManagementTCP(c.directories.getDataHomeDirectory(), c.server, c.tracker, c.loggerServer);
|
|
|
|
|
Thread tudp = new Thread(smudp);
|
|
|
|
|
tudp.setName("server UDP P2P-JAVA-PROJECT");
|
|
|
|
|
tudp.start();
|
|
|
|
|
Thread ttcp = new Thread(smtcp);
|
|
|
|
|
ttcp.setName("server TCP P2P-JAVA-PROJECT");
|
|
|
|
|
ttcp.start();
|
|
|
|
|
|
|
|
|
|
Thread tclient;
|
|
|
|
|
switch(protocolClient){
|
|
|
|
|
case "UDP":
|
|
|
|
|
case "udp":
|
|
|
|
|
case "upd": // to avoid users typos
|
|
|
|
|
case "2" :
|
|
|
|
|
System.out.println("Starting with UDP");
|
|
|
|
|
ClientManagementUDP cmudp = new ClientManagementUDP(c.directories.getDataHomeDirectory(), c.tracker, c.directories.getDataHomeDirectory() + c.partsDir, c.loggerClient, c.scanner, c.server);
|
|
|
|
|
tclient = new Thread(cmudp);
|
|
|
|
|
break;
|
|
|
|
|
case "TCP":
|
|
|
|
|
case "tcp":
|
|
|
|
|
case "1":
|
|
|
|
|
default:
|
|
|
|
|
System.out.println("Starting with TCP");
|
|
|
|
|
ClientManagementTCP cmtcp = new ClientManagementTCP(c.directories.getDataHomeDirectory(), c.tracker, c.directories.getDataHomeDirectory() + c.partsDir, c.loggerClient, c.scanner, c.server);
|
|
|
|
|
tclient = new Thread(cmtcp);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
tclient.setName("client P2P-JAVA-PROJECT");
|
|
|
|
|
tclient.start();
|
|
|
|
|
try {
|
|
|
|
|
tclient.join();
|
|
|
|
|
} catch (InterruptedException e) {}
|
|
|
|
|
smudp.setStop();
|
|
|
|
|
smtcp.setStop();
|
|
|
|
|
// Wait a bit before printing client interface
|
|
|
|
|
// This is not required, but allow to have a cleaner interface
|
|
|
|
|
try {
|
|
|
|
|
Thread.sleep(200);
|
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
|
Thread.currentThread().interrupt();
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
System.out.println("\n TRACKER: Port not in range. " + trackerPortRange);
|
|
|
|
|
|
|
|
|
|
Thread tclient;
|
|
|
|
|
switch (protocolClient) {
|
|
|
|
|
case "UDP":
|
|
|
|
|
case "udp":
|
|
|
|
|
case "upd": // to avoid users typos
|
|
|
|
|
case "2" :
|
|
|
|
|
System.out.println("Starting with UDP");
|
|
|
|
|
ClientManagementUDP cmudp = new ClientManagementUDP(c.directories.getDataHomeDirectory(), c.tracker, c.directories.getDataHomeDirectory() + c.partsDir, c.loggerClient, c.scanner, c.server);
|
|
|
|
|
tclient = new Thread(cmudp);
|
|
|
|
|
break;
|
|
|
|
|
case "TCP":
|
|
|
|
|
case "tcp":
|
|
|
|
|
case "1":
|
|
|
|
|
default:
|
|
|
|
|
System.out.println("Starting with TCP");
|
|
|
|
|
ClientManagementTCP cmtcp = new ClientManagementTCP(c.directories.getDataHomeDirectory(), c.tracker, c.directories.getDataHomeDirectory() + c.partsDir, c.loggerClient, c.scanner, c.server);
|
|
|
|
|
tclient = new Thread(cmtcp);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
System.out.println("\n SERVER: Port not in range. " + serverPortRange);
|
|
|
|
|
tclient.setName("client P2P-JAVA-PROJECT");
|
|
|
|
|
tclient.start();
|
|
|
|
|
try {
|
|
|
|
|
tclient.join();
|
|
|
|
|
} catch (InterruptedException e) {}
|
|
|
|
|
smudp.setStop();
|
|
|
|
|
smtcp.setStop();
|
|
|
|
|
} else {
|
|
|
|
|
if (!serverInRange) {
|
|
|
|
|
System.err.println("SERVER: Port not in range. " + serverPortRange);
|
|
|
|
|
}
|
|
|
|
|
if (!trackerInRange) {
|
|
|
|
|
System.err.println("TRACKER: Port not in range. " + trackerPortRange);
|
|
|
|
|
}
|
|
|
|
|
System.exit(2);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|