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

org.hibernate.type.descriptor.java.BlobTypeDescriptor Maven / Gradle / Ivy

There is a newer version: 7.0.0.Alpha1
Show newest version
/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2010, Red Hat Inc. or third-party contributors as
 * indicated by the @author tags or express copyright attribution
 * statements applied by the authors.  All third-party contributions are
 * distributed under license by Red Hat Inc.
 *
 * This copyrighted material is made available to anyone wishing to use, modify,
 * copy, or redistribute it subject to the terms and conditions of the GNU
 * Lesser General Public License, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this distribution; if not, write to:
 * Free Software Foundation, Inc.
 * 51 Franklin Street, Fifth Floor
 * Boston, MA  02110-1301  USA
 */
package org.hibernate.type.descriptor.java;

import java.io.IOException;
import java.io.InputStream;
import java.io.Serializable;
import java.sql.Blob;
import java.sql.SQLException;
import java.util.Comparator;

import org.hibernate.HibernateException;
import org.hibernate.engine.jdbc.BlobImplementer;
import org.hibernate.engine.jdbc.BlobProxy;
import org.hibernate.engine.jdbc.WrappedBlob;
import org.hibernate.engine.jdbc.BinaryStream;
import org.hibernate.engine.jdbc.internal.BinaryStreamImpl;
import org.hibernate.type.descriptor.WrapperOptions;

/**
 * Descriptor for {@link Blob} handling.
 * 

* Note, {@link Blob blobs} really are mutable (their internal state can in fact be mutated). We simply * treat them as immutable because we cannot properly check them for changes nor deep copy them. * * @author Steve Ebersole * @author Brett Meyer */ public class BlobTypeDescriptor extends AbstractTypeDescriptor { public static final BlobTypeDescriptor INSTANCE = new BlobTypeDescriptor(); public static class BlobMutabilityPlan implements MutabilityPlan { public static final BlobMutabilityPlan INSTANCE = new BlobMutabilityPlan(); public boolean isMutable() { return false; } public Blob deepCopy(Blob value) { return value; } public Serializable disassemble(Blob value) { throw new UnsupportedOperationException( "Blobs are not cacheable" ); } public Blob assemble(Serializable cached) { throw new UnsupportedOperationException( "Blobs are not cacheable" ); } } public BlobTypeDescriptor() { super( Blob.class, BlobMutabilityPlan.INSTANCE ); } /** * {@inheritDoc} */ public String toString(Blob value) { final byte[] bytes; try { bytes = DataHelper.extractBytes( value.getBinaryStream() ); } catch ( SQLException e ) { throw new HibernateException( "Unable to access blob stream", e ); } return PrimitiveByteArrayTypeDescriptor.INSTANCE.toString( bytes ); } /** * {@inheritDoc} */ public Blob fromString(String string) { return BlobProxy.generateProxy( PrimitiveByteArrayTypeDescriptor.INSTANCE.fromString( string ) ); } @Override @SuppressWarnings({ "unchecked" }) public Comparator getComparator() { return IncomparableComparator.INSTANCE; } @Override public int extractHashCode(Blob value) { return System.identityHashCode( value ); } @Override public boolean areEqual(Blob one, Blob another) { return one == another; } @SuppressWarnings({ "unchecked" }) public X unwrap(Blob value, Class type, WrapperOptions options) { if ( value == null ) { return null; } try { if ( BinaryStream.class.isAssignableFrom( type ) ) { if ( BlobImplementer.class.isInstance( value ) ) { // if the incoming Blob is a wrapper, just pass along its BinaryStream return (X) ( (BlobImplementer) value ).getUnderlyingStream(); } else { // otherwise we need to build a BinaryStream... return (X) new BinaryStreamImpl( DataHelper.extractBytes( value.getBinaryStream() ) ); } } else if ( byte[].class.isAssignableFrom( type )) { if ( BlobImplementer.class.isInstance( value ) ) { // if the incoming Blob is a wrapper, just grab the bytes from its BinaryStream return (X) ( (BlobImplementer) value ).getUnderlyingStream().getBytes(); } else { // otherwise extract the bytes from the stream manually return (X) DataHelper.extractBytes( value.getBinaryStream() ); } } else if (Blob.class.isAssignableFrom( type )) { final Blob blob = WrappedBlob.class.isInstance( value ) ? ( (WrappedBlob) value ).getWrappedBlob() : value; return (X) blob; } } catch ( SQLException e ) { throw new HibernateException( "Unable to access blob stream", e ); } throw unknownUnwrap( type ); } public Blob wrap(X value, WrapperOptions options) { if ( value == null ) { return null; } // Support multiple return types from // org.hibernate.type.descriptor.sql.BlobTypeDescriptor if ( Blob.class.isAssignableFrom( value.getClass() ) ) { return options.getLobCreator().wrap( (Blob) value ); } else if ( byte[].class.isAssignableFrom( value.getClass() ) ) { return options.getLobCreator().createBlob( ( byte[] ) value); } else if ( InputStream.class.isAssignableFrom( value.getClass() ) ) { InputStream inputStream = ( InputStream ) value; try { return options.getLobCreator().createBlob( inputStream, inputStream.available() ); } catch ( IOException e ) { throw unknownWrap( value.getClass() ); } } throw unknownWrap( value.getClass() ); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy