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

org.teiid.infinispan.api.TeiidMarshallerProvider Maven / Gradle / Ivy

/*
 * Copyright Red Hat, Inc. and/or its affiliates
 * and other contributors as indicated by the @author tags and
 * the COPYRIGHT.txt file distributed with this work.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.teiid.infinispan.api;

import java.io.IOException;

import org.infinispan.protostream.BaseMarshaller;
import org.infinispan.protostream.ImmutableSerializationContext;
import org.infinispan.protostream.RawProtoStreamReader;
import org.infinispan.protostream.RawProtoStreamWriter;
import org.infinispan.protostream.RawProtobufMarshaller;
import org.infinispan.protostream.SerializationContext.MarshallerProvider;
import org.teiid.core.TeiidRuntimeException;
import org.teiid.metadata.RuntimeMetadata;
import org.teiid.metadata.Table;
import org.teiid.translator.TranslatorException;

import com.github.benmanes.caffeine.cache.Cache;
import com.github.benmanes.caffeine.cache.Caffeine;

public class TeiidMarshallerProvider implements MarshallerProvider {

    private Cache types =
            Caffeine.newBuilder().weakValues().build();
    private Cache> marshallers =
            Caffeine.newBuilder().weakKeys().build();

    private static ThreadLocal CURRENT_DOCUMENT = new ThreadLocal<>();

    @Override
    public RawProtobufMarshaller getMarshaller(String typeName) {
        Table table = types.getIfPresent(typeName);
        if (table == null) {
            return null;
        }
        RawProtobufMarshaller marshaller = marshallers.getIfPresent(table);
        if (marshaller == null) {
            return null;
        }
        return marshaller;
    }

    public static void setCurrentDocument(InfinispanDocument document) {
        CURRENT_DOCUMENT.set(document);
    }

    @Override
    public BaseMarshaller getMarshaller(Class javaClass) {
        InfinispanDocument current = CURRENT_DOCUMENT.get();
        if (current == null) {
            return null;
        }
        String type = current.getName();
        if (InfinispanDocument.class.isAssignableFrom(javaClass)) {
            return new RawProtobufMarshaller() {

                @Override
                public Class getJavaClass() {
                    return InfinispanDocument.class;
                }

                @Override
                public String getTypeName() {
                    return type;
                }

                @Override
                public InfinispanDocument readFrom(
                        ImmutableSerializationContext ctx,
                        RawProtoStreamReader in) throws IOException {
                    throw new AssertionError();
                }

                @Override
                public void writeTo(ImmutableSerializationContext ctx,
                        RawProtoStreamWriter out, InfinispanDocument t)
                        throws IOException {
                    RawProtobufMarshaller marshaller = getMarshaller(type);
                    if (marshaller == null) {
                        throw new IllegalStateException();
                    }
                    marshaller.writeTo(ctx, out, t);
                }
            };
        }
        return null;
    }

    public void registerMarshaller(Table table, RuntimeMetadata metadata) {
        marshallers.get(table, (t) -> {
            try {
                types.put(ProtobufMetadataProcessor.getMessageName(table), t);
                return MarshallerBuilder.getMarshaller(table, metadata);
            } catch (TranslatorException e) {
                throw new TeiidRuntimeException(e);
            }
        });
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy