[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]
Subject: Issue - 145 - Proposal For Vote
Issue 145 - Properties on Non-Message Variables
Proposal: Allow for the definition of properties on non-WSDL messages.
Rationale: Properties represent a fundamental design approach where
information in potentially very complex XML variables is made available
in a simple name/value fashion. This feature is just as useful for
regular XML variables as it is for WSDL messages and should be available
for both.
Changes Required: Change propertyAlias to make messageType and part
attributes optional and introduce element and type attributes. Specify
that getVariableProperty can take arbitrary BPEL variables as arguments.
Update the terminology to make message properties a type of variable
properties.
Section 1:
From: WS-BPEL uses a notion of message properties to identify
protocol-relevant data embedded in messages.
To: WS-BPEL uses a notion of message properties, which are a type of
variable property, to identify protocol-relevant data embedded in messages.
Section 6.4:
From: Process definitions also rely on other constructs such as partner
link types, message properties and property aliases (defined later in
this specification) which are defined within WSDL 1.1 documents using
the WSDL 1.1 language extensibility feature.
To: Process definitions also rely on other constructs such as partner
link types, variable properties and property aliases (defined later in
this specification) which are defined within WSDL 1.1 documents using
the WSDL 1.1 language extensibility feature.
Section 8:
Change title to “Variable Properties”
Note: There are references in the spec to (see Message Properties) this
will need to be changed to (see Variable Properties)
Section 8.1:
Create section 8.1.1 titled “Motivation for Message Properties”, insert
current section 8.1 text there.
Create section 8.1.2 titled “Motivation for Variable Properties” with
the following value:
Message properties are an instance of a more generic mechanism, variable
properties. All variables in BPEL can have properties defined on them.
Properties are useful on non-message variables as a way to isolate the
BPEL process’s logic from the details of a particular variable’s
definition. Using properties a BPEL process can isolate its variable
initialization logic in one place and then set and get properties on
that variable in order to manipulate it. If the variable’s definition is
later changed the bulk of the BPEL process definition that manipulates
that variable can remain unchanged.
Section 8.2:
From: “Properties can occur anywhere in a message, including in the
message context.”
To “Properties can occur anywhere in a variable.”
Insert the following paragraph after the existing paragraph that begins
“In correlation, the property name must have global significance…”:
Even in the general case of properties on XML typed WS-BPEL variables
the property name should maintain its generic nature. The name is
intended to identify a certain kind of value, often with an implied
semantic. Any variable the property is available on is therefore
expected to provide a value that meets not just the syntax of the
property definition but also its semantics.
End section 8.2 after the schema for property definitions (which this
proposal does not change).
Insert section 8.3 titled "Defining Property Aliases", the content of
this new section is based on the text that was originally in section 8.2
after the property schema definition:
Properties used in business protocols are typically embedded in
application-visible variables. The notion of aliasing is introduced to
map a global property to a field in a specific message part or variable
value. The property name becomes an alias for the message part and/or
location, and can be used as such in Expressions and Assignment in
abstract business processes. As an example, consider the following WSDL
message definition:
1234567890123456789012345678901234567890123456789012345678901234567890
1 2 3 4 5 6
<definitions name="messages"
targetNamespace="http://example.com/taxMessages.wsdl"
xmlns:txtyp="http://example.com/taxTypes.xsd"
xmlns="http://schemas.xmlsoap.org/wsdl/">
<!-- define a WSDL application message -->
<message name="taxpayerInfoMsg">
<part name="identification" element="txtyp:taxPayerInfoElem"/>
</message>
...
</definitions>
The definition of a global property and its location in a particular
field of the message are shown in the next WSDL fragment:
1234567890123456789012345678901234567890123456789012345678901234567890
1 2 3 4 5 6
<definitions name="properties"
targetNamespace="http://example.com/properties.wsdl"
xmlns:tns="http://example.com/properties.wsdl"
xmlns:txtyp="http://example.com/taxTypes.xsd"
xmlns:txmsg="http://example.com/taxMessages.wsdl"
xmlns="http://schemas.xmlsoap.org/wsdl/">
<!-- define a correlation property -->
<bpws:property name="taxpayerNumber" type="txtyp:SSN"/>
...
<bpws:propertyAlias propertyName="tns:taxpayerNumber"
messageType="txmsg:taxpayerInfoMsg" part="identification">
<query>
/txtyp:taxPayerInfoElem/txtyp:socialsecnumber
</query>
</bpws:propertyAlias>
<bpws:propertyAlias propertyName="tns:taxpayerNumber"
element="txtyp:taxPayerInfoElem">
<query>
/txtyp:taxPayerInfoElem/txtyp:socialsecnumber
</query>
</bpws:propertyAlias>
</definitions>
The first bpws:propertyAlias defines a globally named property
tns:taxpayerNumber as an alias for a location in the identification part
of the message type txmsg:taxpayerInfo.
The second bpws:propertyAlias provides a second definition for the same
globally named property tns:taxpayerNumber but this time as an alias for
a location inside of the element txtyp:taxPayerInfoElem.
The presence of both aliases means that it is possible to retrieve the
social security number from both a variable holding a message of
messageType txmsg:taxpayerInfo as well as an element defined using
txtyp:taxPayerInfoElem.
The syntax for a propertyAlias definition is:
1234567890123456789012345678901234567890123456789012345678901234567890
1 2 3 4 5 6
<definitions name="ncname"
... >
<bpws:propertyAlias propertyName="qname"
messageType="qname"? part="ncname"?
type="qname"? element="ncname"?>
<query queryLanguage="anyURI"?>?
... queryString ...
</query>
</bpws:propertyAlias>
...
</wsdl:definitions>
A property alias element MUST use one of the three following
combinations of attributes:
• messageType and part,
• type or
• element.
When a propertyAlias is used with the messageType/part combination then
the property MUST be available on all BPEL variables declared with the
same messageType. The part attribute and query element is applied
against the BPEL messageType variable to either set or get the property
variable in the same way that the part attribute and query element are
used in the first from and to specs in copy assignments.
If a propertyAlias is used with a type attribute then the property MUST
be available on all BPEL variables of that type. The query is applied
against the BPEL variable to either set or get the property variable in
the same way that the query is used in the first from and to specs in
copy assignments when applied against BPEL variables defined using a type.
If a propertyAlias is used with an element attribute then the property
MUST be available on all BPEL variables declared using the same element.
The query is applied against the BPEL variable to either set or get the
property variable in the same way that the query is used in the first
from and to specs in copy assignments when applied against BPEL
variables defined using an element definition.
Section 9.0
From: Abstract processes are restricted to limited manipulation of
values contained in message properties but are permitted to use
nondeterministic values to reflect the consequences of hidden private
behavior.
To: Abstract processes are restricted to limited manipulation of values
contained in variable properties but are permitted to use
nondeterministic values to reflect the consequences of hidden private
behavior.
Section 9.1
From: If the given property does not appear in any of the parts of the
variable's message type, then the semantics of the process is undefined.
To: If the referenced property is not defined or if there does not exist
a propertyAlias to associate the property with the referenced variable
then the semantics of the process is undefined.
Section 9.3
From: The third from-spec and to-spec variants allow explicit
manipulation of message properties (see Message Properties) occurring in
variables.
To: The third from-spec and to-spec variants allow explicit manipulation
of variable properties (see Variable Properties) occurring in variables.
Section 10.2
From: They are abstract in the sense that their occurrence in messages
needs to be separately specified (see Message Properties).
To: They are abstract in the sense that their occurrence in variables
needs to be separately specified (see Variable Properties).
Section 14.1
From: If the given property does not appear in any of the parts of the
variable's message type or the given property definition selects a node
set of a size other than one, then the standard fault
bpws:selectionFailure MUST be thrown by a compliant implementation.
To: If the referenced property is not defined, if there does not exist a
propertyAlias to associate the property with the referenced variable or
if the given property definition selects a node set of a size other than
one, then the standard fault bpws:selectionFailure MUST be thrown by a
compliant implementation.
[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]