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

org.kie.api.runtime.rule.EntryPoint Maven / Gradle / Ivy

Go to download

The Kogito public API which is backwards compatible between releases.

There is a newer version: 10.0.0
Show newest version
/*
 * Copyright 2010 Red Hat, Inc. and/or its affiliates.
 *
 * 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 org.kie.api.runtime.rule;

import java.util.Collection;

import org.kie.api.runtime.ObjectFilter;

/**
 * 

An entry-point is an abstract channel through where facts are inserted into the engine.

*

KIE 6 supports multiple entry-points into a single {@link org.kie.api.KieBase}: the * default, anonymous entry-point, as well as as many user declared entry points the application * requires.

* *

To get a reference to an entry point, just request the session:

*
 * KieSession session = kbase.newStatelessKieSession();
 * ...
 * WorkingMemoryEntryPoint entrypoint = session.getEntryPoint("my entry point");
 * 
*

Once a reference to an entry point is acquired, the application can insert, update and retract facts * to/from that entry-point as usual:

*
 * ...
 * FactHandle factHandle = entrypoint.insert( fact );
 * ...
 * entrypoint.update( factHandle, newFact );
 * ...
 * entrypoint.retract( factHandle );
 * ...
 * 
*/ public interface EntryPoint { String DEFAULT_NAME = "DEFAULT"; /** * @return the String Id of this entry point */ String getEntryPointId(); /** * Inserts a new fact into this entry point * * @param object * the fact to be inserted * * @return the fact handle created for the given fact */ FactHandle insert(Object object); /** * Retracts the fact for which the given FactHandle was assigned. * * @param handle the handle whose fact is to be retracted. * @deprecated use {@link #delete(FactHandle)} */ void retract(FactHandle handle); /** * Retracts the fact for which the given FactHandle was assigned * regardless if it has been explicitly or logically inserted. * * @param handle the handle whose fact is to be retracted. */ void delete(FactHandle handle); /** * Retracts the fact for which the given FactHandle was assigned. * * @param handle the handle whose fact is to be retracted. * @param fhState defines how the handle has to be retracted: * as an explicitly inserted fact (STATED), from the * Truth Maintenance System (LOGICAL), or both (ALL) */ void delete(FactHandle handle, FactHandle.State fhState); /** * Updates the fact for which the given FactHandle was assigned with the new * fact set as the second parameter in this method. * * @param handle the FactHandle for the fact to be updated. * @param object the new value for the fact being updated. */ void update(FactHandle handle, Object object); /** * Updates the fact for which the given FactHandle was assigned with the new * fact set as the second parameter in this method, also specifying the set of * properties that have been modified. * * @param handle the FactHandle for the fact to be updated. * @param object the new value for the fact being updated. * @param modifiedProperties the list of the names of the object's properties modified by this update. */ void update(FactHandle handle, Object object, String... modifiedProperties); /** * Returns the fact handle associated with the given object. It is important to note that this * method behaves in accordance with the configured assert behaviour for this {@link org.kie.api.KieBase} * (either IDENTITY or EQUALITY). * * @param object * the fact for which the fact handle will be returned. * * @return the fact handle for the given object, or null in case no fact handle was found for the * given object. * * @see org.kie.api.KieBaseConfiguration */ FactHandle getFactHandle(Object object); /** * @return the object associated with the given FactHandle. */ Object getObject(FactHandle factHandle); /** *

This class is not a general-purpose Collection * implementation! While this class implements the Collection interface, it * intentionally violates Collection general contract, which mandates the * use of the equals method when comparing objects.

* *

Instead the approach used when comparing objects with the contains(Object) * method is dependent on the WorkingMemory configuration, where it can be configured for Identity * or for Equality.

* * @return all facts from the current session as a Collection. */ Collection getObjects(); /** * @param filter the filter to be applied to the returned collection of facts. * @return all facts from the current session that are accepted by the given ObjectFilter. */ Collection getObjects(ObjectFilter filter); /** * @return all FactHandles from the current session. */ Collection< T > getFactHandles(); /** * @param filter the filter to be applied to the returned collection of FactHandles. * @return all FactHandles from the current session for which the facts are accepted by * the given filter. */ Collection< T > getFactHandles(ObjectFilter filter); /** * @return the total number of facts currently in this entry point */ long getFactCount(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy