/* * Hibernate OGM, Domain model persistence for NoSQL datastores * * License: GNU Lesser General Public License (LGPL), version 2.1 or later * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.ogm.datastore.infinispan.persistencestrategy.table.externalizer.impl; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; import java.util.Collections; import java.util.Set; import org.hibernate.ogm.datastore.infinispan.InfinispanDialect; import org.hibernate.ogm.datastore.infinispan.impl.InfinispanEmbeddedDatastoreProvider; import org.hibernate.ogm.datastore.infinispan.persistencestrategy.common.externalizer.impl.ExternalizerIds; import org.hibernate.ogm.datastore.infinispan.persistencestrategy.common.externalizer.impl.VersionChecker; import org.hibernate.ogm.model.key.spi.EntityKey; import org.infinispan.commons.marshall.AdvancedExternalizer; /** * An externalizer for serializing and de-serializing {@link EntityKey} instances. Implicitly used by * {@link InfinispanDialect} which stores keys as is in the Infinispan data store. * <p> * This externalizer is automatically registered with the cache manager when starting the * {@link InfinispanEmbeddedDatastoreProvider}, so it's not required to configure the externalizer in the Infinispan * configuration file. * * @author Gunnar Morling */ // As an implementation of AdvancedExternalizer this is never serialized according to the Externalizer docs @SuppressWarnings("serial") public class PersistentEntityKeyExternalizer implements AdvancedExternalizer<PersistentEntityKey> { public static final PersistentEntityKeyExternalizer INSTANCE = new PersistentEntityKeyExternalizer(); /** * Format version of the key type; allows to apply version dependent deserialization logic in the future if * required; to be incremented when adding new fields to the serialized structure */ private static final int VERSION = 1; private static final Set<Class<? extends PersistentEntityKey>> TYPE_CLASSES = Collections .<Class<? extends PersistentEntityKey>>singleton( PersistentEntityKey.class ); private PersistentEntityKeyExternalizer() { } @Override public void writeObject(ObjectOutput output, PersistentEntityKey key) throws IOException { output.writeInt( VERSION ); output.writeObject( key.getColumnNames() ); output.writeObject( key.getColumnValues() ); } @Override public PersistentEntityKey readObject(ObjectInput input) throws IOException, ClassNotFoundException { VersionChecker.readAndCheckVersion( input, VERSION, PersistentEntityKey.class ); String[] columnNames = (String[]) input.readObject(); Object[] values = (Object[]) input.readObject(); return new PersistentEntityKey( columnNames, values ); } @Override public Set<Class<? extends PersistentEntityKey>> getTypeClasses() { return TYPE_CLASSES; } @Override public Integer getId() { return ExternalizerIds.PER_TABLE_ENTITY_KEY; } }