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

com.sun.xml.messaging.saaj.packaging.mime.internet.MimePartDataSource Maven / Gradle / Ivy

Go to download

Open source Reference Implementation of JSR-67: SOAP with Attachments API for Java (SAAJ MR: 1.4)

There is a newer version: 3.0.4
Show newest version
/*
 * Copyright (c) 1997, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Distribution License v. 1.0, which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

/*
 * @(#)MimePartDataSource.java        1.9 02/03/27
 */


package com.sun.xml.messaging.saaj.packaging.mime.internet;

import com.sun.xml.messaging.saaj.packaging.mime.MessagingException;

import jakarta.activation.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.UnknownServiceException;

/**
 * A utility class that implements a DataSource out of
 * a MimeBodyPart. This class is primarily meant for service providers.
 *
 * @author John Mani
 */

public final class MimePartDataSource implements DataSource {
    private final MimeBodyPart part;

    /**
     * Constructor, that constructs a DataSource from a MimeBodyPart.
     *
     * @param part body part
     */
    public MimePartDataSource(MimeBodyPart part) {
        this.part = part;
    }

    /**
     * Returns an input stream from this  MimeBodyPart. 

* * This method applies the appropriate transfer-decoding, based * on the Content-Transfer-Encoding attribute of this MimeBodyPart. * Thus the returned input stream is a decoded stream of bytes.

* * This implementation obtains the raw content from the MimeBodyPart * using the getContentStream() method and decodes * it using the MimeUtility.decode() method. * * @return decoded input stream */ @Override public InputStream getInputStream() throws IOException { try { InputStream is = part.getContentStream(); String encoding = part.getEncoding(); if (encoding != null) return MimeUtility.decode(is, encoding); else return is; } catch (MessagingException mex) { throw new IOException(mex.getMessage()); } } /** * DataSource method to return an output stream.

* * This implementation throws the UnknownServiceException. */ @Override public OutputStream getOutputStream() throws IOException { throw new UnknownServiceException(); } /** * Returns the content-type of this DataSource.

* * This implementation just invokes the getContentType * method on the MimeBodyPart. */ @Override public String getContentType() { return part.getContentType(); } /** * DataSource method to return a name.

* * This implementation just returns an empty string. */ @Override public String getName() { try { return part.getFileName(); } catch (MessagingException mex) { return ""; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy