1fba2635c088b01af59300e8a02611bb788ee3bffchrismair/* 2fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Copyright 2007 the original author or authors. 3fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 4fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Licensed under the Apache License, Version 2.0 (the "License"); 5fba2635c088b01af59300e8a02611bb788ee3bffchrismair * you may not use this file except in compliance with the License. 6fba2635c088b01af59300e8a02611bb788ee3bffchrismair * You may obtain a copy of the License at 7fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 8fba2635c088b01af59300e8a02611bb788ee3bffchrismair * http://www.apache.org/licenses/LICENSE-2.0 9fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 10fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Unless required by applicable law or agreed to in writing, software 11fba2635c088b01af59300e8a02611bb788ee3bffchrismair * distributed under the License is distributed on an "AS IS" BASIS, 12fba2635c088b01af59300e8a02611bb788ee3bffchrismair * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13fba2635c088b01af59300e8a02611bb788ee3bffchrismair * See the License for the specific language governing permissions and 14fba2635c088b01af59300e8a02611bb788ee3bffchrismair * limitations under the License. 15fba2635c088b01af59300e8a02611bb788ee3bffchrismair */ 16fba2635c088b01af59300e8a02611bb788ee3bffchrismairpackage org.mockftpserver.core.command; 17fba2635c088b01af59300e8a02611bb788ee3bffchrismair 18fba2635c088b01af59300e8a02611bb788ee3bffchrismairimport org.mockftpserver.core.session.Session; 19fba2635c088b01af59300e8a02611bb788ee3bffchrismair 20fba2635c088b01af59300e8a02611bb788ee3bffchrismair/** 21fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Interface for classes that can handle an FTP command. 22fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 23fba2635c088b01af59300e8a02611bb788ee3bffchrismair * @version $Revision$ - $Date$ 24fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 25fba2635c088b01af59300e8a02611bb788ee3bffchrismair * @author Chris Mair 26fba2635c088b01af59300e8a02611bb788ee3bffchrismair */ 27fba2635c088b01af59300e8a02611bb788ee3bffchrismairpublic interface CommandHandler { 28fba2635c088b01af59300e8a02611bb788ee3bffchrismair 29fba2635c088b01af59300e8a02611bb788ee3bffchrismair /** 30fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Handle the specified command for the session. This method is declared to throw 31fba2635c088b01af59300e8a02611bb788ee3bffchrismair * Exception, allowing CommandHandler implementations to avoid unnecessary 32fba2635c088b01af59300e8a02611bb788ee3bffchrismair * exception-handling. All checked exceptions are expected to be wrapped and handled 33fba2635c088b01af59300e8a02611bb788ee3bffchrismair * by the caller. 34fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 35fba2635c088b01af59300e8a02611bb788ee3bffchrismair * @param command - the Command to be handled 36fba2635c088b01af59300e8a02611bb788ee3bffchrismair * @param session - the session on which the Command was submitted 37fba2635c088b01af59300e8a02611bb788ee3bffchrismair * 38fba2635c088b01af59300e8a02611bb788ee3bffchrismair * @throws Exception 39fba2635c088b01af59300e8a02611bb788ee3bffchrismair */ 40fba2635c088b01af59300e8a02611bb788ee3bffchrismair public void handleCommand(Command command, Session session) throws Exception; 41fba2635c088b01af59300e8a02611bb788ee3bffchrismair 42fba2635c088b01af59300e8a02611bb788ee3bffchrismair}