com.gemstone.gemfire.internal.cache.ClientSubscriptionConfigImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gemfire-core Show documentation
Show all versions of gemfire-core Show documentation
SnappyData store based off Pivotal GemFireXD
/*
* Copyright (c) 2010-2015 Pivotal Software, 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. See accompanying
* LICENSE file.
*/
/**
*
*/
package com.gemstone.gemfire.internal.cache;
import com.gemstone.gemfire.cache.server.ClientSubscriptionConfig;
import com.gemstone.gemfire.internal.i18n.LocalizedStrings;
/**
*
* Configuration parameters for client subscription
* @author aingle
*/
public class ClientSubscriptionConfigImpl implements ClientSubscriptionConfig {
/**
* To get client subscription
*/
public static final String CLIENT_SUBSCRIPTION = "client_subscription";
private int haQueueCapacity = 1;
private String haEvictionPolicy = null;
/**
* The name of the directory in which to store overflowed client queue entries
*/
private String overflowDirectory;
/**
* disk store name for overflow
*/
private String diskStoreName;
private boolean hasOverflowDirectory = false;
public ClientSubscriptionConfigImpl(){
this.haQueueCapacity = DEFAULT_CAPACITY;
this.haEvictionPolicy = DEFAULT_EVICTION_POLICY;
this.overflowDirectory = DEFAULT_OVERFLOW_DIRECTORY;
}
/**
* Returns the capacity of the client client queue.
* will be in MB for eviction-policy mem else
* number of entries
* @see #DEFAULT_CAPACITY
* @since 5.7
*/
public int getCapacity(){
return this.haQueueCapacity ;
}
/**
* Sets the capacity of the client client queue.
* will be in MB for eviction-policy mem else
* number of entries
* @see #DEFAULT_CAPACITY
* @since 5.7
*/
public void setCapacity(int capacity){
this.haQueueCapacity = capacity;
}
/**
* Returns the eviction policy that is executed when capacity of the client client queue is reached.
* @see #DEFAULT_EVICTION_POLICY
* @since 5.7
*/
public String getEvictionPolicy(){
return this.haEvictionPolicy ;
}
/**
* Sets the eviction policy that is executed when capacity of the client client queue is reached.
* @see #DEFAULT_EVICTION_POLICY
* @since 5.7
*/
public void setEvictionPolicy(String policy){
this.haEvictionPolicy = policy;
}
/**
* Sets the overflow directory for a client client queue
* @param overflowDirectory the overflow directory for a client queue's overflowed entries
* @since 5.7
* @deprecated as of prPersistSprint2
*/
@Deprecated
public void setOverflowDirectory(String overflowDirectory) {
if (this.getDiskStoreName() != null) {
throw new IllegalStateException(LocalizedStrings.DiskStore_Deprecated_API_0_Cannot_Mix_With_DiskStore_1
.toLocalizedString(new Object[] {"setOverflowDirectory", this.getDiskStoreName()}));
}
this.overflowDirectory = overflowDirectory;
setHasOverflowDirectory(true);
}
/**
* Answers the overflow directory for a client queue's
* overflowed client queue entries.
* @return the overflow directory for a client queue's
* overflowed entries
* @since 5.7
* @deprecated as of prPersistSprint2
*/
@Deprecated
public String getOverflowDirectory() {
if (this.getDiskStoreName() != null) {
throw new IllegalStateException(LocalizedStrings.DiskStore_Deprecated_API_0_Cannot_Mix_With_DiskStore_1
.toLocalizedString(new Object[] {"getOverflowDirectory", this.getDiskStoreName()}));
}
return this.overflowDirectory;
}
@Override
public String toString() {
String str = " Eviction policy "
+ this.getEvictionPolicy() + " capacity "
+ this.getCapacity();
if (diskStoreName == null) {
str += " Overflow Directory " + this.getOverflowDirectory();
} else {
str += " DiskStore Name: " + this.diskStoreName;
}
return str;
}
/**
* get the diskStoreName for overflow
* @since prPersistSprint2
*/
public String getDiskStoreName() {
return diskStoreName;
}
/**
* Sets the disk store name for overflow
* @param diskStoreName
* @since prPersistSprint2
*/
public void setDiskStoreName(String diskStoreName) {
if (hasOverflowDirectory()) {
throw new IllegalStateException(LocalizedStrings.DiskStore_Deprecated_API_0_Cannot_Mix_With_DiskStore_1
.toLocalizedString(new Object[] {"setDiskStoreName", this.getDiskStoreName()}));
}
this.diskStoreName = diskStoreName;
}
public boolean hasOverflowDirectory()
{
return this.hasOverflowDirectory;
}
private void setHasOverflowDirectory(boolean hasOverflowDirectory)
{
this.hasOverflowDirectory = hasOverflowDirectory;
}
/*public boolean equals(ClientSubscriptionConfig other) {
if (other != null && other.getEvictionPolicy() != null
&& other.getOverflowDirectory() != null) {
if ((this.getEvictionPolicy() == other.getEvictionPolicy())
&& (this.getOverflowDirectory() == other.getOverflowDirectory())
&& (this.getCapacity() == this.getCapacity()))
return true;
}
return false;
}*/
}