The event service defines two roles for objects: the supplier role and the consumer role. Suppliers supply event data to the event channel and consumers receive event data from the channel. Suppliers do not need to know the identity of the consumers, and vice versa. Consumers and suppliers are connected to the event channel via proxies, which are managed by ConsumerAdmin and SupplierAdmin objects.
There are four general models of communication. These are:
Notifier
. Active suppliers use event channel to push data to
passive consumers registered with the event channel.
Procure
since they
procure events on behalf of consumers. Active consumers can explicitly
pull data from passive suppliers via the event channels.
Queue
.
Active consumers explicitly pull data deposited by active suppliers via
the event channels.
Intelligent agent
. Active event channels can pull data from
passive suppliers to push it to passive consumers.
To get access to the record definitions for the structuress use:
-include_lib("cosEvent/src/CosEventChannelAdmin.hrl").
.
There are seven different interfaces supported in the service:
IDL specification for CosEventChannelAdmin:
#ifndef _COSEVENTCHANELADMIN_IDL #define _COSEVENTCHANELADMIN_IDL #include "CosEventComm.idl" #pragma prefix "omg.org" module CosEventChannelAdmin { exception AlreadyConnected{}; exception TypeError{}; interface ProxyPushConsumer: CosEventComm::PushConsumer { void connect_push_supplier(in CosEventComm:: PushSupplier push_supplier) raises (AlreadyConnected); }; interface ProxyPullSupplier: CosEventComm::PullSupplier { void connect_pull_consumer(in CosEventComm:: PullConsumer pull_consumer) raises (AlreadyConnected); }; interface ProxyPullConsumer: CosEventComm::PullConsumer { void connect_pull_supplier(in CosEventComm:: PullSupplier pull_supplier) raises (AlreadyConnected, TypeError); }; interface ProxyPushSupplier: CosEventComm::PushSupplier { void connect_push_consumer(in CosEventComm:: PushConsumer push_consumer) raises (AlreadyConnected, TypeError); }; interface ConsumerAdmin { ProxyPushSupplier obtain_push_supplier(); ProxyPullSupplier obtain_pull_supplier(); }; interface SupplierAdmin { ProxyPushConsumer obtain_push_consumer(); ProxyPullConsumer obtain_pull_consumer(); }; interface EventChannel { ConsumerAdmin for_consumers(); SupplierAdmin for_suppliers(); void destroy(); }; }; #endif