/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.frameworks.ftpclient.commands;
import org.exoplatform.frameworks.ftpclient.FtpConst;
import org.exoplatform.frameworks.ftpclient.data.FtpDataTransiver;
import org.exoplatform.frameworks.ftpclient.data.FtpFileInfo;
import org.exoplatform.frameworks.ftpclient.data.FtpFileInfoImpl;
import org.exoplatform.services.log.ExoLogger;
import org.exoplatform.services.log.Log;
import java.util.ArrayList;
/**
* Created by The eXo Platform SAS .
*
* @author Vitaly Guly
* @version $Id: $
*/
public class CmdList extends FtpCommandImpl
{
private static final Log LOG = ExoLogger.getLogger("exo.jcr.framework.command.CmdList");
protected String path = "";
protected byte[] fileData;
protected ArrayList<FtpFileInfo> files = new ArrayList<FtpFileInfo>();
public CmdList()
{
}
public CmdList(String path)
{
this.path = path;
}
public byte[] getFileData()
{
return fileData;
}
public ArrayList<FtpFileInfo> getFiles()
{
return files;
}
public int execute()
{
try
{
if (clientSession.getSystemType() == null)
{
clientSession.executeCommand(new CmdSyst());
}
String req;
if ("".equals(path))
{
req = FtpConst.Commands.CMD_LIST;
}
else
{
req = String.format("%s %s", FtpConst.Commands.CMD_LIST, path);
}
sendCommand(req);
int reply = getReply();
if (reply == FtpConst.Replyes.REPLY_125 || reply == FtpConst.Replyes.REPLY_150)
{
FtpDataTransiver dataTransiver = clientSession.getDataTransiver();
fileData = dataTransiver.receive();
dataTransiver.close();
String dd = new String(fileData, "utf-8");
String[] lines = dd.split("\r\n");
String systemType = clientSession.getSystemType();
systemType = systemType.substring(systemType.indexOf(" ") + 1);
for (int i = 0; i < lines.length; i++)
{
try
{
FtpFileInfo fileInfo = new FtpFileInfoImpl();
if (!"".equals(lines[i]))
{
fileInfo.parseDir(lines[i], systemType);
files.add(fileInfo);
}
}
catch (Exception exc)
{
LOG.info("CAN'T PARSE FILE LINE: [" + lines[i] + "]");
}
}
reply = getReply();
}
return reply;
}
catch (Exception exc)
{
LOG.info("Unhandled exception. " + exc.getMessage(), exc);
}
return -1;
}
}