All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.mail.imap.IMAPNestedMessage Maven / Gradle / Ivy

There is a newer version: 3.9
Show newest version
/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright 1997-2009 Sun Microsystems, Inc. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License. You can obtain
 * a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
 * or glassfish/bootstrap/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
 * Sun designates this particular file as subject to the "Classpath" exception
 * as provided by Sun in the GPL Version 2 section of the License file that
 * accompanied this code.  If applicable, add the following below the License
 * Header, with the fields enclosed by brackets [] replaced by your own
 * identifying information: "Portions Copyrighted [year]
 * [name of copyright owner]"
 *
 * Contributor(s):
 *
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */

package com.sun.mail.imap;

import java.io.*;
import javax.mail.*;
import com.sun.mail.imap.protocol.*;
import com.sun.mail.iap.ProtocolException;

/**
 * This class implements a nested IMAP message
 *
 * @author  John Mani
 */

public class IMAPNestedMessage extends IMAPMessage {
    private IMAPMessage msg; // the enclosure of this nested message

    /**
     * Package private constructor. 

* * Note that nested messages have no containing folder, nor * a message number. */ IMAPNestedMessage(IMAPMessage m, BODYSTRUCTURE b, ENVELOPE e, String sid) { super(m._getSession()); msg = m; bs = b; envelope = e; sectionId = sid; setPeek(m.getPeek()); } /* * Get the enclosing message's Protocol object. Overrides * IMAPMessage.getProtocol(). */ protected IMAPProtocol getProtocol() throws ProtocolException, FolderClosedException { return msg.getProtocol(); } /* * Is this an IMAP4 REV1 server? */ protected boolean isREV1() throws FolderClosedException { return msg.isREV1(); } /* * Get the enclosing message's messageCacheLock. Overrides * IMAPMessage.getMessageCacheLock(). */ protected Object getMessageCacheLock() { return msg.getMessageCacheLock(); } /* * Get the enclosing message's sequence number. Overrides * IMAPMessage.getSequenceNumber(). */ protected int getSequenceNumber() { return msg.getSequenceNumber(); } /* * Check whether the enclosing message is expunged. Overrides * IMAPMessage.checkExpunged(). */ protected void checkExpunged() throws MessageRemovedException { msg.checkExpunged(); } /* * Check whether the enclosing message is expunged. Overrides * Message.isExpunged(). */ public boolean isExpunged() { return msg.isExpunged(); } /* * Get the enclosing message's fetchBlockSize. */ protected int getFetchBlockSize() { return msg.getFetchBlockSize(); } /* * IMAPMessage uses RFC822.SIZE. We use the "size" field from * our BODYSTRUCTURE. */ public int getSize() throws MessagingException { return bs.size; } /* * Disallow setting flags on nested messages */ public synchronized void setFlags(Flags flag, boolean set) throws MessagingException { // Cannot set FLAGS on a nested IMAP message throw new MethodNotSupportedException( "Cannot set flags on this nested message"); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy