Im Rahmen dieser Arbeit soll die Betrachtung der wohldefinierten Datenstruktur der Ereignisse des Notification Service im Mittelpunkt stehen. Grund hierfür ist, daß es einerseits noch keine Implementierung des Notification Service gibt und andererseits der Notification Service dem Event Service sehr ähnlich ist. Weitergehende Unterschiede und nähere Information zu diesen kann in der Spezifikation zum Notification Service [OMG98] nachgeschlagen werden.
Der CORBA Event Service unterstützt zwei Arten der Eventkommunikation: typisierte und untypisierte Events. Letzterer wurden schon im vorigen Kapitel angesprochen und stellen die sogennannten Any-Datentypen dar, die leicht zu implementieren sind. Viele Anwendungen brauchen hingegen strenger typisierte Ereignismeldungen. Der OMG Event Service definiert gewisse Schnittstellen und Konventionen für typisierte Ereignismeldungen.
Aus diesem Grund bietet der Notification Service eine wohldefinierte Event-Datenstruktur, der als Structured Event bezeichnet wird. Im Gegensatz zum Event Service ist es nicht mehr nötig, dieses Konstrukt in eine Any-Datenstruktur umzuwandeln, bevor es an den Event Channel geschickt wird. Leider zwingt uns jedoch das Fehlen einer Implementation des Notification Service noch zu dieser Datenkonvertierung.
Der Aufbau des Structured Event, wie er in Abbildung 2.16 zu betrachten ist, besteht aus zwei Hauptbestandteilen:
Der Fixed Header besteht aus drei Feldern vom Typ String: dem domain_type, event_type und event_name. Der domain_type bezeichnet die vertikale Industriezugehörigkeit und kann Werte wie beispielsweise Telekommunikation, Finanz- oder Gesundheitswesen annehmen. Der event_type spezifiziert den Typ der Ereignismeldung und wird somit sinnvollerweise mit Werten wie etwa AgentUp oder AgentDown belegt. Das event_name-Feld identifiziert die Instanz des Events eindeutig.
Der variable Teil setzt sich aus Null oder mehreren Bezeichnern (ohf_name) und deren Wertebelegung (ohf_value) zusammen. Die Bezeichner sind hierbei vom Datentyp String und die Wertebelegung vom CORBA-Datentyp Any.
Der letzte Teil des Body's eines Structured Events, der remainder_of_body, ist vom Datentyp Any. Vorgesehen ist dieses Feld für Daten, die sich aufgrund ihrer Größe nicht zum Filtern eignen oder nicht wichtig genug sind, um sie wohlstrukturiert auszugeben, dem Consumer aber nicht vorenthalten werden sollen. Denkbar ist hier die Ausgabe von Fehlermeldungen bzw. core-Files, die Informationen über einen möglichen Programmabsturz liefern.
Um die Vorteile der wohldefinierten Datenstrukturen nutzen zu können und spätere Portierungen vom Event Channel-Konzept zum Notification Service-Konzept möglichst einfach zu gestalten, werden alle Events in ein Structured Event verpackt. So kann ein später hinzukommender Notification Service diese wohldefinierte Datenstruktur weiter verwenden, ohne Supplier und Consumer noch an den Notification Service anpassen zu müssen. Gleichwohl können dann die Filtermöglichkeiten des Notification Service sofort genutzt werden.