/* * Copyright (c) 2017. Sunghyouk Bae <sunghyouk.bae@gmail.com> * 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.hibernate.cache.redis.hibernate52.strategy; import lombok.extern.slf4j.Slf4j; import org.hibernate.boot.spi.SessionFactoryOptions; import org.hibernate.cache.internal.DefaultCacheKeysFactory; import org.hibernate.cache.redis.hibernate52.regions.RedisNaturalIdRegion; import org.hibernate.cache.spi.NaturalIdRegion; import org.hibernate.cache.spi.access.NaturalIdRegionAccessStrategy; import org.hibernate.cache.spi.access.SoftLock; import org.hibernate.engine.spi.SharedSessionContractImplementor; import org.hibernate.persister.entity.EntityPersister; /** * Redis specific non-strict read/write NaturalId region access strategy * * @author sunghyouk.bae@gmail.com * @since 13. 4. 5. 오후 11:06 */ @Slf4j public class NonStrictReadWriteRedisNaturalIdRegionAccessStrategy extends AbstractRedisAccessStrategy<RedisNaturalIdRegion> implements NaturalIdRegionAccessStrategy { /** * Create a non-strict read/write access strategy accessing the given NaturalId region. */ public NonStrictReadWriteRedisNaturalIdRegionAccessStrategy(RedisNaturalIdRegion region, SessionFactoryOptions options) { super(region, options); } @Override public Object generateCacheKey(Object[] naturalIdValues, EntityPersister persister, SharedSessionContractImplementor session) { return DefaultCacheKeysFactory.INSTANCE.createNaturalIdKey(naturalIdValues, persister, session); } @Override public Object[] getNaturalIdValues(Object cacheKey) { return DefaultCacheKeysFactory.INSTANCE.getNaturalIdValues(cacheKey); } @Override public NaturalIdRegion getRegion() { return region; } @Override public Object get(SharedSessionContractImplementor session, Object key, long txTimestamp) { return region.get(key); } @Override public boolean putFromLoad(SharedSessionContractImplementor session, Object key, Object value, long txTimestamp, Object version, boolean minimalPutOverride) { if (minimalPutOverride && region.contains(key)) { return false; } region.put(key, value); return true; } @Override public boolean insert(SharedSessionContractImplementor session, Object key, Object value) { return false; } @Override public boolean afterInsert(SharedSessionContractImplementor session, Object key, Object value) { return false; } @Override public boolean update(SharedSessionContractImplementor session, Object key, Object value) { remove(session, key); return false; } @Override public boolean afterUpdate(SharedSessionContractImplementor session, Object key, Object value, SoftLock lock) { unlockItem(session, key, lock); return false; } }