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

org.apache.manifoldcf.crawler.interfaces.IRepositoryConnection Maven / Gradle / Ivy

/* $Id: IRepositoryConnection.java 988245 2010-08-23 18:39:35Z kwright $ */

/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.apache.manifoldcf.crawler.interfaces;

import org.apache.manifoldcf.core.interfaces.*;
import java.util.*;

/** An instance of this interface represents a paper object that describes a repository connection.
* This is the paper object meant for editing and manipulation.
*/
public interface IRepositoryConnection
{
  public static final String _rcsid = "@(#)$Id: IRepositoryConnection.java 988245 2010-08-23 18:39:35Z kwright $";

  /** Set 'isnew' condition.
  *@param isnew true if this is a new instance.
  */
  public void setIsNew(boolean isnew);
  
  /** Get 'isnew' condition.
  *@return true if this is a new connection, false otherwise.
  */
  public boolean getIsNew();

  /** Set name.
  *@param name is the name.
  */
  public void setName(String name);

  /** Get name.
  *@return the name
  */
  public String getName();

  /** Set description.
  *@param description is the description.
  */
  public void setDescription(String description);

  /** Get description.
  *@return the description
  */
  public String getDescription();

  /** Set the class name.
  *@param className is the class name.
  */
  public void setClassName(String className);

  /** Get the class name.
  *@return the class name
  */
  public String getClassName();

  /** Get the configuration parameters.
  *@return the map.  Can be modified.
  */
  public ConfigParams getConfigParams();

  /** Set the ACL authority name.
  *@param authorityName is the ACL authority name.
  */
  public void setACLAuthority(String authorityName);

  /** Get the ACL authority name.
  *@return the ACL authority name.
  */
  public String getACLAuthority();

  /** Set the maximum size of the connection pool.
  *@param maxCount is the maximum connection count per JVM.
  */
  public void setMaxConnections(int maxCount);

  /** Get the maximum size of the connection pool.
  *@return the maximum size.
  */
  public int getMaxConnections();

  // Connection throttle control

  /** Clear all throttle values. */
  public void clearThrottleValues();

  /** Add a throttle value.
  *@param description is the throttle description.
  *@param match is the regexp to be applied to the bin names.
  *@param throttle is the fetch rate to use, in fetches per millisecond.
  */
  public void addThrottleValue(String match, String description, float throttle);

  /** Delete a throttle.
  *@param match is the regexp describing the throttle to be removed.
  */
  public void deleteThrottleValue(String match);

  /** Get throttles.  This will return a list of match strings, ordered by description and then
  * match string.
  *@return the ordered list of throttles.
  */
  public String[] getThrottles();

  /** Get the description for a throttle.
  *@param match describes the throttle.
  *@return the description.
  */
  public String getThrottleDescription(String match);

  /** Get the throttle value for a throttle.
  *@param match describes the throttle.
  *@return the throttle value, in fetches per millisecond.
  */
  public float getThrottleValue(String match);

  /** Set the maximum number of document fetches per millisecond, for all bins (.*).
  *@param rate is the rate, in fetches/millisecond.
  */
  public void setThrottle(Float rate);

  /** Get the maximum number of document fetches per millisecond, for all bins (.*).
  *@return fetches/ms, or null if there is no such throttle.
  */
  public Float getThrottle();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy