Java tutorial
// $Id: STOU.java 306757 2005-10-06 11:33:33 +0530 (Thu, 06 Oct 2005) rana_b $ /* * Copyright 2004 The Apache Software Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.ftpserver.command; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.SocketException; import org.apache.commons.logging.Log; import org.apache.ftpserver.Command; import org.apache.ftpserver.FtpRequestImpl; import org.apache.ftpserver.FtpWriter; import org.apache.ftpserver.RequestHandler; import org.apache.ftpserver.ftplet.FileObject; import org.apache.ftpserver.ftplet.FileSystemView; import org.apache.ftpserver.ftplet.FtpException; import org.apache.ftpserver.ftplet.Ftplet; import org.apache.ftpserver.ftplet.FtpletEnum; import org.apache.ftpserver.interfaces.IFtpConfig; import org.apache.ftpserver.interfaces.IFtpStatistics; import org.apache.ftpserver.util.IoUtils; /** * <code>STOU <CRLF></code><br> * * This command behaves like STOR except that the resultant * file is to be created in the current directory under a name * unique to that directory. The 250 Transfer Started response * must include the name generated. * * @author <a href="mailto:rana_b@yahoo.com">Rana Bhattacharyya</a> */ public class STOU implements Command { /** * Execute command. */ public void execute(RequestHandler handler, FtpRequestImpl request, FtpWriter out) throws IOException, FtpException { try { // reset state variables request.resetState(); IFtpConfig fconfig = handler.getConfig(); // call Ftplet.onUploadUniqueStart() method Ftplet ftpletContainer = fconfig.getFtpletContainer(); FtpletEnum ftpletRet = ftpletContainer.onUploadUniqueStart(request, out); if (ftpletRet == FtpletEnum.RET_SKIP) { return; } else if (ftpletRet == FtpletEnum.RET_DISCONNECT) { fconfig.getConnectionManager().closeConnection(handler); return; } // get filenames FileObject file = null; try { file = request.getFileSystemView().getFileObject("ftp.dat"); file = getUniqueFile(handler, file); } catch (Exception ex) { } if (file == null) { out.send(550, "STOU", null); return; } String fileName = file.getFullName(); // check permission if (!file.hasWritePermission()) { out.send(550, "STOU.permission", fileName); return; } // get data connection out.send(150, "STOU", null); InputStream is = null; try { is = request.getDataInputStream(); } catch (IOException ex) { out.send(425, "STOU", fileName); return; } // get data from client boolean failure = false; BufferedInputStream bis = null; BufferedOutputStream bos = null; out.send(250, "STOU", fileName); try { // open streams bis = IoUtils.getBufferedInputStream(is); bos = IoUtils.getBufferedOutputStream(file.createOutputStream(false)); // transfer data int maxRate = handler.getRequest().getUser().getMaxUploadRate(); long transSz = handler.transfer(bis, bos, maxRate); // log message String userName = request.getUser().getName(); Log log = fconfig.getLogFactory().getInstance(getClass()); log.info("File upload : " + userName + " - " + fileName); // notify the statistics component IFtpStatistics ftpStat = (IFtpStatistics) fconfig.getFtpStatistics(); ftpStat.setUpload(handler, file, transSz); } catch (SocketException ex) { failure = true; out.send(426, "STOU", fileName); } catch (IOException ex) { failure = true; out.send(551, "STOU", fileName); } finally { IoUtils.close(bis); IoUtils.close(bos); } // if data transfer ok - send transfer complete message if (!failure) { out.send(226, "STOU", fileName); // call Ftplet.onUploadUniqueEnd() method ftpletRet = ftpletContainer.onUploadUniqueEnd(request, out); if (ftpletRet == FtpletEnum.RET_DISCONNECT) { fconfig.getConnectionManager().closeConnection(handler); return; } } } finally { request.getFtpDataConnection().closeDataSocket(); } } /** * Get unique file object. */ protected FileObject getUniqueFile(RequestHandler handler, FileObject oldFile) throws FtpException { FileObject newFile = oldFile; FileSystemView fsView = handler.getRequest().getFileSystemView(); String fileName = newFile.getFullName(); while (newFile.doesExist()) { newFile = fsView.getFileObject(fileName + '.' + System.currentTimeMillis()); } return newFile; } }