001/* 002 * Syncany, www.syncany.org 003 * Copyright (C) 2011-2016 Philipp C. Heckel <philipp.heckel@gmail.com> 004 * 005 * This program is free software: you can redistribute it and/or modify 006 * it under the terms of the GNU General Public License as published by 007 * the Free Software Foundation, either version 3 of the License, or 008 * (at your option) any later version. 009 * 010 * This program is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU General Public License for more details. 014 * 015 * You should have received a copy of the GNU General Public License 016 * along with this program. If not, see <http://www.gnu.org/licenses/>. 017 */ 018package org.syncany.operations.daemon.messages.api; 019 020import java.util.logging.Logger; 021 022import org.syncany.config.Config; 023 024public abstract class FolderRequestHandler extends RequestHandler { 025 protected static final Logger logger = Logger.getLogger(FolderRequestHandler.class.getSimpleName()); 026 protected Config config; 027 028 public FolderRequestHandler(Config config) { 029 this.config = config; 030 } 031 032 public abstract Response handleRequest(FolderRequest request); 033 034 // TODO [low] Fix "throws Exception" 035 public static FolderRequestHandler createFolderRequestHandler(FolderRequest request, Config config) throws Exception { 036 String fqClassName = request.getClass().getName() + "Handler"; // TODO [medium] Ugly hardcoded string 037 Class<?> clazz = Class.forName(fqClassName); 038 039 return (FolderRequestHandler) clazz.getConstructor(Config.class).newInstance(config); 040 } 041}