/* http-base - Extensions to jdk.httpserver Copyright (C) 2021 Ulrich Hilger This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ package de.uhilger.httpserver.base.handler; import com.sun.net.httpserver.HttpExchange; import de.uhilger.httpserver.base.actor.DelegateActor; import java.io.IOException; import java.util.HashMap; import java.util.Map; /** * Der PatternDelegator delegiert HTTP-Aufrufe an HttpHandler, indem * der URL des Aufrufs mit einem Muster verglichen wird. Zu einem bestimmten * Muster passende URLs werden an den zum Muster hinterlegten HttpHandler * weitergegeben. * * Wird kein passendes Muster gefunden, reicht der PatternDelegator * die Anfrage an den FileHandler weiter, wodurch - sofern vorhanden - die * vom URL bezeichnete Ressource ausgeliefert wird. * * @author Ulrich Hilger * @version 1, 29.06.2021 */ public class PatternDelegator extends FileHandler { /** die HttpHandler, an die dieser Delegator passende Anfragen weitergibt */ //private Map handlers; private Map handlers; /** * Ein neues Objekt der Klasse PatternDelegator erzeugen */ public PatternDelegator() { //super(absoluteDirectoryPathAndName); handlers = new HashMap(); } /** * Diesem Delegator einen HttpHandler hinzufuegen * * @param pattern das Muster, das ein URL treffen muss, damit der hier * hinzugefuegte Handler aufgerufen wird * @param handler der Handler, an den dieser Delegator eine Anfrage * delegiert, wenn das Muster passt */ public void addHandler(String pattern, HandlerDescriptor handler) { handlers.put(pattern, handler); } /** * Einen HttpHandler von diesem Delegator entfernen * * @param pattern das Muster, das dem HttpHandler zugeordnet ist, der * entfernt werden soll */ public void removeHandler(String pattern) { handlers.remove(pattern); } /** * Eine HTTP-Anfrage ausfuehren, indem das Muster des URL mit den * Mustern verglichen wird, die fuer diesen Delegator hinterlegt wurden * und die Anfrage an den HttpHandler delegiert wird, dessen Aufrufmuster * passt * * @param exchange das Objekt mit allen Infos zu Anfrage und Antwort * @throws IOException wenn etwas nicht geklappt hat */ @Override public void handle(HttpExchange exchange) throws IOException { boolean noMatch = new DelegateActor().handle(exchange, handlers); if(noMatch) { super.handle(exchange); } } }