added functionnality to select a file to download by a number
This commit is contained in:
parent
f77ea0ae2b
commit
7af42f000f
@ -1,11 +1,14 @@
|
|||||||
package clientP2P;
|
package clientP2P;
|
||||||
import tools.HostItem;
|
|
||||||
import tools.Logger;
|
import java.util.Arrays;
|
||||||
import tools.LogLevel;
|
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import localException.ProtocolError;
|
import java.security.MessageDigest;
|
||||||
import tools.ServeErrors;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.net.UnknownHostException;
|
||||||
import protocolP2P.RequestResponseCode;
|
import protocolP2P.RequestResponseCode;
|
||||||
import protocolP2P.FileList;
|
import protocolP2P.FileList;
|
||||||
import protocolP2P.ProtocolP2PPacket;
|
import protocolP2P.ProtocolP2PPacket;
|
||||||
@ -13,6 +16,7 @@ import protocolP2P.DiscoverRequest;
|
|||||||
import protocolP2P.DiscoverResponse;
|
import protocolP2P.DiscoverResponse;
|
||||||
import protocolP2P.Payload;
|
import protocolP2P.Payload;
|
||||||
import protocolP2P.HashAlgorithm;
|
import protocolP2P.HashAlgorithm;
|
||||||
|
import localException.ProtocolError;
|
||||||
import localException.InternalError;
|
import localException.InternalError;
|
||||||
import localException.ProtocolError;
|
import localException.ProtocolError;
|
||||||
import localException.SizeError;
|
import localException.SizeError;
|
||||||
@ -26,15 +30,10 @@ import remoteException.NotFound;
|
|||||||
import remoteException.ProtocolRemoteError;
|
import remoteException.ProtocolRemoteError;
|
||||||
import remoteException.VersionRemoteError;
|
import remoteException.VersionRemoteError;
|
||||||
import remoteException.NotATracker;
|
import remoteException.NotATracker;
|
||||||
import remoteException.UnknownHost;
|
import tools.ServeErrors;
|
||||||
import java.io.IOException;
|
import tools.HostItem;
|
||||||
import java.security.MessageDigest;
|
import tools.Logger;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import tools.LogLevel;
|
||||||
import java.net.UnknownHostException;
|
|
||||||
import java.nio.file.Files;
|
|
||||||
import java.nio.file.Paths;
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
|
|
||||||
/** Implementation of P2P-JAVA-PROJECT CLIENT
|
/** Implementation of P2P-JAVA-PROJECT CLIENT
|
||||||
* @author Louis Royer
|
* @author Louis Royer
|
||||||
@ -230,14 +229,30 @@ public abstract class ClientManagement extends ServeErrors implements Runnable {
|
|||||||
*/
|
*/
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
|
int i = 1;
|
||||||
String[] list = listDirectory();
|
String[] list = listDirectory();
|
||||||
System.out.println("Files present on the server:");
|
System.out.println("Files present on the server:");
|
||||||
|
System.out.println("0 : Exit the program");
|
||||||
for(String listItem: list) {
|
for(String listItem: list) {
|
||||||
System.out.println(listItem);
|
System.out.println(i + " : " + listItem);
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
System.out.println("Name of the file to download:");
|
System.out.println("Type the number associated with the file to download:");
|
||||||
String f = scanner.nextLine();
|
String f = scanner.nextLine();
|
||||||
download(f);
|
if(f.equals("0")){
|
||||||
|
System.out.println("on ferme tout");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
int j = Integer.parseInt(f);
|
||||||
|
if(j <= list.length){
|
||||||
|
j = j-1;
|
||||||
|
download(list[j]);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
System.out.println("Wrong number");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//download(f);
|
||||||
System.out.println("File " + f + " sucessfully downloaded");
|
System.out.println("File " + f + " sucessfully downloaded");
|
||||||
writeLog("File " + f + " sucessfully downloaded", LogLevel.Info);
|
writeLog("File " + f + " sucessfully downloaded", LogLevel.Info);
|
||||||
} catch (EmptyDirectory e) {
|
} catch (EmptyDirectory e) {
|
||||||
|
@ -4,7 +4,6 @@ import java.util.Scanner;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import clientP2P.ClientManagementUDP;
|
import clientP2P.ClientManagementUDP;
|
||||||
import clientP2P.ClientManagementTCP;
|
import clientP2P.ClientManagementTCP;
|
||||||
|
|
||||||
import serverP2P.ServerManagementUDP;
|
import serverP2P.ServerManagementUDP;
|
||||||
import serverP2P.ServerManagementTCP;
|
import serverP2P.ServerManagementTCP;
|
||||||
import tools.Logger;
|
import tools.Logger;
|
||||||
@ -14,7 +13,6 @@ import tools.HostItem;
|
|||||||
import tools.ServerPortRange;
|
import tools.ServerPortRange;
|
||||||
import tools.TrackerPortRange;
|
import tools.TrackerPortRange;
|
||||||
|
|
||||||
|
|
||||||
/** Client + Server implementation.
|
/** Client + Server implementation.
|
||||||
* @author Louis Royer
|
* @author Louis Royer
|
||||||
* @author Flavien Haas
|
* @author Flavien Haas
|
||||||
|
Loading…
Reference in New Issue
Block a user