/****************************************************************
* Licensed to the Apache Software Foundation (ASF) under one *
* or more contributor license agreements. See the NOTICE file *
* distributed with this work for additional information *
* regarding copyright ownership. The ASF licenses this file *
* to you under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0 *
* *
* Unless required by applicable law or agreed to in writing, *
* software distributed under the License is distributed on an *
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY *
* KIND, either express or implied. See the License for the *
* specific language governing permissions and limitations *
* under the License. *
****************************************************************/
package org.apache.james.mime4j.message;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Stack;
import org.apache.james.mime4j.BodyDescriptor;
import org.apache.james.mime4j.ContentHandler;
import org.apache.james.mime4j.MimeStreamParser;
import org.apache.james.mime4j.decoder.Base64InputStream;
import org.apache.james.mime4j.decoder.QuotedPrintableInputStream;
import org.apache.james.mime4j.field.Field;
import org.apache.james.mime4j.field.UnstructuredField;
/**
* Represents a MIME message. The following code parses a stream into a
* Message
object.
*
*
* Message msg = new Message(new BufferedInputStream( * new FileInputStream("mime.msg"))); ** * * * @version $Id: Message.java,v 1.3 2004/10/02 12:41:11 ntherning Exp $ */ public class Message extends Entity implements Body { /** * Creates a new empty
Message
.
*/
public Message() {
}
/**
* Parses the specified MIME message stream into a Message
* instance.
*
* @param is the stream to parse.
* @throws IOException on I/O errors.
*/
public Message(InputStream is) throws IOException {
MimeStreamParser parser = new MimeStreamParser();
parser.setContentHandler(new MessageBuilder());
parser.parse(is);
}
/**
* Gets the Subject
field.
*
* @return the Subject
field or null
if it
* doesn't exist.
*/
public UnstructuredField getSubject() {
return (UnstructuredField) getHeader().getField(Field.SUBJECT);
}
/**
*
* @see org.apache.james.mime4j.message.Entity#writeTo(java.io.OutputStream)
*/
@Override
public void writeTo(OutputStream out) throws IOException {
getHeader().writeTo(out);
Body body = getBody();
if (body instanceof Multipart) {
Multipart mp = (Multipart) body;
mp.writeTo(out);
} else {
body.writeTo(out);
}
}
private class MessageBuilder implements ContentHandler {
private Stack