/******************************************************************************
* Product: Adempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* See the GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/
package org.adempiere.base;
/**
* Interface for dynamic discovery of services.
* This is the primary entry point for iDempiere service discovery.
*
* @author viola
*
*/
public interface IServiceLocator {
/**
* Locate matching service by type (order by service.ranking priority)
* @param type service interface
* @return holder for dynamic service
*/
IServiceHolder locate(Class type);
/**
* Locate matching service by type and query expression
* @param type
* @param query
* @return holder for service
*/
IServiceHolder locate(Class type, ServiceQuery query);
/**
* Locate matching service by component name and query expression
* @param type
* @param componentName service component name
* @param query
* @return holder for dynamic service
*/
IServiceHolder locate(Class type, String componentName, ServiceQuery query);
/**
* Find all matching services by type
* @param type
* @return holder for list of dynamic service
*/
IServicesHolder list(Class type);
/**
* Find all matching services by type and query expression
* @param type
* @param query
* @return holder for list of dynamic service
*/
IServicesHolder list(Class type, ServiceQuery query);
/**
* Find all matching services by component name and query expression
* @param type
* @param componentName osgi service component name
* @param query
* @return holder for list of dynamic service
*/
IServicesHolder list(Class type, String componentName, ServiceQuery query);
}