Configuring Rules
As part of configuring your Windchill solution, you can:
Create additional default value, constraint, and conditional logic algorithms that can be used in object initialization rules.
Use the AttrValue element to specify default values for additional object types or attributes in object initialization rules.
To use object types or attributes that are not listed in Using Supported Types and Attributes, you may need to perform additional configuration and customization as described in the “Additional Type and Attribute Pairs” section in this topic.
Use the AttrConstraint element to specify constraints for additional attributes in object initialization rules.
To use object types or attributes that are not listed in Using Supported Types and Attributes, you may need to perform additional configuration and customization as described in the “Additional Type and Attribute Pairs” section in this topic.
Many of the object initialization rules that are loaded provide specific functionality in the user interface. Do not modify the rules that are loaded without considering the full impact of your changes.
Custom Rule Algorithms
To create custom algorithms, PTC provides the wt.rule.algorithm.RuleAlgorithm interface upon which all out-of-the-box algorithms have been built. For details on how to use this interface to create custom algorithms, see the Javadoc associated with this interface.
Additional Type and Attribute Pairs
The RuleConfigurableTypeAttribute.properties file contains the list of object and attribute pairs for constraints. Each property has the following format:
object_type="list_of_attributes"
where:
object_type is the internal name of the object type, as defined in the Type and Attribute Management utility.
list_of_attributes is zero or more attributes (separated by commas).
* 
A value of zero indicates that display constraints are not supported for the object type.
Use the internal name of each local or global attribute you want to include. The internal names for attributes are defined in the Type and Attribute Management utility.
To add new properties to this file, use the Property element. For example, to add a new object type that has the internal name of "myCompany.demoType" and defined attributes that have the internal names "myCompany.demoAttr1" and "myCompany.demoAttr2", enter following tag in the xconf file of your module. For example, <moduleName>/main/xconf/<yourFileName>.xconf file:
<Property name="myCompany.demoType"
default="myCompany.demoAttr1,myCompany.demoAttr2" targetFile="
codebase/com/ptc/core/rule/server/delegate/init/RuleConfigurableTypeAttribute.properties"
/>
To add a new attribute to an existing property, copy the existing value and set the property again with the complete value, that is append the new attribute with the existing value. For example, to add an attribute with the internal name as “description” to the existing property for the wt.doc.WTDocument object type, add the given Property element in the configurations/xconf/custom.site.xonf file:
<Property name="wt.doc.WTDocument"
value="number,lifeCycle.id,lifeCycle,teamTemplate,teamTemplate.id,folder.id,organization.id,description"
targetFile="codebase/com/ptc/core/rule/server/delegate/init/RuleConfigurableTypeAttribute.properties"
/>
A default value that is specified in a rule will only be used if the value for the attribute is left unspecified by the user interface that is used to create the object. If the user interface code does not allow the value for an attribute to be left unspecified, then you must customize the user interface to allow the value to be left unspecified. If you do not customize the interface, the value that you specify in the object initialization rule will not be used. If there is no user interface used to create this attribute, and no attribute value is specified, the default value is used.
A constraint that is specified in a rule will only impact the way an attribute is rendered in a user interface if the user interface code reads constraints and uses the constraint information to determine how to render the attribute. If the user interface does not read constraints or does not use the constraint information to determine how to render the attribute, then you must customize the user interface to do so. If you do not customize the interface, the constraint that you specify in the object initialization rules will not have any impact on the display of the attribute.
* 
All user interfaces provided by PTC require customization to use constraints defined in rules for local or global attributes.
Was this helpful?