📄 pop3clientsession.h
字号:
//// POP3ClientSession.h//// $Id: //poco/1.2/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 <ostream>#include <vector>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<MessageInfo> 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
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -