Persoenliche Mediazentrale
ulrich
2021-04-03 0439151a901ba6f51b06ab1b797889be9bf36076
commit | author | age
c3b1d1 1 /*
043915 2   Mediazentrale - Personal Media Center
c3b1d1 3   Copyright (C) 2021  Ulrich Hilger
U 4
5   This program is free software: you can redistribute it and/or modify
6   it under the terms of the GNU Affero General Public License as
7   published by the Free Software Foundation, either version 3 of the
8   License, or (at your option) any later version.
9
10   This program is distributed in the hope that it will be useful,
11   but WITHOUT ANY WARRANTY; without even the implied warranty of
12   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13   GNU Affero General Public License for more details.
14
15   You should have received a copy of the GNU Affero General Public License
16   along with this program.  If not, see <https://www.gnu.org/licenses/>.
043915 17  */
c3b1d1 18 package de.uhilger.mediaz;
U 19
20 import com.sun.net.httpserver.HttpServer;
21 import de.uhilger.mediaz.handler.FileHandler;
22 import de.uhilger.mediaz.handler.StopServerHandler;
23 import java.io.IOException;
24 import java.util.logging.Logger;
25 import java.net.InetSocketAddress;
26 import java.util.concurrent.Executors;
27
28 /**
29  * Die Klasse Server stellt Methoden zur Ausf&uuml;hrung eines 
30  * HTTP-Servers bereit
31  * 
32  * @author Ulrich Hilger
33  * @version 0.1, 25.03.2021
34  */
35 public class Server {
36   
37   private static final Logger logger = Logger.getLogger(Server.class.getName());
38   
39   public static final String STR_SLASH = "/";
40   public static final String CMD_SERVER_STOP = "/server/stop";
41   
42   private int port;
43   
44   private String ctx;
45   
46   /**
47    * Ein neues Objekt der Kalsse Server erzeugen
48    * @param port  der Port, &uuml;ber den dieser Server erreichbar sein soll
49    */
50   public Server(int port) {
51     this.port = port;
52   }
53   
54   /**
55    * Den Port angeben, unter dem der Server erreichbar sein soll
56    * 
57    * @param port der Port, unter dem der Server erreichbar sein soll
58    */
59   public void setPort(int port) {
60     this.port = port;
61   }
62   
63   /**
64    * Den Namen des Kontexts angeben, &uuml;ber den dieser Server 
65    * erreichbar sein soll
66    * @param ctxName Name des Kontexts, unter dem der Server aufrufbar sein soll
67    */
68   public void setContextName(String ctxName) {
69     if(!ctxName.startsWith(STR_SLASH)) {
70       this.ctx = STR_SLASH + ctxName;
71     } else {
72       this.ctx = ctxName;
73     }
74   }
75   
76   /**
77    * Die Endpunkte ('Context'e) einrichten, unter denen die Dienste 
78    * dieses Servers erreichbar sein sollen und den Server starten
79    * 
80    * @throws IOException wenn etwas schief geht, finden sich Angaben 
81    * in diesem Objekt 
82    */
83   public void start() throws IOException {
84     logger.info("Server starting on port " + port);
85
86     HttpServer server = HttpServer.create(new InetSocketAddress(port), 0);
87     server.createContext(ctx + STR_SLASH, new FileHandler(App.getInitParameter(App.IP_WWW_DATA)));
88     server.createContext(ctx + CMD_SERVER_STOP, new StopServerHandler());
89     server.setExecutor(Executors.newFixedThreadPool(20));
90     server.start();
91   }
92
93 }