Class MultipartReport


public class MultipartReport extends MimeMultipart
A multipart/report message content, as defined in RFC 3462. A multipart/report content is a container for mail reports of any kind, and is most often used to return a delivery status report or a disposition notification report.

A MultipartReport object is a special type of MimeMultipart object with a restricted set of body parts. A MultipartReport object contains:

  • [Required] A human readable text message describing the reason the report was generated.
  • [Required] A Report object containing the details for why the report was generated.
  • [Optional] A returned copy of the entire message, or just its headers, which caused the generation of this report.
Many of the normal MimeMultipart operations are restricted to ensure that the MultipartReport object always follows this structure.
Since:
JavaMail 1.4
  • Field Details

    • constructed

      protected boolean constructed
  • Constructor Details

    • MultipartReport

      public MultipartReport() throws MessagingException
      Construct a multipart/report object with no content.
      Throws:
      MessagingException - for failures
    • MultipartReport

      public MultipartReport(String text, Report report) throws MessagingException
      Construct a multipart/report object with the specified plain text and report type (DeliveryStatus or DispositionNotification) to be returned to the user.
      Parameters:
      text - the plain text
      report - the Report object
      Throws:
      MessagingException - for failures
    • MultipartReport

      public MultipartReport(String text, Report report, MimeMessage msg) throws MessagingException
      Construct a multipart/report object with the specified plain text, report, and original message to be returned to the user.
      Parameters:
      text - the plain text
      report - the Report object
      msg - the message this report is about
      Throws:
      MessagingException - for failures
    • MultipartReport

      public MultipartReport(String text, Report report, InternetHeaders hdr) throws MessagingException
      Construct a multipart/report object with the specified plain text, report, and headers from the original message to be returned to the user.
      Parameters:
      text - the plain text
      report - the Report object
      hdr - the headers of the message this report is about
      Throws:
      MessagingException - for failures
    • MultipartReport

      public MultipartReport(jakarta.activation.DataSource ds) throws MessagingException
      Constructs a MultipartReport object and its bodyparts from the given DataSource.
      Parameters:
      ds - DataSource, can be a MultipartDataSource
      Throws:
      MessagingException - for failures
  • Method Details

    • getText

      public String getText() throws MessagingException
      Get the plain text to be presented to the user, if there is any. Rarely, the message may contain only HTML text, or no text at all. If the text body part of this multipart/report object is of type text/plain, or if it is of type multipart/alternative and contains a text/plain part, the text from that part is returned. Otherwise, null is return and the getTextBodyPart method may be used to extract the data.
      Returns:
      the text
      Throws:
      MessagingException - for failures
    • setText

      public void setText(String text) throws MessagingException
      Set the message to be presented to the user as just a text/plain part containing the specified text.
      Parameters:
      text - the text
      Throws:
      MessagingException - for failures
    • getTextBodyPart

      public MimeBodyPart getTextBodyPart() throws MessagingException
      Return the body part containing the message to be presented to the user, usually just a text/plain part.
      Returns:
      the body part containing the text
      Throws:
      MessagingException - for failures
    • setTextBodyPart

      public void setTextBodyPart(MimeBodyPart mbp) throws MessagingException
      Set the body part containing the text to be presented to the user. Usually this a text/plain part, but it might also be a text/html part or a multipart/alternative part containing text/plain and text/html parts. Any type is allowed here but these types are most common.
      Parameters:
      mbp - the body part containing the text
      Throws:
      MessagingException - for failures
    • getReport

      public Report getReport() throws MessagingException
      Get the report associated with this multipart/report.
      Returns:
      the Report object
      Throws:
      MessagingException - for failures
      Since:
      JavaMail 1.4.2
    • setReport

      public void setReport(Report report) throws MessagingException
      Set the report associated with this multipart/report.
      Parameters:
      report - the Report object
      Throws:
      MessagingException - for failures
      Since:
      JavaMail 1.4.2
    • getDeliveryStatus

      @Deprecated public DeliveryStatus getDeliveryStatus() throws MessagingException
      Deprecated.
      use getReport instead
      Get the delivery status associated with this multipart/report.
      Returns:
      the delivery status
      Throws:
      MessagingException - for failures
    • setDeliveryStatus

      public void setDeliveryStatus(DeliveryStatus status) throws MessagingException
      Deprecated.
      use setReport instead
      Set the delivery status associated with this multipart/report.
      Parameters:
      status - the deliver status
      Throws:
      MessagingException - for failures
    • getReturnedMessage

      public MimeMessage getReturnedMessage() throws MessagingException
      Get the original message that is being returned along with this multipart/report. If no original message is included, null is returned. In some cases only the headers of the original message will be returned as an object of type MessageHeaders.
      Returns:
      the returned message
      Throws:
      MessagingException - for failures
    • setReturnedMessage

      public void setReturnedMessage(MimeMessage msg) throws MessagingException
      Set the original message to be returned as part of the multipart/report. If msg is null, any previously set returned message or headers is removed.
      Parameters:
      msg - the returned message
      Throws:
      MessagingException - for failures
    • setSubType

      public void setSubType(String subtype) throws MessagingException
      Set the subtype. Throws MessagingException.
      Overrides:
      setSubType in class MimeMultipart
      Parameters:
      subtype - Subtype
      Throws:
      MessagingException - always; can't change subtype
    • removeBodyPart

      public boolean removeBodyPart(BodyPart part) throws MessagingException
      Remove the specified part from the multipart message. Not allowed on a multipart/report object.
      Overrides:
      removeBodyPart in class MimeMultipart
      Parameters:
      part - The part to remove
      Returns:
      true if part removed, false otherwise
      Throws:
      MessagingException - always
    • removeBodyPart

      public void removeBodyPart(int index) throws MessagingException
      Remove the part at specified location (starting from 0). Not allowed on a multipart/report object.
      Overrides:
      removeBodyPart in class MimeMultipart
      Parameters:
      index - Index of the part to remove
      Throws:
      MessagingException - always
    • addBodyPart

      public void addBodyPart(BodyPart part) throws MessagingException
      Adds a Part to the multipart. Not allowed on a multipart/report object.
      Overrides:
      addBodyPart in class MimeMultipart
      Parameters:
      part - The Part to be appended
      Throws:
      MessagingException - always
    • addBodyPart

      public void addBodyPart(BodyPart part, int index) throws MessagingException
      Adds a BodyPart at position index. Not allowed on a multipart/report object.
      Overrides:
      addBodyPart in class MimeMultipart
      Parameters:
      part - The BodyPart to be inserted
      index - Location where to insert the part
      Throws:
      MessagingException - always