Package org.apache.james.protocols.pop3.core

Source Code of org.apache.james.protocols.pop3.core.AbstractRetrCmdHandler

/****************************************************************
* Licensed to the Apache Software Foundation (ASF) under one   *
* or more contributor license agreements.  See the NOTICE file *
* distributed with this work for additional information        *
* regarding copyright ownership.  The ASF licenses this file   *
* to you 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.james.protocols.pop3.core;

import org.apache.james.protocols.api.CommandHandler;
import org.apache.james.protocols.api.Request;
import org.apache.james.protocols.api.Response;
import org.apache.james.protocols.pop3.POP3Exception;
import org.apache.james.protocols.pop3.POP3Response;
import org.apache.james.protocols.pop3.POP3Session;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

/**
* Handles RETR command
*/
public abstract class AbstractRetrCmdHandler implements CommandHandler<POP3Session> {

  private final static String COMMAND_NAME = "RETR";

  /**
   * Handler method called upon receipt of a RETR command. This command
   * retrieves a particular mail message from the mailbox.
   *
   */
  public Response onCommand(POP3Session session, Request request) {
    POP3Response response = null;
    String parameters = request.getArgument();
    if (session.getHandlerState() == POP3Session.TRANSACTION) {
      int num = 0;
      try {
        num = Integer.parseInt(parameters.trim());
      } catch (Exception e) {
        response = new POP3Response(POP3Response.ERR_RESPONSE,
            "Usage: RETR [mail number]");
        return response;
      }
      try {
        InputStream msgIn = getMessageInputstream(session, num);
        response = new POP3Response(POP3Response.OK_RESPONSE,
            "Message follows");
        try {

          // write the full mail to the client
          writeMessageContentTo(msgIn, response, -1);

        } finally {
          response.appendLine(".");

        }
        return response;

      } catch (IOException ioe) {
        response = new POP3Response(POP3Response.ERR_RESPONSE,
            "Error while retrieving message.");
      } catch (POP3Exception me) {
        response = new POP3Response(POP3Response.ERR_RESPONSE,
            "Error while retrieving message.");
      } catch (IndexOutOfBoundsException iob) {
        StringBuilder responseBuffer = new StringBuilder(64).append(
            "Message (").append(num).append(") does not exist.");
        response = new POP3Response(POP3Response.ERR_RESPONSE,
            responseBuffer.toString());
      }
    } else {
      response = new POP3Response(POP3Response.ERR_RESPONSE);
    }
    return response;
  }

  /**
   * Return the InputStream for the given message number. Throw Exception if
   * no message was found for the number
   *
   * @param session
   * @param num
   * @return message
   * @throws POP3Exception
   */
  protected abstract InputStream getMessageInputstream(POP3Session session, int num)
      throws POP3Exception;

  /**
   * Writes the content of the Mail to the client
   *
   * @param mail
   *            the Mail to write
   * @param lines
   *            the number of lines to write to the client. If -1 is given it
   *            write every line of the given MimeMessage to the client
   * @param session
   *            the POP3Session to use
   *
   * @throws MessagingException
   *             if the MimeMessage is not set for this Mail
   * @throws IOException
   *             if an error occurs while reading or writing from the stream
   */
  protected void writeMessageContentTo(InputStream mailIn,
      POP3Response response, int lines) throws IOException {
    String line;
    BufferedReader br;

    br = new BufferedReader(new InputStreamReader(mailIn));
    try {

      while (lines == -1 || lines > 0) {
        if ((line = br.readLine()) == null) {
          break;
        }

        // add extra dot if line starts with dot
        if (line.startsWith(".")) {
          line = "." + line;
        }
        response.appendLine(line);

        lines--;

      }

    } finally {
      br.close();
    }

  }

  /*
   * (non-Javadoc)
   *
   * @see org.apache.james.api.protocol.CommonCommandHandler#getImplCommands()
   */
  public Collection<String> getImplCommands() {
    List<String> commands = new ArrayList<String>();
    commands.add(COMMAND_NAME);
    return commands;
  }

}
TOP

Related Classes of org.apache.james.protocols.pop3.core.AbstractRetrCmdHandler

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.