com.hazelcast.config.MapConfigReadOnly Maven / Gradle / Ivy
/*
* Copyright (c) 2008-2018, Hazelcast, Inc. All Rights Reserved.
*
* 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.hazelcast.config;
import com.hazelcast.map.eviction.MapEvictionPolicy;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* Contains the configuration for an {@link com.hazelcast.core.IMap} (read-only).
*
* @deprecated this class will be removed in 4.0; it is meant for internal usage only.
*/
public class MapConfigReadOnly extends MapConfig {
MapConfigReadOnly(MapConfig config) {
super(config);
}
@Override
public MaxSizeConfig getMaxSizeConfig() {
final MaxSizeConfig maxSizeConfig = super.getMaxSizeConfig();
if (maxSizeConfig == null) {
return null;
}
return maxSizeConfig.getAsReadOnly();
}
@Override
public WanReplicationRef getWanReplicationRef() {
final WanReplicationRef wanReplicationRef = super.getWanReplicationRef();
if (wanReplicationRef == null) {
return null;
}
return wanReplicationRef.getAsReadOnly();
}
@Override
public List getEntryListenerConfigs() {
final List listenerConfigs = super.getEntryListenerConfigs();
final List readOnlyListenerConfigs = new ArrayList(listenerConfigs.size());
for (EntryListenerConfig listenerConfig : listenerConfigs) {
readOnlyListenerConfigs.add(listenerConfig.getAsReadOnly());
}
return Collections.unmodifiableList(readOnlyListenerConfigs);
}
@Override
public List getPartitionLostListenerConfigs() {
final List listenerConfigs = super.getPartitionLostListenerConfigs();
final List readOnlyListenerConfigs =
new ArrayList(listenerConfigs.size());
for (MapPartitionLostListenerConfig listenerConfig : listenerConfigs) {
readOnlyListenerConfigs.add(listenerConfig.getAsReadOnly());
}
return Collections.unmodifiableList(readOnlyListenerConfigs);
}
@Override
public List getMapIndexConfigs() {
final List mapIndexConfigs = super.getMapIndexConfigs();
final List readOnlyMapIndexConfigs = new ArrayList(mapIndexConfigs.size());
for (MapIndexConfig mapIndexConfig : mapIndexConfigs) {
readOnlyMapIndexConfigs.add(mapIndexConfig.getAsReadOnly());
}
return Collections.unmodifiableList(readOnlyMapIndexConfigs);
}
@Override
public PartitioningStrategyConfig getPartitioningStrategyConfig() {
final PartitioningStrategyConfig partitioningStrategyConfig = super.getPartitioningStrategyConfig();
if (partitioningStrategyConfig == null) {
return null;
}
return partitioningStrategyConfig.getAsReadOnly();
}
@Override
public MapStoreConfig getMapStoreConfig() {
final MapStoreConfig mapStoreConfig = super.getMapStoreConfig();
if (mapStoreConfig == null) {
return null;
}
return mapStoreConfig.getAsReadOnly();
}
@Override
public NearCacheConfig getNearCacheConfig() {
final NearCacheConfig nearCacheConfig = super.getNearCacheConfig();
if (nearCacheConfig == null) {
return null;
}
return nearCacheConfig.getAsReadOnly();
}
@Override
public List getQueryCacheConfigs() {
List queryCacheConfigs = super.getQueryCacheConfigs();
List readOnlyOnes = new ArrayList(queryCacheConfigs.size());
for (QueryCacheConfig config : queryCacheConfigs) {
readOnlyOnes.add(config.getAsReadOnly());
}
return Collections.unmodifiableList(readOnlyOnes);
}
@Override
public MapConfig setHotRestartConfig(HotRestartConfig hotRestartConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setName(String name) {
throw throwReadOnly();
}
@Override
public MapConfig setInMemoryFormat(InMemoryFormat inMemoryFormat) {
throw throwReadOnly();
}
@Override
public MapConfig setBackupCount(int backupCount) {
throw throwReadOnly();
}
@Override
public MapConfig setAsyncBackupCount(int asyncBackupCount) {
throw throwReadOnly();
}
@Override
public MapConfig setEvictionPercentage(int evictionPercentage) {
throw throwReadOnly();
}
@Override
public MapConfig setMinEvictionCheckMillis(long checkIfEvictableAfterMillis) {
throw throwReadOnly();
}
@Override
public MapConfig setTimeToLiveSeconds(int timeToLiveSeconds) {
throw throwReadOnly();
}
@Override
public MapConfig setMaxIdleSeconds(int maxIdleSeconds) {
throw throwReadOnly();
}
@Override
public MapConfig setMaxSizeConfig(MaxSizeConfig maxSizeConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setEvictionPolicy(EvictionPolicy evictionPolicy) {
throw throwReadOnly();
}
@Override
public MapConfig setMapEvictionPolicy(MapEvictionPolicy mapEvictionPolicy) {
throw throwReadOnly();
}
@Override
public MapConfig setMapStoreConfig(MapStoreConfig mapStoreConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setNearCacheConfig(NearCacheConfig nearCacheConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setMergePolicy(String mergePolicy) {
throw throwReadOnly();
}
@Override
public MapConfig setMergePolicyConfig(MergePolicyConfig mergePolicyConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setStatisticsEnabled(boolean statisticsEnabled) {
throw throwReadOnly();
}
@Override
public MapConfig setReadBackupData(boolean readBackupData) {
throw throwReadOnly();
}
@Override
public MapConfig setWanReplicationRef(WanReplicationRef wanReplicationRef) {
throw throwReadOnly();
}
@Override
public MapConfig addEntryListenerConfig(EntryListenerConfig listenerConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setEntryListenerConfigs(List listenerConfigs) {
throw throwReadOnly();
}
@Override
public MapConfig addMapIndexConfig(MapIndexConfig mapIndexConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setMapIndexConfigs(List mapIndexConfigs) {
throw throwReadOnly();
}
@Override
public MapConfig setPartitioningStrategyConfig(PartitioningStrategyConfig partitioningStrategyConfig) {
throw throwReadOnly();
}
@Override
public MapConfig setOptimizeQueries(boolean optimizeQueries) {
throw throwReadOnly();
}
@Override
public MapConfig setPartitionLostListenerConfigs(List listenerConfigs) {
throw throwReadOnly();
}
@Override
public MapConfig setMapAttributeConfigs(List mapAttributeConfigs) {
throw throwReadOnly();
}
@Override
public void setQueryCacheConfigs(List queryCacheConfigs) {
throw throwReadOnly();
}
@Override
public MapConfig setCacheDeserializedValues(CacheDeserializedValues cacheDeserializedValues) {
throw throwReadOnly();
}
@Override
public MapConfig setQuorumName(String quorumName) {
throw throwReadOnly();
}
private UnsupportedOperationException throwReadOnly() {
throw new UnsupportedOperationException("This config is read-only");
}
}