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}