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

com.github.lontime.shaded.org.redisson.codec.ReferenceCodecProvider Maven / Gradle / Ivy

The newest version!
/**
 * Copyright (c) 2013-2021 Nikita Koksharov
 *
 * 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 com.github.lontime.shaded.org.redisson.codec;

import com.github.lontime.shaded.org.redisson.client.codec.Codec;
import com.github.lontime.shaded.org.redisson.config.Config;
import com.github.lontime.shaded.org.redisson.api.RObject;
import com.github.lontime.shaded.org.redisson.api.annotation.REntity;
import com.github.lontime.shaded.org.redisson.api.annotation.RObjectField;

/**
 *
 * @author Rui Gu (https://github.com/jackygurui)
 */
public interface ReferenceCodecProvider {

    /**
     * Get codec instance by its class.
     * 
     * @param  the expected codec type.
     * @param codecClass the codec class used to lookup the codec.
     * @return the cached codec instance.
     */
     T getCodec(Class codecClass);
    
    /**
     * Get a codec instance by a REntity annotation and the class annotated with
     * it.
     * 
     * @param  the expected codec type.
     * @param anno REntity annotation used on the class.
     * @param cls The class that has the REntity annotation.
     * @param config Redisson config object
     * 
     * @return the cached codec instance.
     */
     T getCodec(REntity anno, Class cls, Config config);
    
    /**
     * Get a codec instance by a RObjectField annotation and the class annotated
     * with REntity, the implementation class of RObject the field is going to
     * be transformed into and the name of the field with this RObjectField 
     * annotation.
     * 
     * @param  the expected codec type.
     * @param  the type of the RObject.
     * @param anno RObjectField annotation used on the field.
     * @param cls The class that has the REntity annotation.
     * @param rObjectClass the implementation class of RObject the field is going
     * to be transformed into.
     * @param fieldName the name of the field with this RObjectField annotation.
     * @param config Redisson config object
     * 
     * @return the cached codec instance.
     */
     T getCodec(RObjectField anno, Class cls, Class rObjectClass, String fieldName, Config config);

    /**
     * Register a codec by its class or super class.
     * 
     * @param  the codec type to register.
     * @param codecClass the codec Class to register it can be a super class of 
     * the instance.
     * @param codec the codec instance.
     */
     void registerCodec(Class codecClass, T codec);
    
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy