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

org.redisson.api.RLiveObjectService Maven / Gradle / Ivy

Go to download

Easy Redis Java client and Real-Time Data Platform. Valkey compatible. Sync/Async/RxJava3/Reactive API. Client side caching. Over 50 Redis based Java objects and services: JCache API, Apache Tomcat, Hibernate, Spring, Set, Multimap, SortedSet, Map, List, Queue, Deque, Semaphore, Lock, AtomicLong, Map Reduce, Bloom filter, Scheduler, RPC

There is a newer version: 3.40.2
Show newest version
/**
 * Copyright (c) 2013-2024 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 org.redisson.api;

import java.util.Collection;
import java.util.List;

import org.redisson.api.condition.Condition;
import org.redisson.api.condition.Conditions;

/**
 * The pre-registration of each entity class is not necessary.
 *
 * Entity's getters and setters operations gets redirected to Redis
 * automatically.
 *
 * @author Rui Gu (https://github.com/jackygurui)
 * @author Nikita Koksharov
 *
 */
public interface RLiveObjectService {

    /**
     * Finds the entity from Redis with the id.
     *
     * The entityClass should have a field annotated with RId, and the
     * entityClass itself should have REntity annotated. The type of the RId can
     * be anything except the followings:
     * 
    *
  1. An array i.e. byte[], int[], Integer[], etc.
  2. *
  3. or a RObject i.e. RedissonMap
  4. *
  5. or a Class with REntity annotation.
  6. *
* * * @param entityClass - entity class * @param id identifier * @param Entity type * @return a proxied object if it exists in redis, or null if not. */ T get(Class entityClass, Object id); /** * Finds the entities matches specified condition. *

* NOTE: open-source version is slow.
* Use Redisson PRO instead. *

* Usage example: *

     * Collection objects = liveObjectService.find(MyObject.class, Conditions.or(Conditions.in("field", "value1", "value2"), 
     *                          Conditions.and(Conditions.eq("field2", "value2"), Conditions.eq("field3", "value5"))));
     * 
* * @see Conditions * * @param Entity type * @param entityClass - entity class * @param condition - condition object * @return collection of live objects or empty collection. */ Collection find(Class entityClass, Condition condition); /** * Counts the entities matches specified condition. *

* NOTE: open-source version is slow.
* Use Redisson PRO instead. *

* Usage example: *

     * long objectsAmount = liveObjectService.count(MyObject.class, Conditions.or(Conditions.in("field", "value1", "value2"),
     *                          Conditions.and(Conditions.eq("field2", "value2"), Conditions.eq("field3", "value5"))));
     * 
* * @see Conditions * * @param entityClass - entity class * @param condition - condition object * @return amount of live objects. */ long count(Class entityClass, Condition condition); /** * Returns iterator for all entry ids by specified entityClass. * Ids traversed with SCAN operation. Each SCAN operation loads * up to count keys per request. * * @param entityClass - entity class * @param Key type * @return collection of ids or empty collection. */ Iterable findIds(Class entityClass); /** * Returns iterator for all entry ids by specified entityClass. * Ids traversed with SCAN operation. Each SCAN operation loads * up to count keys per request. * * @param entityClass - entity class * @param count - keys loaded per request to Redis * @param Key type * @return collection of ids or empty collection. */ Iterable findIds(Class entityClass, int count); /** * Returns proxied object for the detached object. Discard all the * field values already in the detached instance. * * The class representing this object should have a field annotated with * RId, and the object should hold a non null value in that field. * * If this object is not in redis then a new blank proxied instance * with the same RId field value will be created. * * @param Entity type * @param detachedObject - not proxied object * @return proxied object * @throws IllegalArgumentException if the object is is a RLiveObject instance. */ T attach(T detachedObject); /** * Returns proxied object for the detached object. Transfers all the * NON NULL field values to the redis server. It does not delete any * existing data in redis in case of the field value is null. * * The class representing this object should have a field annotated with * RId, and the object should hold a non null value in that field. * * If this object is not in redis then a new hash key will be created to * store it. Otherwise overrides current object state in Redis with the given object state. * * @param Entity type * @param detachedObject - not proxied object * @return proxied object * @throws IllegalArgumentException if the object is is a RLiveObject instance. */ T merge(T detachedObject); /** * Returns proxied object for the detached object. Transfers all the * NON NULL field values to the redis server. It does not delete any * existing data in redis in case of the field value is null. * * The class representing this object should have a field annotated with * RId, and the object should hold a non null value in that field. * * If this object is not in redis then a new hash key will be created to * store it. Otherwise overrides current object state in Redis with the given object state. * * @param Entity type * @param detachedObjects - not proxied objects * @return proxied object * @throws IllegalArgumentException if the object is is a RLiveObject instance. */ List merge(T... detachedObjects); /** * Returns proxied attached object for the detached object. Transfers all the * NON NULL field values to the redis server. Only when the it does * not already exist. * * @param Entity type * @param detachedObject - not proxied object * @return proxied object */ T persist(T detachedObject); /** * Returns proxied attached objects for the detached objects. Stores all the * NON NULL field values. *

* Executed in a batch mode. * * @param Entity type * @param detachedObjects - not proxied objects * @return list of proxied objects */ List persist(T... detachedObjects); /** * Returns unproxied detached object for the attached object. * * @param Entity type * @param attachedObject - proxied object * @return detachedObject object - not proxied object */ T detach(T attachedObject); /** * Deletes attached object including all nested objects. * * @param Entity type * @param attachedObject - proxied object */ void delete(T attachedObject); /** * Deletes object by class and ids including all nested objects. * * @param Entity type * @param entityClass - object class * @param ids - object ids * * @return amount of deleted objects */ long delete(Class entityClass, Object... ids); /** * To cast the instance to RLiveObject instance. * * @param type of instance * @param instance - live object * @return RLiveObject compatible object */ RLiveObject asLiveObject(T instance); /** * To cast the instance to RMap instance. * * @param type of instance * @param type of key * @param type of value * @param instance - live object * @return RMap compatible object */ RMap asRMap(T instance); /** * Returns true if the instance is a instance of RLiveObject. * * @param type of instance * @param instance - live object * @return true object is RLiveObject */ boolean isLiveObject(T instance); /** * Returns true if the RLiveObject already exists in redis. It will return false if * the passed object is not a RLiveObject. * * @param type of instance * @param instance - live object * @return true object exists */ boolean isExists(T instance); /** * Pre register the class with the service, registering all the classes on * startup can speed up the instance creation. This is NOT mandatory * since the class will also be registered lazily when it is first used. * * All classed registered with the service is stored in a class cache. * * The cache is independent between different RedissonClient instances. When * a class is registered in one RLiveObjectService instance it is also * accessible in another RLiveObjectService instance so long as they are * created by the same RedissonClient instance. * * @param cls - class */ void registerClass(Class cls); /** * Unregister the class with the service. This is useful after you decide * the class is no longer required. * * A class will be automatically unregistered if the service encountered any * errors during proxying or creating the object, since those errors are not * recoverable. * * All classed registered with the service is stored in a class cache. * * The cache is independent between different RedissonClient instances. When * a class is registered in one RLiveObjectService instance it is also * accessible in another RLiveObjectService instance so long as they are * created by the same RedissonClient instance. * * @param cls It can be either the proxied class or the unproxied conterpart. */ void unregisterClass(Class cls); /** * Check if the class is registered in the cache. * * All classed registered with the service is stored in a class cache. * * The cache is independent between different RedissonClient instances. When * a class is registered in one RLiveObjectService instance it is also * accessible in another RLiveObjectService instance so long as they are * created by the same RedissonClient instance. * * @param cls - type of instance * @return true if class already registered */ boolean isClassRegistered(Class cls); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy