com.sun.appserv.connectors.internal.api.ConnectorRuntime Maven / Gradle / Ivy
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 1997-2013 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package com.sun.appserv.connectors.internal.api;
import com.sun.appserv.connectors.internal.spi.ConnectorNamingEventListener;
import com.sun.enterprise.config.serverbeans.ResourcePool;
import com.sun.enterprise.deployment.ConnectorDescriptor;
import com.sun.enterprise.transaction.api.JavaEETransactionManager;
import org.glassfish.api.admin.ProcessEnvironment;
import org.glassfish.api.invocation.InvocationManager;
import org.glassfish.connectors.config.WorkSecurityMap;
import org.glassfish.resourcebase.resources.api.PoolInfo;
import org.glassfish.resourcebase.resources.api.ResourceInfo;
import org.jvnet.hk2.annotations.Contract;
import javax.naming.NamingException;
import javax.resource.ResourceException;
import javax.resource.spi.ManagedConnectionFactory;
import javax.resource.spi.ResourceAdapterAssociation;
import javax.security.auth.callback.CallbackHandler;
import java.util.Hashtable;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* This class is the entry point to connector backend module.
* It exposes different API's called by external entities like JPA, admin
* to perform various connector backend related operations.
* It delegates calls to various connetcor admin services and other
* connector services which actually implement the functionality.
* This is a delegating class.
*
* @author Binod P.G, Srikanth P, Aditya Gore, Jagadish Ramu
*/
@Contract
public interface ConnectorRuntime extends ConnectorConstants{
/**
* Creates Active resource Adapter which abstracts the rar module.
* During the creation of ActiveResourceAdapter, default pools and
* resources also are created.
*
* @param sourcePath Directory where rar module is exploded.
* @param moduleName Name of the module
* @param loader Classloader used to load the .rar
* @throws ConnectorRuntimeException if creation fails.
*/
public void createActiveResourceAdapter(String sourcePath, String moduleName, ClassLoader loader)
throws ConnectorRuntimeException;
/**
* Creates Active resource Adapter which abstracts the rar module.
* During the creation of ActiveResourceAdapter, default pools and
* resources also are created.
*
* @param moduleName Name of the module
* @throws ConnectorRuntimeException if creation fails.
*/
public void createActiveResourceAdapterForEmbeddedRar(String moduleName) throws ConnectorRuntimeException;
/**
* Destroys/deletes the Active resource adapter object from the
* connector container. Active resource adapter abstracts the rar
* deployed.
*
* @param moduleName Name of the rarModule to destroy/delete
* @throws ConnectorRuntimeException if the deletion fails
*/
public void destroyActiveResourceAdapter(String moduleName) throws ConnectorRuntimeException;
/**
* Shut down all pools and active resource-adapters
*/
public void cleanUpResourcesAndShutdownAllActiveRAs();
/**
* Shut down all active resource adapters
*/
public void shutdownAllActiveResourceAdapters();
/**
* Given the module directory, creates a connector-class-finder (class-loader) for the module
* @param moduleDirectory rar module directory for which classloader is needed
* @param parent parent classloader
* For standalone rars, pass null, as the parent should be common-class-loader
* that will be automatically taken care by ConnectorClassLoaderService.
* For embedded rars, parent is necessary
* @return classloader created for the module
* @throws ConnectorRuntimeException when unable to create classloader
*/
public ClassLoader createConnectorClassLoader(String moduleDirectory, ClassLoader parent, String rarModuleName)
throws ConnectorRuntimeException;
/**
* Does lookup of non-tx-datasource. If found, it will be returned.
*
* If not found and force is true, this api will try to get a wrapper datasource specified
* by the jdbcjndi name. The motivation for having this
* API is to provide the CMP backend/ JPA-Java2DB a means of acquiring a connection during
* the codegen phase. If a user is trying to deploy an JPA-Java2DB app on a remote server,
* without this API, a resource reference has to be present both in the DAS
* and the server instance. This makes the deployment more complex for the
* user since a resource needs to be forcibly created in the DAS Too.
* This API will mitigate this need.
*
* @param jndiName jndi name of the resource
* @param force provide the resource (in DAS) even if it is not enabled in DAS
* @return DataSource representing the resource.
* @throws javax.naming.NamingException when not able to get the datasource.
*/
public Object lookupNonTxResource(String jndiName, boolean force) throws NamingException;
/**
* Does lookup of "__pm" datasource. If found, it will be returned.
*
* If not found and force is true, this api will try to get a wrapper datasource specified
* by the jdbcjndi name. The motivation for having this
* API is to provide the CMP backend/ JPA-Java2DB a means of acquiring a connection during
* the codegen phase. If a user is trying to deploy an JPA-Java2DB app on a remote server,
* without this API, a resource reference has to be present both in the DAS
* and the server instance. This makes the deployment more complex for the
* user since a resource needs to be forcibly created in the DAS Too.
* This API will mitigate this need.
* When the resource is not enabled, datasource wrapper provided will not be of
* type "__pm"
*
* @param jndiName jndi name of the resource
* @param force provide the resource (in DAS) even if it is not enabled in DAS
* @return DataSource representing the resource.
* @throws javax.naming.NamingException when not able to get the datasource.
*/
public Object lookupPMResource(String jndiName, boolean force) throws NamingException;
/**
* Does lookup of non-tx-datasource. If found, it will be returned.
*
* If not found and force is true, this api will try to get a wrapper datasource specified
* by the jdbcjndi name. The motivation for having this
* API is to provide the CMP backend/ JPA-Java2DB a means of acquiring a connection during
* the codegen phase. If a user is trying to deploy an JPA-Java2DB app on a remote server,
* without this API, a resource reference has to be present both in the DAS
* and the server instance. This makes the deployment more complex for the
* user since a resource needs to be forcibly created in the DAS Too.
* This API will mitigate this need.
*
* @param resourceInfo jndi name of the resource
* @param force provide the resource (in DAS) even if it is not enabled in DAS
* @return DataSource representing the resource.
* @throws javax.naming.NamingException when not able to get the datasource.
*/
public Object lookupNonTxResource(ResourceInfo resourceInfo, boolean force) throws NamingException;
/**
* Does lookup of "__pm" datasource. If found, it will be returned.
*
* If not found and force is true, this api will try to get a wrapper datasource specified
* by the jdbcjndi name. The motivation for having this
* API is to provide the CMP backend/ JPA-Java2DB a means of acquiring a connection during
* the codegen phase. If a user is trying to deploy an JPA-Java2DB app on a remote server,
* without this API, a resource reference has to be present both in the DAS
* and the server instance. This makes the deployment more complex for the
* user since a resource needs to be forcibly created in the DAS Too.
* This API will mitigate this need.
* When the resource is not enabled, datasource wrapper provided will not be of
* type "__pm"
*
* @param resourceInfo jndi name of the resource
* @param force provide the resource (in DAS) even if it is not enabled in DAS
* @return DataSource representing the resource.
* @throws javax.naming.NamingException when not able to get the datasource.
*/
public Object lookupPMResource(ResourceInfo resourceInfo, boolean force) throws NamingException;
/**
* register the connector naming event listener
* @param listener connector-naming-event-listener
*/
public void registerConnectorNamingEventListener(ConnectorNamingEventListener listener);
/**
* unregister the connector naming event listner
* @param listener connector-naming-event-listener
*/
public void unregisterConnectorNamingEventListener(ConnectorNamingEventListener listener);
/**
* Provide the configuration of the pool
* @param PoolInfo connection pool info
* @return ResourcePool connection pool configuration
*/
public ResourcePool getConnectionPoolConfig(PoolInfo poolInfo);
/**
* Tests whether the configuration for the pool is valid by making a connection.
* @param PoolInfo connection pool info.
* @return boolean indicating ping status
* @throws ResourceException when unable to ping
*/
public boolean pingConnectionPool(PoolInfo poolInfo) throws ResourceException;
/**
* provides the transactionManager
*
* @return TransactionManager
*/
public JavaEETransactionManager getTransactionManager();
/**
* provides the invocationManager
*
* @return InvocationManager
*/
public InvocationManager getInvocationManager();
/**
* get resource reference descriptors from current component's jndi environment
* @return set of resource-refs
*/
public Set getResourceReferenceDescriptor();
/** Returns the MCF instance. If the MCF is already created and
* present in connectorRegistry that instance is returned. Otherwise it
* is created explicitly and added to ConnectorRegistry.
* @param PoolInfo Name of the pool.MCF pertaining to this pool is
* created/returned.
* @return created/already present MCF instance
* @throws ConnectorRuntimeException if creation/retrieval of MCF fails
*/
public ManagedConnectionFactory obtainManagedConnectionFactory( PoolInfo poolInfo)
throws ConnectorRuntimeException ;
/**
* provide the MCF of the pool (either retrieve or create)
* @param poolName connection pool name
* @param env Environment entries to use for lookup
* @return ManagedConnectionFactory mcf of the pool
* @throws ConnectorRuntimeException when unable to provide the MCF
*/
public ManagedConnectionFactory obtainManagedConnectionFactory(PoolInfo poolInfo, Hashtable env)
throws ConnectorRuntimeException;
/**
* Indicates whether the execution environment is server or client
* @return ConnectorConstants.SERVER or ConnectorConstants.CLIENT
*/
public ProcessEnvironment.ProcessType getEnvironment();
/**
* provides container's (application server's) callback handler
* @return container callback handler
*/
public CallbackHandler getCallbackHandler();
/**
* Checks whether the executing environment is application server
* @return true if execution environment is server
* false if it is not server
*/
boolean isServer();
/**
* Checks whether the executing environment is embedded runtime
* @return true if execution environment is embedded mode
* false if it non-embedded
*/
boolean isEmbedded() ;
/**
* Initializes the execution environment. If the execution environment
* is appserv runtime it is set to ConnectorConstants.SERVER else
* it is set ConnectorConstants.CLIENT
*
* @param environment set to ConnectorConstants.SERVER if execution
* environment is appserv runtime else set to
* ConnectorConstants.CLIENT
*/
/*
void initialize(int environment);
*/
/**
* provides connector class loader
* @return ClassLoader
*/
ClassLoader getConnectorClassLoader();
/**
* Gets the properties of the Java bean connection definition class that
* have setter methods defined and the default values as provided by the
* Connection Definition java bean developer.
* This method is used to get properties of jdbc-data-source
* To get Connection definition properties for Connector Connection Pool,
* use ConnectorRuntime.getMCFConfigProperties()
* When the connection definition class is not found, standard JDBC
* properties (of JDBC 3.0 Specification) will be returned.
*
* @param connectionDefinitionClassName
* The Connection Definition Java bean class for which
* overrideable properties are required.
* @param resType resource-type
* @return Map String represents property name
* and Object is the defaultValue that is a primitive type or String
*/
public Map getConnectionDefinitionPropertiesAndDefaults(String connectionDefinitionClassName,
String resType);
/**
* Provides the list of built in custom resources by
* resource-type and factory-class-name pair.
* @return map of resource-type & factory-class-name
*/
public Map getBuiltInCustomResources();
/**
* Returns the system RAR names that allow pool creation
* @return String array representing list of system-rars
*/
public String[] getSystemConnectorsAllowingPoolCreation();
/** Obtains all the Connection definition names of a rar
* @param rarName rar moduleName
* @return Array of connection definition names.
* @throws ConnectorRuntimeException when unable to obtain connection definition from descriptor.
*/
public String[] getConnectionDefinitionNames(String rarName)
throws ConnectorRuntimeException ;
/**
* Obtains the Permission string that needs to be added to the
* to the security policy files. These are the security permissions needed
* by the resource adapter implementation classes.
* These strings are obtained by parsing the ra.xml and by processing annotations if any
* @param moduleName rar module Name
* @throws ConnectorRuntimeException If rar.xml parsing or annotation processing fails.
* @return security permission spec
*/
public String getSecurityPermissionSpec(String moduleName)
throws ConnectorRuntimeException ;
/**
* Obtains all the Admin object interface names of a rar
* @param rarName rar moduleName
* @return Array of admin object interface names.
* @throws ConnectorRuntimeException when unable to obtain admin object interface names
*/
public String[] getAdminObjectInterfaceNames(String rarName)
throws ConnectorRuntimeException ;
/**
* Obtains all the Admin object implementation class names of the admin-object-interface for a rar
* @param rarName rar moduleName
* @param intfName admin-object-interface-name
* @return Array of admin object interface names.
* @throws ConnectorRuntimeException when unable to obtain admin object interface names
*/
public String[] getAdminObjectClassNames(String rarName, String intfName)
throws ConnectorRuntimeException;
/**
* checks whether the specified intfName, className has presence in
* admin objects of the RAR
* @param rarName resource-adapter name
* @param intfName admin object interface name
* @param className admin object class name
* @return boolean indicating the presence of admin object
* @throws ConnectorRuntimeException when unable to determine the presence
*/
public boolean hasAdminObject(String rarName, String intfName, String className)
throws ConnectorRuntimeException;
/**
* Retrieves the Resource adapter javabean properties with default values.
* The default values will the values present in the ra.xml. If the
* value is not present in ra.xxml, javabean is introspected to obtain
* the default value present, if any. If intrspection fails or null is the
* default value, empty string is returned.
* If ra.xml has only the property and no value, empty string is the value
* returned.
* If the Resource Adapter Java bean is annotated, properties will be the result of merging
* annotated config property and config-property of Resource Adapter bean in ra.xml
* @param rarName rar module name
* @return Resource adapter javabean properties with default values.
* @throws ConnectorRuntimeException if property retrieval fails.
*/
public Map getResourceAdapterConfigProps(String rarName)
throws ConnectorRuntimeException ;
/**
* Retrieves the MCF javabean properties with default values.
* The default values will the values present in the ra.xml. If the
* value is not present in ra.xxml, javabean is introspected to obtain
* the default value present, if any. If intrspection fails or null is the
* default value, empty string is returned.
* If ra.xml has only the property and no value, empty string is the value
* returned.
* If the ManagedConnectionFactory Java bean is annotated, properties will be the result of merging
* annotated config property and config-property of MCF in ra.xml
* @param rarName rar module name
* @param connectionDefName connection-definition-name
* @return managed connection factory javabean properties with
* default values.
* @throws ConnectorRuntimeException if property retrieval fails.
*/
public Map getMCFConfigProps(
String rarName,String connectionDefName) throws ConnectorRuntimeException ;
/**
* Retrieves the admin object javabean properties with default values.
* The default values will the values present in the ra.xml. If the
* value is not present in ra.xxml, javabean is introspected to obtain
* the default value present, if any. If intrspection fails or null is the
* default value, empty string is returned.
* If ra.xml has only the property and no value, empty string is the value
* returned.
* If the AdministeredObject Java bean is annotated, properties will be the result of merging
* annotated config property and config-property of AdministeredObject in ra.xml
* @param rarName rar module name
* @param adminObjectIntf admin-object-interface name
* @return admin object javabean properties with
* default values.
* @throws ConnectorRuntimeException if property retrieval fails.
*/
public Map getAdminObjectConfigProps(
String rarName,String adminObjectIntf) throws ConnectorRuntimeException ;
/**
* Retrieves the admin object javabean properties with default values.
* The default values will the values present in the ra.xml. If the
* value is not present in ra.xxml, javabean is introspected to obtain
* the default value present, if any. If intrspection fails or null is the
* default value, empty string is returned.
* If ra.xml has only the property and no value, empty string is the value
* returned.
* If the AdministeredObject Java bean is annotated, properties will be the result of merging
* annotated config property and config-property of AdministeredObject in ra.xml
* @param rarName rar module name
* @param adminObjectIntf admin-object-interface name
* @param adminObjectClass admin-object-class name
* @return admin object javabean properties with
* default values.
* @throws ConnectorRuntimeException if property retrieval fails.
*/
public Map getAdminObjectConfigProps(
String rarName,String adminObjectIntf, String adminObjectClass) throws ConnectorRuntimeException ;
/**
* Retrieves the XXX javabean properties with default values.
* The javabean to introspect/retrieve is specified by the type.
* The default values will be the values present in the ra.xml. If the
* value is not present in ra.xxml, javabean is introspected to obtain
* the default value present, if any. If intrspection fails or null is the
* default value, empty string is returned.
* If ra.xml has only the property and no value, empty string is the value
* returned.
* @param rarName rar module name
* @param connectionDefName connection definition name
* @param type JavaBean type to introspect
* @return admin object javabean properties with
* default values.
* @throws ConnectorRuntimeException if property retrieval fails.
*/
public Map getConnectorConfigJavaBeans(String rarName,
String connectionDefName,String type) throws ConnectorRuntimeException ;
/**
* Return the ActivationSpecClass name for given rar and messageListenerType
* @param rarName name of the rar module
* @param messageListenerType MessageListener type
* @throws ConnectorRuntimeException If moduleDir is null.
* If corresponding rar is not deployed.
* @return activation-spec class
*/
public String getActivationSpecClass( String rarName,
String messageListenerType) throws ConnectorRuntimeException ;
/**
* Parses the ra.xml, processes the annotated rar artificats if any
* and returns all the Message listener types.
*
* @param rarName name of the rar module.
* @return Array of message listener types as strings.
* @throws ConnectorRuntimeException If moduleDir is null.
* If corresponding rar is not deployed.
*
*/
public String[] getMessageListenerTypes(String rarName)
throws ConnectorRuntimeException ;
/** Parses the ra.xml for the ActivationSpec javabean
* properties and processes annotations if any. The ActivationSpec to be parsed is
* identified by the moduleDir where ra.xml is present and the
* message listener type.
*
* message listener type will be unique in a given ra.xml.
*
* It throws ConnectorRuntimeException if either or both the
* parameters are null, if corresponding rar is not deployed,
* if message listener type mentioned as parameter is not found in ra.xml.
* If rar is deployed and message listener (type mentioned) is present
* but no properties are present for the corresponding message listener,
* null is returned.
*
* @param rarName name of the rar module.
* @param messageListenerType message listener type.It is uniqie
* across all sub-elements in
* element in a given rar.
* @return Javabean properties with the property names and values
* of properties. The property values will be the values
* mentioned in ra.xml if present. Otherwise it will be the
* default values obtained by introspecting the javabean.
* In both the case if no value is present, empty String is
* returned as the value.
* @throws ConnectorRuntimeException if either of the parameters are null.
* If corresponding rar is not deployed i.e moduleDir is invalid.
* If messagelistener type is not found in ra.xml or could not be
* found in annotations if any
*/
public Map getMessageListenerConfigProps(String rarName,
String messageListenerType)throws ConnectorRuntimeException ;
/** Returns the Properties object consisting of propertyname as the
* key and datatype as the value.
* @param rarName name of the rar module.
* @param messageListenerType message listener type.It is uniqie
* across all sub-elements in
* element in a given rar.
* @return Properties object with the property names(key) and datatype
* of property(as value).
* @throws ConnectorRuntimeException if either of the parameters are null.
* If corresponding rar is not deployed i.e moduleDir is invalid.
* If messagelistener type is not found in ra.xmlor could not be found
* in annotations if any
*/
public Map getMessageListenerConfigPropTypes(String rarName,
String messageListenerType) throws ConnectorRuntimeException ;
/**
* get work security maps for a resource-adapter-name
* @param raName resource-adapter name
* @return all work security maps of a resource-adapter
*/
public List getWorkSecurityMap(String raName);
/**
* Used to register data-source-definitions at an earlier stage of deployment (prepare phase).
* This is used to register "java:global" and "java:app" scoped DataSourceDefinitions
* which can be referred by JPA in persistence.xml
* @param application Application being deployed.
*/
public void registerDataSourceDefinitions(com.sun.enterprise.deployment.Application application);
/**
* Used to unRegister data-source-definitions at an later stage of undeploy operation.
* This is used to unRegister "java:global" and "java:app" scoped DataSourceDefinitions
* which can be referred by JPA in persistence.xml
* @param application Application being undeployed.
*/
public void unRegisterDataSourceDefinitions(com.sun.enterprise.deployment.Application application);
/**
* Flush Connection pool by reinitializing the connections
* established in the pool.
* @param PoolInfo connection pool info
* @throws ConnectorRuntimeException
*/
public boolean flushConnectionPool(PoolInfo poolInfo) throws ConnectorRuntimeException;
/**
* Flush Connection pool by reinitializing the connections
* established in the pool.
* @param PoolInfo connection pool info
* @throws ConnectorRuntimeException
*/
public boolean flushConnectionPool(String poolName) throws ConnectorRuntimeException;
/**
* Fetch the DataSource/Driver implementation class names for a particular
* dbVendor and resource type. Sometimes an already stored datasource
* classname is used in this method.
* @param dbVendor database vendor name
* @param resType resource-type
* (javax.sql.DataSource/javax.sql.ConnectionPoolDataSource/javax.sql.XADataSource/java.sql.Driver)
* @return set of implementation class names for the dbvendor.
*/
public Set getJdbcDriverClassNames(String dbVendor, String resType);
/**
*
* Fetch the DataSource/Driver implementation class names for a particular
* dbVendor and resource type. A pre-defined datasource or driver
* classname is returned by this method by default for common database
* vendors. When introspect is true, classnames
* are got by introspection of the jdbc driver jar.
* @param dbVendor database vendor name
* @param resType resource-type
* @param introspect
* (javax.sql.DataSource/javax.sql.ConnectionPoolDataSource/javax.sql.XADataSource/java.sql.Driver)
* @return set of implementation class names for the dbvendor.
*/
public Set getJdbcDriverClassNames(String dbVendor, String resType,
boolean introspect);
/**
* Check if Ping attribute is on during pool creation. This is used for
* pinging the pool for erroneous values during pool creation.
*
* @param PoolInfo connection pool info
* @return true if ping is on
*/
public boolean getPingDuringPoolCreation(PoolInfo poolInfo);
/**
* given a resource-adapter name, retrieves the connector-descriptor
* either from runtime's registry or by reading the descriptor from
* deployment location.
* @param rarName resource-adapter-name
* @return ConnectorDescriptor of the .rar
* @throws ConnectorRuntimeException when unable to provide the descriptor
*/
public ConnectorDescriptor getConnectorDescriptor(String rarName)
throws ConnectorRuntimeException ;
/**
* Get jdbc database vendor names list. This is used for getting a list
* of all common database vendor names.
* @return set of common database vendor names
*/
public Set getDatabaseVendorNames();
/**
* associates the given instance of ResourceAdapterAssociation with
* the ResourceAdapter java-bean of the specified RAR
* @param rarName resource-adapter-name
* @param raa Object that is an instance of ResourceAdapterAssociation
* @throws ResourceException when unable to associate the RA Bean with RAA instance.
*/
public void associateResourceAdapter(String rarName, ResourceAdapterAssociation raa)
throws ResourceException;
/**
* Gets the shutdown-timeout attribute configured in connector-service
* @return long shutdown timeout (in milli-seconds)
*/
public long getShutdownTimeout() ;
/**
* Retrieve the "confidential" config properties of specified artifact from a resource-adapter
* @param rarName resource-adapter name
* @param type indicates the artifact type. Valid values are : ConnectorConstants.AOR, RA, MCF, MSL
* @param keyFields var-args list of key fields.
* eg: connection-definition-name when
* @return list of confidential properties
* @throws ConnectorRuntimeException
*/
public List getConfidentialProperties(String rarName,
String type, String... keyFields) throws ConnectorRuntimeException ;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy