/usr/include/ptclib/inetmail.h is in libpt-dev 2.10.11~dfsg-2.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 | /*
* inetmail.h
*
* Internet Mail channel classes
* Simple Mail Transport Protocol & Post Office Protocol v3
*
* Portable Windows Library
*
* Copyright (c) 1993-2002 Equivalence Pty. Ltd.
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.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.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Portable Windows Library.
*
* The Initial Developer of the Original Code is Equivalence Pty. Ltd.
*
* Contributor(s): Federico Pinna and Reitek S.p.A.
*
* $Revision: 25387 $
* $Author: rjongbloed $
* $Date: 2011-03-22 22:51:09 -0500 (Tue, 22 Mar 2011) $
*/
#ifndef PTLIB_INETMAIL_H
#define PTLIB_INETMAIL_H
#ifdef P_USE_PRAGMA
#pragma interface
#endif
#include <ptclib/inetprot.h>
#include <ptclib/mime.h>
class PSocket;
//////////////////////////////////////////////////////////////////////////////
// PSMTP
/** A TCP/IP socket for the Simple Mail Transfer Protocol.
When acting as a client, the procedure is to make the connection to a
remote server, then to send a message using the following procedure:
<CODE>
PSMTPClient mail("mailserver");
if (mail.IsOpen()) {
mail.BeginMessage("Me@here.com.au", "Fred@somwhere.com");
mail.Write(myMessage);
if (!mail.EndMessage())
PError << "Mail send failed." << endl;
}
else
PError << "Mail conection failed." << endl;
</CODE>
When acting as a server, a descendant class would be created to override
at least the <A>LookUpName()</A> and <A>HandleMessage()</A> functions.
Other functions may be overridden for further enhancement to the sockets
capabilities, but these two will give a basic SMTP server functionality.
The server socket thread would continuously call the
<A>ProcessMessage()</A> function until it returns false. This will then
call the appropriate virtual function on parsing the SMTP protocol.
*/
class PSMTP : public PInternetProtocol
{
PCLASSINFO(PSMTP, PInternetProtocol)
public:
// New functions for class.
enum Commands {
HELO, EHLO, QUIT, HELP, NOOP,
TURN, RSET, VRFY, EXPN, RCPT,
MAIL, SEND, SAML, SOML, DATA,
AUTH, NumCommands
};
protected:
PSMTP();
// Create a new SMTP protocol channel.
};
/** A TCP/IP socket for the Simple Mail Transfer Protocol.
When acting as a client, the procedure is to make the connection to a
remote server, then to send a message using the following procedure:
<CODE>
PSMTPSocket mail("mailserver");
if (mail.IsOpen()) {
mail.BeginMessage("Me@here.com.au", "Fred@somwhere.com");
mail.Write(myMessage);
if (!mail.EndMessage())
PError << "Mail send failed." << endl;
}
else
PError << "Mail conection failed." << endl;
</CODE>
*/
class PSMTPClient : public PSMTP
{
PCLASSINFO(PSMTPClient, PSMTP)
public:
/** Create a TCP/IP SMPTP protocol socket channel. The parameterless form
creates an unopened socket, the form with the <CODE>address</CODE>
parameter makes a connection to a remote system, opening the socket. The
form with the <CODE>socket</CODE> parameter opens the socket to an
incoming call from a "listening" socket.
*/
PSMTPClient();
/** Destroy the channel object. This will close the channel and as a
client, QUIT from remote SMTP server.
*/
~PSMTPClient();
// Overrides from class PChannel.
/** Close the socket, and if connected as a client, QUITs from server.
@return
true if the channel was closed and the QUIT accepted by the server.
*/
virtual PBoolean Close();
// New functions for class.
/** Log into the SMTP server using the mailbox and access codes specified.
Login is actually attempted only if the server supports SASL authentication
and a common method is found
@return
true if logged in.
*/
PBoolean LogIn(
const PString & username, ///< User name on remote system.
const PString & password ///< Password for user name.
);
/** Begin transmission of a message using the SMTP socket as a client. This
negotiates with the remote server and establishes the protocol state
for data transmission. The usual Write() or stream commands may then
be used to transmit the data itself.
@return
true if message was handled, false if an error occurs.
*/
PBoolean BeginMessage(
const PString & from, ///< User name of sender.
const PString & to, ///< User name of recipient.
PBoolean eightBitMIME = false ///< Mesage will be 8 bit MIME.
);
PBoolean BeginMessage(
const PString & from, ///< User name of sender.
const PStringList & toList, ///< List of user names of recipients.
PBoolean eightBitMIME = false ///< Mesage will be 8 bit MIME.
);
/** End transmission of a message using the SMTP socket as a client.
@return
true if message was accepted by remote server, false if an error occurs.
*/
PBoolean EndMessage();
protected:
PBoolean OnOpen();
PBoolean haveHello;
PBoolean extendedHello;
PBoolean eightBitMIME;
PString fromAddress;
PStringList toNames;
PBoolean sendingData;
private:
bool InternalBeginMessage();
};
/** A TCP/IP socket for the Simple Mail Transfer Protocol.
When acting as a client, the procedure is to make the connection to a
remote server, then to send a message using the following procedure:
<CODE>
PSMTPSocket mail("mailserver");
if (mail.IsOpen()) {
mail.BeginMessage("Me@here.com.au", "Fred@somwhere.com");
mail.Write(myMessage);
if (!mail.EndMessage())
PError << "Mail send failed." << endl;
}
else
PError << "Mail conection failed." << endl;
</CODE>
When acting as a server, a descendant class would be created to override
at least the <A>LookUpName()</A> and <A>HandleMessage()</A> functions.
Other functions may be overridden for further enhancement to the sockets
capabilities, but these two will give a basic SMTP server functionality.
The server socket thread would continuously call the
<A>ProcessMessage()</A> function until it returns false. This will then
call the appropriate virtual function on parsing the SMTP protocol.
*/
class PSMTPServer : public PSMTP
{
PCLASSINFO(PSMTPServer, PSMTP)
public:
/** Create a TCP/IP SMPTP protocol socket channel. The parameterless form
creates an unopened socket, the form with the <CODE>address</CODE>
parameter makes a connection to a remote system, opening the socket. The
form with the <CODE>socket</CODE> parameter opens the socket to an
incoming call from a "listening" socket.
*/
PSMTPServer();
// New functions for class.
/** Process commands, dispatching to the appropriate virtual function. This
is used when the socket is acting as a server.
@return
true if more processing may be done, false if the QUIT command was
received or the <A>OnUnknown()</A> function returns false.
*/
PBoolean ProcessCommand();
void ServerReset();
// Reset the state of the SMTP server socket.
enum ForwardResult {
LocalDomain, ///< User may be on local machine, do LookUpName().
WillForward, ///< User may be forwarded to another SMTP host.
CannotForward ///< User cannot be forwarded.
};
// Result of forward check
/** Determine if a user for this domain may be on the local system, or
should be forwarded.
@return
Result of forward check operation.
*/
virtual ForwardResult ForwardDomain(
PCaselessString & userDomain, ///< Domain for user
PCaselessString & forwardDomainList ///< Domains forwarding to
);
enum LookUpResult {
ValidUser, ///< User name was valid and unique.
AmbiguousUser, ///< User name was valid but ambiguous.
UnknownUser, ///< User name was invalid.
LookUpError ///< Some other error occurred in look up.
};
// Result of user name look up
/** Look up a name in the context of the SMTP server.
The default bahaviour simply returns false.
@return
Result of name look up operation.
*/
virtual LookUpResult LookUpName(
const PCaselessString & name, ///< Name to look up.
PString & expandedName ///< Expanded form of name (if found).
);
/** Handle a received message. The <CODE>buffer</CODE> parameter contains
the partial or complete message received, depending on the
<CODE>completed</CODE> parameter.
The default behaviour is to simply return false;
@return
true if message was handled, false if an error occurs.
*/
virtual PBoolean HandleMessage(
PCharArray & buffer, ///< Buffer containing message data received.
PBoolean starting, ///< This is the first call for the message.
PBoolean completed ///< This is the last call for the message.
///< Indication that the entire message has been received.
);
protected:
PBoolean OnOpen();
virtual void OnHELO(
const PCaselessString & remoteHost ///< Name of remote host.
);
// Start connection.
virtual void OnEHLO(
const PCaselessString & remoteHost ///< Name of remote host.
);
// Start extended SMTP connection.
virtual void OnQUIT();
// close connection and die.
virtual void OnHELP();
// get help.
virtual void OnNOOP();
// do nothing
virtual void OnTURN();
// switch places
virtual void OnRSET();
// Reset state.
virtual void OnVRFY(
const PCaselessString & name ///< Name to verify.
);
// Verify address.
virtual void OnEXPN(
const PCaselessString & name ///< Name to expand.
);
// Expand alias.
virtual void OnRCPT(
const PCaselessString & recipient ///< Name of recipient.
);
// Designate recipient
virtual void OnMAIL(
const PCaselessString & sender ///< Name of sender.
);
// Designate sender
virtual void OnSEND(
const PCaselessString & sender ///< Name of sender.
);
// send message to screen
virtual void OnSAML(
const PCaselessString & sender ///< Name of sender.
);
// send AND mail
virtual void OnSOML(
const PCaselessString & sender ///< Name of sender.
);
// send OR mail
virtual void OnDATA();
// Message text.
/** Handle an unknown command.
@return
true if more processing may be done, false if the
<A>ProcessCommand()</A> function is to return false.
*/
virtual PBoolean OnUnknown(
const PCaselessString & command ///< Complete command line received.
);
virtual void OnSendMail(
const PCaselessString & sender ///< Name of sender.
);
// Common code for OnMAIL(), OnSEND(), OnSOML() and OnSAML() funtions.
/** Read a standard text message that is being received by the socket. The
text message is terminated by a line with a '.' character alone.
The default behaviour is to read the data into the <CODE>buffer</CODE>
parameter until either the end of the message or when the
<CODE>messageBufferSize</CODE> bytes have been read.
@return
true if partial message received, false if the end of the data was
received.
*/
virtual PBoolean OnTextData(PCharArray & buffer, PBoolean & completed);
/** Read an eight bit MIME message that is being received by the socket. The
MIME message is terminated by the CR/LF/./CR/LF sequence.
The default behaviour is to read the data into the <CODE>buffer</CODE>
parameter until either the end of the message or when the
<CODE>messageBufferSize</CODE> bytes have been read.
@return
true if partial message received, false if the end of the data was
received.
*/
virtual PBoolean OnMIMEData(PCharArray & buffer, PBoolean & completed);
// Member variables
PBoolean extendedHello;
PBoolean eightBitMIME;
PString fromAddress;
PString fromPath;
PStringList toNames;
PStringList toDomains;
PINDEX messageBufferSize;
enum { WasMAIL, WasSEND, WasSAML, WasSOML } sendCommand;
StuffState endMIMEDetectState;
};
//////////////////////////////////////////////////////////////////////////////
// PPOP3
/** A TCP/IP socket for the Post Office Protocol version 3.
When acting as a client, the procedure is to make the connection to a
remote server, then to retrieve a message using the following procedure:
<CODE>
PPOP3Client mail("popserver");
if (mail.IsOpen()) {
if (mail.LogIn("Me", "password")) {
if (mail.GetMessageCount() > 0) {
PUnsignedArray sizes = mail.GetMessageSizes();
for (PINDEX i = 0; i < sizes.GetSize(); i++) {
if (mail.BeginMessage(i+1))
mail.Read(myMessage, sizes[i]);
else
PError << "Error getting mail message." << endl;
}
}
else
PError << "No mail messages." << endl;
}
else
PError << "Mail log in failed." << endl;
}
else
PError << "Mail conection failed." << endl;
</CODE>
When acting as a server, a descendant class would be created to override
at least the <A>HandleOpenMailbox()</A>, <A>HandleSendMessage()</A> and
<A>HandleDeleteMessage()</A> functions. Other functions may be overridden
for further enhancement to the sockets capabilities, but these will give a
basic POP3 server functionality.
The server socket thread would continuously call the
<A>ProcessMessage()</A> function until it returns false. This will then
call the appropriate virtual function on parsing the POP3 protocol.
*/
class PPOP3 : public PInternetProtocol
{
PCLASSINFO(PPOP3, PInternetProtocol)
public:
enum Commands {
USER, PASS, QUIT, RSET, NOOP, STATcmd,
LIST, RETR, DELE, APOP, TOP, UIDL,
AUTH, NumCommands
};
protected:
PPOP3();
/** Parse a response line string into a response code and any extra info
on the line. Results are placed into the member variables
<CODE>lastResponseCode</CODE> and <CODE>lastResponseInfo</CODE>.
The default bahaviour looks for a space or a '-' and splits the code
and info either side of that character, then returns false.
@return
Position of continuation character in response, 0 if no continuation
lines are possible.
*/
virtual PINDEX ParseResponse(
const PString & line ///< Input response line to be parsed
);
// Member variables
static const PString & okResponse();
static const PString & errResponse();
};
/** A TCP/IP socket for the Post Office Protocol version 3.
When acting as a client, the procedure is to make the connection to a
remote server, then to retrieve a message using the following procedure:
<CODE>
PPOP3Client mail;
if (mail.Connect("popserver")) {
if (mail.LogIn("Me", "password")) {
if (mail.GetMessageCount() > 0) {
PUnsignedArray sizes = mail.GetMessageSizes();
for (PINDEX i = 0; i < sizes.GetSize(); i++) {
if (mail.BeginMessage(i+1))
mail.Read(myMessage, sizes[i]);
else
PError << "Error getting mail message." << endl;
}
}
else
PError << "No mail messages." << endl;
}
else
PError << "Mail log in failed." << endl;
}
else
PError << "Mail conection failed." << endl;
</CODE>
*/
class PPOP3Client : public PPOP3
{
PCLASSINFO(PPOP3Client, PPOP3)
public:
/** Create a TCP/IP POP3 protocol socket channel. The parameterless form
creates an unopened socket, the form with the <CODE>address</CODE>
parameter makes a connection to a remote system, opening the socket. The
form with the <CODE>socket</CODE> parameter opens the socket to an
incoming call from a "listening" socket.
*/
PPOP3Client();
/** Destroy the channel object. This will close the channel and as a
client, QUIT from remote POP3 server.
*/
~PPOP3Client();
// Overrides from class PChannel.
/** Close the socket, and if connected as a client, QUITs from server.
@return
true if the channel was closed and the QUIT accepted by the server.
*/
virtual PBoolean Close();
// New functions for class.
enum LoginOptions
{
AllowUserPass = 1, ///< Allow the use of the plain old USER/PASS if APOP
///< or SASL are not available
UseSASL = 2, ///< Use SASL if the AUTH command is supported by
///< the server
AllowClearTextSASL = 4 ///< Allow LOGIN and PLAIN mechanisms to be used
};
/** Log into the POP server using the mailbox and access codes specified.
@return
true if logged in.
*/
PBoolean LogIn(
const PString & username, ///< User name on remote system.
const PString & password, ///< Password for user name.
int options = AllowUserPass ///< See LoginOptions above
);
/** Get a count of the number of messages in the mail box.
@return
Number of messages in mailbox or -1 if an error occurred.
*/
int GetMessageCount();
/** Get an array of a integers representing the sizes of each of the
messages in the mail box.
@return
Array of integers representing the size of each message.
*/
PUnsignedArray GetMessageSizes();
/** Get an array of a strings representing the standard internet message
headers of each of the messages in the mail box.
Note that the remote server may not support this function, in which
case an empty array will be returned.
@return
Array of strings continaing message headers.
*/
PStringArray GetMessageHeaders();
/* Begin the retrieval of an entire message. The application may then use
the <A>PApplicationSocket::ReadLine()</A> function with the
<CODE>unstuffLine</CODE> parameter set to true. Repeated calls until
its return valus is false will read the message headers and body.
@return
Array of strings continaing message headers.
*/
PBoolean BeginMessage(
PINDEX messageNumber
/** Number of message to retrieve. This is an integer from 1 to the
maximum number of messages available.
*/
);
/** Delete the message specified from the mail box.
@return
Array of strings continaing message headers.
*/
PBoolean DeleteMessage(
PINDEX messageNumber
/* Number of message to retrieve. This is an integer from 1 to the
maximum number of messages available.
*/
);
protected:
PBoolean OnOpen();
// Member variables
PBoolean loggedIn;
PString apopBanner;
};
/** A TCP/IP socket for the Post Office Protocol version 3.
When acting as a server, a descendant class would be created to override
at least the <A>HandleOpenMailbox()</A>, <A>HandleSendMessage()</A> and
<A>HandleDeleteMessage()</A> functions. Other functions may be overridden
for further enhancement to the sockets capabilities, but these will give a
basic POP3 server functionality.
The server socket thread would continuously call the
<A>ProcessMessage()</A> function until it returns false. This will then
call the appropriate virtual function on parsing the POP3 protocol.
*/
class PPOP3Server : public PPOP3
{
PCLASSINFO(PPOP3Server, PPOP3)
public:
/** Create a TCP/IP POP3 protocol socket channel. The parameterless form
creates an unopened socket, the form with the <CODE>address</CODE>
parameter makes a connection to a remote system, opening the socket. The
form with the <CODE>socket</CODE> parameter opens the socket to an
incoming call from a "listening" socket.
*/
PPOP3Server();
// New functions for class.
/** Process commands, dispatching to the appropriate virtual function. This
is used when the socket is acting as a server.
@return
true if more processing may be done, false if the QUIT command was
received or the <A>OnUnknown()</A> function returns false.
*/
PBoolean ProcessCommand();
/** Log the specified user into the mail system and return sizes of each
message in mail box.
The user override of this function is expected to populate the protected
member fields <CODE>messageSizes</CODE> and <CODE>messageIDs</CODE>.
@return
true if user and password were valid.
*/
virtual PBoolean HandleOpenMailbox(
const PString & username, ///< User name for mail box
const PString & password ///< Password for user name
);
/** Handle the sending of the specified message to the remote client. The
data written to the socket will automatically have the '.' character
stuffing enabled.
@return
true if successfully sent message.
*/
virtual void HandleSendMessage(
PINDEX messageNumber, ///< Number of message to send.
const PString & id, ///< Unique id of message to send.
PINDEX lines ///< Nuumber of lines in body of message to send.
);
/** Handle the deleting of the specified message from the mail box. This is
called when the OnQUIT command is called for each message that was
deleted using the DELE command.
@return
true if successfully sent message.
*/
virtual void HandleDeleteMessage(
PINDEX messageNumber, ///< Number of message to send.
const PString & id ///< Unique id of message to send.
);
protected:
PBoolean OnOpen();
virtual void OnUSER(
const PString & name ///< Name of user.
);
// Specify user name (mailbox).
virtual void OnPASS(
const PString & passwd ///< Password for account.
);
// Specify password and log user in.
virtual void OnQUIT();
// End connection, saving all changes (delete messages).
virtual void OnRSET();
// Reset connection (undelete messages).
virtual void OnNOOP();
// Do nothing.
virtual void OnSTAT();
// Get number of messages in mailbox.
/** Get the size of a message in mailbox. If <CODE>msg</CODE> is 0 then get
sizes of all messages in mailbox.
*/
virtual void OnLIST(
PINDEX msg ///< Number of message.
);
virtual void OnRETR(
PINDEX msg ///< Number of message.
);
// Retrieve a message from mailbox.
virtual void OnDELE(
PINDEX msg ///< Number of message.
);
// Delete a message from mailbox.
virtual void OnTOP(
PINDEX msg, ///< Number of message.
PINDEX count ///< Count of messages
);
// Get the message header and top <CODE>count</CODE> lines of message.
/** Get unique ID for message in mailbox. If <CODE>msg</CODE> is 0 then get
all IDs for all messages in mailbox.
*/
virtual void OnUIDL(
PINDEX msg ///< Number of message.
);
/** Handle an unknown command.
@return
true if more processing may be done, false if the
<A>ProcessCommand()</A> function is to return false.
*/
virtual PBoolean OnUnknown(
const PCaselessString & command ///< Complete command line received.
);
// Member variables
PString username;
PUnsignedArray messageSizes;
PStringArray messageIDs;
PBYTEArray messageDeletions;
};
/**A channel for sending/receiving RFC822 compliant mail messages.
This encpsulates all that is required to send an RFC822 compliant message
via another channel. It automatically adds/strips header information from
the stream so the Read() and Write() functions only deal with the message
body.
For example to send a message using the SMTP classes:
<CODE>
PSMTPClient mail("mailserver");
if (mail.IsOpen()) {
PRFC822Channel message;
message.SetFromAddress("Me@here.com.au");
message.SetToAddress("Fred@somwhere.com");
if (message.Open(mail)) {
if (mail.BeginMessage("Me@here.com.au", "Fred@somwhere.com")) {
if (!message.Write(myMessageBody))
PError << "Mail write failed." << endl;
if (!message.EndMessage())
PError << "Mail send failed." << endl;
}
}
}
else
PError << "Mail conection failed." << endl;
</CODE>
*/
class PRFC822Channel : public PIndirectChannel
{
PCLASSINFO(PRFC822Channel, PIndirectChannel);
public:
enum Direction {
Sending,
Receiving
};
/**Construct a RFC822 aware channel.
*/
PRFC822Channel(
Direction direction ////< Indicates are sending or receiving a message
);
/**Close the channel before destruction.
*/
~PRFC822Channel();
// Overrides from class PChannel.
/**Close the channel.
This assures that all mime fields etc are closed off before closing
the underliying channel.
*/
PBoolean Close();
/** Low level write to the channel.
This override assures that the header is written before the body that
will be output via this function.
@return
true if at least len bytes were written to the channel.
*/
virtual PBoolean Write(
const void * buf, ///< Pointer to a block of memory to write.
PINDEX len ///< Number of bytes to write.
);
/**Begin a new message.
This may be used if the object is to encode 2 or more messages
sequentially. It resets the internal state of the object.
*/
void NewMessage(
Direction direction ///< Indicates are sending or receiving a message
);
/**Enter multipart MIME message mode.
This indicates that the message, or individual part within a message as
MIME is nestable, is a multipart message. This form returns the
boundary indicator string generated internally which must then be used
in all subsequent NextPart() calls.
Note this must be called before any writes are done to the message or
part.
*/
PString MultipartMessage();
/**Enter multipart MIME message mode.
This indicates that the message, or individual part within a message as
MIME is nestable, is a multipart message. In this form the user
supplies a boundary indicator string which must then be used in all
subsequent NextPart() calls.
Note this must be called before any writes are done to the message or
part.
*/
PBoolean MultipartMessage(
const PString & boundary
);
/**Indicate that a new multipart message part is to begin.
This will close off the previous part, and any nested multipart
messages contained therein, and allow a new part to begin.
The user may adjust the parts content type and other header fields
after this call and before the first write of the parts body. The
default Content-Type is "text/plain".
Note that all header fields are cleared from the previous part.
*/
void NextPart(
const PString & boundary
);
/**Set the sender address.
This must be called before any writes are done to the channel.
*/
void SetFromAddress(
const PString & fromAddress ///< Senders e-mail address
);
/**Set the recipient address(es).
This must be called before any writes are done to the channel.
*/
void SetToAddress(
const PString & toAddress ///< Recipients e-mail address (comma separated)
);
/**Set the Carbon Copy address(es).
This must be called before any writes are done to the channel.
*/
void SetCC(
const PString & ccAddress ///< Recipients e-mail address (comma separated)
);
/**Set the Blind Carbon Copy address(es).
This must be called before any writes are done to the channel.
*/
void SetBCC(
const PString & bccAddress ///< Recipients e-mail address (comma separated)
);
/**Set the message subject.
This must be called before any writes are done to the channel.
*/
void SetSubject(
const PString & subject ///< Subject string
);
/**Set the content type.
This must be called before any writes are done to the channel. It may
be set again immediately after any call to NextPart() when multipart
mime is being used.
The default Content-Type is "text/plain".
*/
void SetContentType(
const PString & contentType ///< Content type in form major/minor
);
/**Set the content disposition for attachments.
This must be called before any writes are done to the channel. It may
be set again immediately after any call to NextPart() when multipart
mime is being used.
Note that this will alter the Content-Type field to
*/
void SetContentAttachment(
const PFilePath & filename ///< Attachment filename
);
/**Set the content transfer encoding.
This must be called before any writes are done to the channel. It may
be set again immediately after any call to NextPart() when multipart
mime is being used.
If the encoding is "base64" (case insensitive) and , all writes will be
treated as binary and translated into base64 encoding before output to
the underlying channel.
*/
void SetTransferEncoding(
const PString & encoding, ///< Encoding type
PBoolean autoTranslate = true ///< Automatically convert to encoding type
);
/**Set the and arbitrary header field.
This must be called before any writes are done to the channel.
*/
void SetHeaderField(
const PString & name, ///< MIME fields tag
const PString & value ///< MIME fields contents
);
// Common MIME header tags
static const PCaselessString & MimeVersionTag();
static const PCaselessString & FromTag();
static const PCaselessString & ToTag();
static const PCaselessString & CCTag();
static const PCaselessString & BCCTag();
static const PCaselessString & SubjectTag();
static const PCaselessString & DateTag();
static const PCaselessString & ReturnPathTag();
static const PCaselessString & ReceivedTag();
static const PCaselessString & MessageIDTag();
static const PCaselessString & MailerTag();
static const PCaselessString & ContentTypeTag() { return PMIMEInfo::ContentTypeTag(); }
static const PCaselessString & ContentDispositionTag() { return PMIMEInfo::ContentDispositionTag(); }
static const PCaselessString & ContentTransferEncodingTag() { return PMIMEInfo::ContentTransferEncodingTag(); }
/**Send this message using an SMTP socket.
This will create a PSMTPClient and connect to the specified host then
send the message to the remote SMTP server.
*/
PBoolean SendWithSMTP(
const PString & hostname
);
/**Send this message using an SMTP socket.
This assumes PSMTPClient is open the sends the message to the remote
SMTP server.
*/
PBoolean SendWithSMTP(
PSMTPClient * smtp
);
protected:
PBoolean OnOpen();
PBoolean writeHeaders;
PMIMEInfo headers;
PBoolean writePartHeaders;
PMIMEInfo partHeaders;
PStringList boundaries;
PBase64 * base64;
};
#endif // PTLIB_INETMAIL_H
// End Of File ///////////////////////////////////////////////////////////////
|