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_remote.LsRemoteOperation; 027import org.syncany.operations.ls_remote.LsRemoteOperationResult; 028 029public class LsRemoteFolderRequestHandler extends FolderRequestHandler { 030 public LsRemoteFolderRequestHandler(Config config) { 031 super(config); 032 } 033 034 @Override 035 public Response handleRequest(FolderRequest request) { 036 try { 037 LsRemoteOperation operation = new LsRemoteOperation(config); 038 LsRemoteOperationResult operationResult = operation.execute(); 039 LsRemoteFolderResponse response = new LsRemoteFolderResponse(operationResult, request.getId()); 040 041 return response; 042 } 043 catch (Exception e) { 044 logger.log(Level.WARNING, "Cannot obtain status.", e); 045 return new BadRequestResponse(request.getId(), "Cannot execute operation: " + e.getMessage()); 046 } 047 } 048}