// // POP3ClientSession.h // // $Id: //poco/1.3/Net/include/Poco/Net/POP3ClientSession.h#1 $ // // Library: Net // Package: Mail // Module: POP3ClientSession // // Definition of the POP3ClientSession class. // // Copyright (c) 2005-2006, Applied Informatics Software Engineering GmbH. // and Contributors. // // Permission is hereby granted, free of charge, to any person or organization // obtaining a copy of the software and accompanying documentation covered by // this license (the "Software") to use, reproduce, display, distribute, // execute, and transmit the Software, and to prepare derivative works of the // Software, and to permit third-parties to whom the Software is furnished to // do so, all subject to the following: // // The copyright notices in the Software and this entire statement, including // the above license grant, this restriction and the following disclaimer, // must be included in all copies of the Software, in whole or in part, and // all derivative works of the Software, unless such copies or derivative // works are solely in the form of machine-executable object code generated by // a source language processor. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER // DEALINGS IN THE SOFTWARE. // #ifndef Net_POP3ClientSession_INCLUDED #define Net_POP3ClientSession_INCLUDED #include "Poco/Net/Net.h" #include "Poco/Net/DialogSocket.h" #include "Poco/Timespan.h" #include #include namespace Poco { namespace Net { class MessageHeader; class MailMessage; class PartHandler; class Net_API POP3ClientSession /// This class implements an Post Office Protocol /// Version 3 (POP3, RFC 1939) /// client for receiving e-mail messages. { public: enum { POP3_PORT = 110 }; struct MessageInfo /// Information returned by listMessages(). { int id; int size; }; typedef std::vector MessageInfoVec; POP3ClientSession(const StreamSocket& socket); /// Creates the POP3ClientSession using /// the given socket, which must be connected /// to a POP3 server. POP3ClientSession(const std::string& host, Poco::UInt16 port = POP3_PORT); /// Creates the POP3ClientSession using a socket connected /// to the given host and port. virtual ~POP3ClientSession(); /// Destroys the SMTPClientSession. void setTimeout(const Poco::Timespan& timeout); /// Sets the timeout for socket read operations. Poco::Timespan getTimeout() const; /// Returns the timeout for socket read operations. void login(const std::string& username, const std::string& password); /// Logs in to the POP3 server by sending a USER command /// followed by a PASS command. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void close(); /// Sends a QUIT command and closes the connection to the server. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. int messageCount(); /// Sends a STAT command to determine the number of messages /// available on the server and returns that number. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void listMessages(MessageInfoVec& messages); /// Fills the given vector with the ids and sizes of all /// messages available on the server. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void retrieveMessage(int id, MailMessage& message); /// Retrieves the message with the given id from the server and /// stores the raw message content in the message's /// content string, available with message.getContent(). /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void retrieveMessage(int id, MailMessage& message, PartHandler& handler); /// Retrieves the message with the given id from the server and /// stores it in message. /// /// If the message has multiple parts, the parts /// are reported to the PartHandler. If the message /// is not a multi-part message, the content is stored /// in a string available by calling message.getContent(). /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void retrieveMessage(int id, std::ostream& ostr); /// Retrieves the raw message with the given id from the /// server and copies it to the given output stream. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void retrieveHeader(int id, MessageHeader& header); /// Retrieves the message header of the message with the /// given id and stores it in header. /// /// For this to work, the server must support the TOP command. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. void deleteMessage(int id); /// Marks the message with the given ID for deletion. The message /// will be deleted when the connection to the server is /// closed by calling close(). /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. bool sendCommand(const std::string& command, std::string& response); /// Sends the given command verbatim to the server /// and waits for a response. /// /// Returns true if the response is positive, false otherwise. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. bool sendCommand(const std::string& command, const std::string& arg, std::string& response); /// Sends the given command verbatim to the server /// and waits for a response. /// /// Returns true if the response is positive, false otherwise. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. bool sendCommand(const std::string& command, const std::string& arg1, const std::string& arg2, std::string& response); /// Sends the given command verbatim to the server /// and waits for a response. /// /// Returns true if the response is positive, false otherwise. /// /// Throws a POP3Exception in case of a POP3-specific error, or a /// NetException in case of a general network communication failure. protected: static bool isPositive(const std::string& response); private: DialogSocket _socket; bool _isOpen; }; } } // namespace Poco::Net #endif // Net_POP3ClientSession_INCLUDED