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; 019 020import java.util.logging.Level; 021 022import org.syncany.config.Config; 023import org.syncany.operations.daemon.messages.api.FolderRequest; 024import org.syncany.operations.daemon.messages.api.FolderRequestHandler; 025import org.syncany.operations.daemon.messages.api.Response; 026import org.syncany.operations.ls.LsOperation; 027import org.syncany.operations.ls.LsOperationResult; 028 029public class LsFolderRequestHandler extends FolderRequestHandler { 030 public LsFolderRequestHandler(Config config) { 031 super(config); 032 } 033 034 @Override 035 public Response handleRequest(FolderRequest request) { 036 LsFolderRequest concreteRequest = (LsFolderRequest) request; 037 038 try { 039 LsOperation operation = new LsOperation(config, concreteRequest.getOptions()); 040 LsOperationResult operationResult = operation.execute(); 041 LsFolderResponse response = new LsFolderResponse(operationResult, request.getId()); 042 043 return response; 044 } 045 catch (Exception e) { 046 logger.log(Level.WARNING, "Cannot obtain status.", e); 047 return new BadRequestResponse(request.getId(), "Cannot execute operation: " + e.getMessage()); 048 } 049 } 050}