Newer
Older
import java.io.IOException;
import java.net.InetSocketAddress;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLEngine;
import javax.net.ssl.SSLParameters;
import javax.net.ssl.TrustManagerFactory;
import com.sun.net.httpserver.HttpsConfigurator;
import com.sun.net.httpserver.HttpsParameters;
import com.sun.net.httpserver.HttpsServer;
Alfredo Chissotti
committed
public static void main(String[] args) throws IOException, JSONException {
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) Executors.newCachedThreadPool();
HttpsServer server = HttpsServer.create(new InetSocketAddress(port), 0);// port gets set here
// initialise the HTTPS server
try {
SSLContext sslContext = SSLContext.getInstance("TLS");
// initialise the keystore
char[] password = "miapasswd".toCharArray();
KeyStore ks = KeyStore.getInstance("JKS");
FileInputStream fis = new FileInputStream("../lig.keystore");
ks.load(fis, password);
// setup the key manager factory
KeyManagerFactory kmf = KeyManagerFactory.getInstance("SunX509");
kmf.init(ks, password);
// setup the trust manager factory
TrustManagerFactory tmf = TrustManagerFactory.getInstance("SunX509");
tmf.init(ks);
// setup the HTTPS context and parameters
sslContext.init(kmf.getKeyManagers(), tmf.getTrustManagers(), null);
server.setHttpsConfigurator(new HttpsConfigurator(sslContext) {
@Override
public void configure(HttpsParameters params) {
try {
// initialise the SSL context
SSLContext context = getSSLContext();
SSLEngine engine = context.createSSLEngine();
params.setNeedClientAuth(false);
params.setCipherSuites(engine.getEnabledCipherSuites());
params.setProtocols(engine.getEnabledProtocols());
// Set the SSL parameters
SSLParameters sslParameters = context.getSupportedSSLParameters();
params.setSSLParameters(sslParameters);
} catch (Exception ex) {
System.out.println("Failed to create HTTPS port");
ex.printStackTrace();
}
}
});
// chiamata per popolare moduli
URL url = new URL("https://gitlab.di.unipmn.it/alfredo/iotlabgw.edu-al.unipmn.it/-/raw/main/index.json");
HttpsURLConnection con = (HttpsURLConnection) url.openConnection();
Helper.setConnectionSettings(con, "GET");
// leggo risposta
int status = con.getResponseCode();
// controllare ToDo
String content = Helper.getResponseFromConnection(con);
con.disconnect();
// manipolazione per ottenere i campi dei moduli
riempiModuli(content);
server.setExecutor(threadPoolExecutor);
// API del server
server.createContext("/install/", new InstallHandler());
server.createContext("/start/", new StartHandler());
server.createContext("/stop/", new StopHandler());
server.createContext("/delete/", new DeleteHandler());
server.createContext("/secured/domains/", new TokenHandler());
server.createContext("/secured/services", new ServicesHandler());
server.createContext("/secured/priviledges", new PriviledgesHandler());
server.start();
System.out.println("domain running on " + Helper.getSelfURL());
} catch (Exception e) {
System.out.println("Failed to create HTTPS server on port " + port + Helper.getSelfURL());
e.printStackTrace();
}
private static void riempiModuli(String content) throws JSONException {
for (int i = 0; i < s1.length; i++) {
String remZip = s1[i].substring(0, s1[i].length() - 4);
if(remZip.contains("-debian9-BB")){
String[] curr = remZip.split("-");
String a = curr[0];
String b = curr[1];
try {
// inserimento modulo non arduino
DBC.fillModules(a, b, s1[i]);
} catch (SQLException | JSONException e) {
e.printStackTrace();
}
}
if(remZip.contains("_Arduino1wifi")){
String[] curr = remZip.split("_");
String a = curr[0];
// vogliamo solo Arduino1
String b = curr[1].substring(0, 8);
try {
// inserimento modulo arduino
DBC.fillModules(a, b, s1[i]);
} catch (SQLException | JSONException e) {
e.printStackTrace();