325N/A/*
325N/A * Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
325N/A * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
325N/A *
325N/A * This code is free software; you can redistribute it and/or modify it
325N/A * under the terms of the GNU General Public License version 2 only, as
325N/A * published by the Free Software Foundation. Oracle designates this
325N/A * particular file as subject to the "Classpath" exception as provided
325N/A * by Oracle in the LICENSE file that accompanied this code.
325N/A *
325N/A * This code is distributed in the hope that it will be useful, but WITHOUT
325N/A * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
325N/A * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
325N/A * version 2 for more details (a copy is included in the LICENSE file that
325N/A * accompanied this code).
325N/A *
325N/A * You should have received a copy of the GNU General Public License version
325N/A * 2 along with this work; if not, write to the Free Software Foundation,
325N/A * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
325N/A *
325N/A * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
325N/A * or visit www.oracle.com if you need additional information or have any
325N/A * questions.
325N/A */
325N/A
325N/Apackage com.sun.xml.internal.messaging.saaj.soap;
325N/A
325N/Aimport java.io.*;
325N/Aimport java.awt.datatransfer.DataFlavor;
325N/Aimport javax.activation.*;
325N/Aimport com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeMultipart;
325N/Aimport com.sun.xml.internal.messaging.saaj.packaging.mime.internet.ContentType;
325N/Aimport com.sun.xml.internal.messaging.saaj.util.ByteOutputStream;
325N/A
325N/Apublic class MultipartDataContentHandler implements DataContentHandler {
325N/A private ActivationDataFlavor myDF = new ActivationDataFlavor(
325N/A com.sun.xml.internal.messaging.saaj.packaging.mime.internet.MimeMultipart.class,
325N/A "multipart/mixed",
325N/A "Multipart");
325N/A
325N/A /**
325N/A * Return the DataFlavors for this <code>DataContentHandler</code>.
325N/A *
325N/A * @return The DataFlavors
325N/A */
325N/A public DataFlavor[] getTransferDataFlavors() { // throws Exception;
325N/A return new DataFlavor[] { myDF };
325N/A }
325N/A
325N/A /**
325N/A * Return the Transfer Data of type DataFlavor from InputStream.
325N/A *
325N/A * @param df The DataFlavor
325N/A * @param ins The InputStream corresponding to the data
325N/A * @return String object
325N/A */
325N/A public Object getTransferData(DataFlavor df, DataSource ds) {
325N/A // use myDF.equals to be sure to get ActivationDataFlavor.equals,
325N/A // which properly ignores Content-Type parameters in comparison
325N/A if (myDF.equals(df))
325N/A return getContent(ds);
325N/A else
325N/A return null;
325N/A }
325N/A
325N/A /**
325N/A * Return the content.
325N/A */
325N/A public Object getContent(DataSource ds) {
325N/A try {
325N/A return new MimeMultipart(
325N/A ds, new ContentType(ds.getContentType()));
325N/A } catch (Exception e) {
325N/A return null;
325N/A }
325N/A }
325N/A
325N/A /**
325N/A * Write the object to the output stream, using the specific MIME type.
325N/A */
325N/A public void writeTo(Object obj, String mimeType, OutputStream os)
325N/A throws IOException {
325N/A if (obj instanceof MimeMultipart) {
325N/A try {
325N/A //TODO: temporarily allow only ByteOutputStream
325N/A // Need to add writeTo(OutputStream) on MimeMultipart
325N/A ByteOutputStream baos = null;
325N/A if (os instanceof ByteOutputStream) {
325N/A baos = (ByteOutputStream)os;
325N/A } else {
325N/A throw new IOException("Input Stream expected to be a com.sun.xml.internal.messaging.saaj.util.ByteOutputStream, but found " +
325N/A os.getClass().getName());
325N/A }
325N/A ((MimeMultipart)obj).writeTo(baos);
325N/A } catch (Exception e) {
325N/A throw new IOException(e.toString());
325N/A }
325N/A }
325N/A }
325N/A}