source: trunk/LogicMail/src/org/logicprobe/LogicMail/message/Message.java @ 772

Revision 772, 3.9 KB checked in by octorian, 14 months ago (diff)

Tracking incomplete POP retrieval cases from fetch to cache.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1/*-
2 * Copyright (c) 2006, Derek Konigsberg
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * 1. Redistributions of source code must retain the above copyright
10 *    notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 *    notice, this list of conditions and the following disclaimer in the
13 *    documentation and/or other materials provided with the distribution.
14 * 3. Neither the name of the project nor the names of its
15 *    contributors may be used to endorse or promote products derived
16 *    from this software without specific prior written permission.
17 *
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
21 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
22 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
23 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
24 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
27 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
29 * OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32package org.logicprobe.LogicMail.message;
33
34import java.util.Enumeration;
35import java.util.Hashtable;
36
37/**
38 * This class encapsulates all the data to represent an E-Mail message.
39 * <p>
40 * It is intended for use as a short lived lightweight container for moving
41 * data between the protocol layer and the rest of the application.
42 * </p>
43 */
44public class Message {
45    private final MimeMessagePart structure;
46    private final Hashtable content = new Hashtable();
47    private final boolean complete;
48   
49    /**
50     * Creates a new instance of Message
51     * @param structure The structured message body tree
52     * @param true, if the message data is complete
53     */
54    public Message(MimeMessagePart structure, boolean complete) {
55        this.structure = structure;
56        this.complete = complete;
57    }
58   
59    /**
60     * Creates a new instance of Message
61     * @param structure The structured message body tree
62     */
63    public Message(MimeMessagePart structure) {
64        this(structure, true);
65    }
66   
67    /**
68     * Checks if the message complete flag was set.
69     * This should always be true, unless this message was created by parsing
70     * incomplete MIME source.
71     *
72     * @return true, if the message is complete
73     */
74    public boolean isComplete() {
75        return complete;
76    }
77   
78    /**
79     * Get the message body
80     * @return Body
81     */
82    public MimeMessagePart getStructure() {
83        return structure;
84    }
85   
86    public void putContent(MimeMessagePart mimeMessagePart, MimeMessageContent mimeMessageContent) {
87        content.put(mimeMessagePart, mimeMessageContent);
88    }
89   
90    public MimeMessageContent getContent(MimeMessagePart mimeMessagePart) {
91        return (MimeMessageContent)content.get(mimeMessagePart);
92    }
93   
94    public MimeMessageContent[] getAllContent() {
95                MimeMessageContent[] result = new MimeMessageContent[content.size()];
96                Enumeration e = content.keys();
97                int i = 0;
98        while(e.hasMoreElements()) {
99                result[i++] = (MimeMessageContent)content.get(e.nextElement());
100        }
101                return result;
102    }
103   
104    public Hashtable getContentMap() {
105        Hashtable result = new Hashtable();
106        Enumeration e = content.keys();
107        while(e.hasMoreElements()) {
108                MimeMessagePart part = (MimeMessagePart)e.nextElement();
109                result.put(part, content.get(part));
110        }
111        return result;
112    }
113}
Note: See TracBrowser for help on using the repository browser.