1 package com.ozacc.mail.fetch;
\r
3 import javax.mail.internet.MimeMessage;
\r
5 import com.ozacc.mail.MailException;
\r
8 * メールサーバからメールを取得する上級インターフェース。<br>
\r
9 * このインターフェースの実装クラスでメールサーバの情報を設定します。
\r
11 * <code>FetchMail</code>インターフェースと異なり、メール取得時に例外が発生しても、
\r
12 * メールサーバとの接続は切断されません。<code>finally</code>ブロックを使用するなりして
\r
13 * メールサーバとの接続を確実に切断できるようにすることを推奨します。
\r
15 * このインターフェース実装クラスのインスタンスは、メールサーバとの接続を保持するため、
\r
16 * スレッドセーフではありません。<br>
\r
17 * DIコンテナでの使用の際はシングルトンでインスタンスを取得しないように注意してください。
\r
21 * @author Tomohiro Otsuka
\r
22 * @version $Id: FetchMailPro.java,v 1.1.2.7 2005/04/10 05:22:24 otsuka Exp $
\r
24 public interface FetchMailPro {
\r
27 * メールサーバに接続し、「INBOX」フォルダをオープンします。
\r
29 * @throws MailException メールサーバとの接続に失敗した場合
\r
31 void connect() throws MailException;
\r
34 * メールサーバとの接続を切断します。接続されていなければ何も行いません。
\r
36 * @throws MailException メールサーバとの接続切断に失敗した場合
\r
38 void disconnect() throws MailException;
\r
41 * 現在のフォルダに届いているメール数を返します。
\r
43 * @return 現在のフォルダにあるメール数
\r
44 * @throws MailException
\r
46 int getMailCount() throws MailException;
\r
49 * 現在のフォルダにある指定されたメッセージ番号のメールをReceivedMailに変換して返します。
\r
52 * メッセージはサーバから削除されません。
\r
54 * @param num メッセージ番号。1始まり。
\r
55 * @return 指定されたメッセージ番号のReceivedMailインスタンス
\r
56 * @throws MailException メール取得に失敗した場合
\r
58 ReceivedMail getMail(int num) throws MailException;
\r
61 * 現在のフォルダにある指定されたメッセージ番号のメールをReceivedMailに変換して返します。
\r
63 * 指定した番号のメッセージをサーバから削除するかどうかを指定できます。
\r
65 * @param num メッセージ番号。1始まり。
\r
66 * @param delete 指定された番号のメッセージをサーバから削除する場合 true を指定
\r
67 * @return 指定されたメッセージ番号のReceivedMailインスタンス
\r
68 * @throws MailException メール取得に失敗した場合
\r
70 ReceivedMail getMail(int num, boolean delete) throws MailException;
\r
73 * 現在のフォルダにある全メールをReceivedMailに変換して返します。
\r
75 * @param delete メール取得後にサーバからメールを削除する場合 true
\r
76 * @return 現在のフォルダにある全メールのReceivedMailインスタンス
\r
77 * @throws MailException メール取得に失敗した場合
\r
79 ReceivedMail[] getMails(boolean delete) throws MailException;
\r
82 * 現在のフォルダにある指定されたメッセージ番号のメールを返します。
\r
85 * @see javax.mail.Folder#getMessage(int)
\r
86 * @param num メッセージ番号。1始まり。
\r
87 * @return 指定された番号のMimeMessageインスタンス
\r
88 * @throws MailException メール取得に失敗した場合
\r
90 MimeMessage getMessage(int num) throws MailException;
\r
93 * 現在のフォルダにある全メールを返します。
\r
95 * @param delete メール取得後にサーバからメールを削除する場合 true
\r
96 * @return 現在のフォルダにある全メールのMimeMessageインスタンス
\r
97 * @throws MailException メール取得に失敗した場合
\r
99 MimeMessage[] getMessages(boolean delete) throws MailException;
\r
102 * 指定された名前のフォルダに移動します。
\r
103 * フォルダ名は"INBOX/XXXX"のように、INBOXからのパス指定します。
\r
105 * <strong>注:</strong> このメソッドは、メールサーバがimapサーバの時にのみ使用可能です。
\r
107 * @param folderName 移動先のフォルダ名
\r
108 * @throws MailException
\r
110 void changeFolder(String folderName) throws MailException;
\r
113 * メールサーバと接続しているかどうか判定します。
\r
115 * @return 接続している場合 true
\r
117 boolean isConnected();
\r