How to construct an annotation from a term definition, or re-engineer a term definition from an annotation example?
Here's how.
Terms are defined within a "vocabulary", which is just an EDMX document.
<edmx:Edmx Version="4.0" xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx">
<edmx:DataServices>
<Schema Namespace="Vocab"
xmlns="http://docs.oasis-open.org/odata/ns/edm">
To use a term in an annotation, the vocabulary of the term needs to be referenced and included.
<edmx:Edmx Version="4.0" xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx">
<edmx:Reference Uri="https://somewhere.org/vocab.xml">
<edmx:Include Namespace="Vocab" />
</edmx:Reference>
If the term has a primitive type
<Term Name="StringTerm" Type="Edm.String" />
A constant annotation value can be provided in a corresponding attribute.
<Annotation Term="Vocab.StringTerm" String="annotation value" />
See Constant Annotation Values for a list of all attributes and example values for them.
A dynamic annotation value can be provided for the same term using a value path expression.
<Annotation Term="Vocab.StringTerm" Path="SomeStringProperty" />
The property referenced via the value path expression, here SomeStringProperty
needs to have the same type as the term. A value path expression can always be used instead of a constant value, also in the more complicated cases below.
If the term has a collection type
<Term Name="CollectionTerm" Type="Collection(Edm.Decimal)" />
the annotation value is provided as a collection expression
<Annotation Term="Vocab.CollectionTerm">
<Collection>
<Decimal>2.78</Decimal>
<Decimal>3.14</Decimal>
</Collection>
</Annotation>
If the term has a structured type
<Term Name="StructuredTerm" Type="Vocab.Complex" />
<ComplexType Name="Complex">
<Property Name="IntegerField" Type="Edm.Int32" />
</ComplexType>
the annotation value is provided as a record expression
<Annotation Term="Vocab.StructuredTerm">
<Record>
<PropertyValue Property="IntegerField" Int="42" />
</Record>
</Annotation>
Constant annotation values for primitive properties are provided in the same way as for primitive terms.
Terms can also be typed as a collection of a structured type.
<Term Name="StructuredCollectionTerm" Type="Collection(Vocab.AnotherComplex)" />
<ComplexType Name="AnotherComplex">
<Property Name="DateField" Type="Edm.Date" />
<Property Name="TimeField" Type="Edm.TimeOfDay" DefaultValue="00:00:00" />
</ComplexType>
The annotation value is provided as a collection of records.
<Annotation Term="Vocab.StructuredCollectionTerm">
<Collection>
<Record>
<PropertyValue Property="DateField" Date="2020-06-30" />
<PropertyValue Property="TimeField" TimeOfDay="16:55:03" />
</Record>
<Record>
<PropertyValue Property="DateField" Date="2020-07-01" />
</Record>
<Record>
<PropertyValue Property="TimeField" TimeOfDay="23:59:59" />
</Record>
</Collection>
</Annotation>
Properties that are nullable or have a default value can be omitted.
Properties of a structured type can themselves be structured or collections.
<Term Name="NestedTerm" Type="Collection(Vocab.YetAnotherComplex)" />
<ComplexType Name="YetAnotherComplex">
<Property Name="StructuredField" Type="Vocab.Complex" />
<Property Name="CollectionField" Type="Collection(Vocab.AnotherComplex)" />
</ComplexType>
The property value is provided as a record or collection.
<Annotation Term="Vocab.NestedTerm">
<Record>
<PropertyValue Property="StructuredField">
<Record>
<PropertyValue Property="IntegerField" Int="42" />
</Record>
</PropertyValue>
<PropertyValue Property="CollectionField">
<Collection>
<Record>
<PropertyValue Property="DateField" Date="2020-06-30" />
<PropertyValue Property="TimeField" TimeOfDay="16:55:03" />
</Record>
</Collection>
</PropertyValue>
</Record>
</Annotation>
The name of the attribute to provide a constant annotation value depends on the type of the term or term property.
Type of Term or Term Property | Attribute with Example Value |
---|---|
Edm.Binary |
Binary="T0RhdGE" |
Edm.Boolean |
Bool="true" |
Edm.Date |
Date="2000-01-01" |
Edm.DateTimeOffset |
DateTimeOffset="2000-01-01T16:00:00.000Z" |
Edm.Decimal |
Decimal="3.14" |
Edm.Duration |
Duration="P7D" |
Enumeration Type | EnumMember="org.example.Pattern/Red" |
Edm.Double or Edm.Single |
Float="3.14" |
Edm.Guid |
Guid="21EC2020-3AEA-1069-A2DD-08002B30309D" |
Edm.Int16 , Edm.Int32 , Edm.64 , Edm.Byte , Edm.SByte |
Int="42" |
Edm.String |
String="annotation value" |
Edm.TimeOfDay |
TimeOfDay="21:45:00" |
Edm.AnnotationPath |
AnnotationPath="Product/Supplier/@UI.LineItem" |
Edm.NavigationPropertyPath |
NavigationPropertyPath="Supplier" |
Edm.PropertyPath |
PropertyPath="Details/ChangedAt" |