blob: 25f2dc805b6d6c568d72a552ca9bb69e3aab1c4b (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
<?xml version="1.0" encoding="latin1" ?>
<!DOCTYPE erlref SYSTEM "erlref.dtd">
<erlref>
<header>
<copyright>
<year>1997</year>
<year>2007</year>
<holder>Ericsson AB, All Rights Reserved</holder>
</copyright>
<legalnotice>
The contents of this file are subject to the Erlang Public License,
Version 1.1, (the "License"); you may not use this file except in
compliance with the License. You should have received a copy of the
Erlang Public License along with this software. If not, it can be
retrieved online at http://www.erlang.org/.
Software distributed under the License is distributed on an "AS IS"
basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
the License for the specific language governing rights and limitations
under the License.
The Initial Developer of the Original Code is Ericsson AB.
</legalnotice>
<title>CosEventChannelAdmin</title>
<prepared></prepared>
<responsible></responsible>
<docno></docno>
<approved></approved>
<checked></checked>
<date>1997-11-13</date>
<rev>PA1</rev>
<file>CosEventChannelAdmin.xml</file>
</header>
<module>CosEventChannelAdmin</module>
<modulesummary>The CosEventChannelAdmin defines a set if event service interfaces that enables decoupled asynchronous communication between objects and implements generic (untyped) version of the OMG COSS standard event service.</modulesummary>
<description>
<p>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.</p>
<p>There are four general models of communication. These are: </p>
<list type="bulleted">
<item>The canonical push model. It allows the suppliers of events to initiate the
transfer of event data to consumers. Event channels play the role of
<c><![CDATA[Notifier]]></c>. Active suppliers use event channel to push data to
passive consumers registered with the event channel.</item>
<item>The canonical pull model. It allows consumers to request events from
suppliers. Event channels play the role of <c><![CDATA[Procure]]></c> since they
procure events on behalf of consumers. Active consumers can explicitly
pull data from passive suppliers via the event channels.</item>
<item>The hybrid push/pull model. It allows consumers request events queued at
a channel by suppliers. Event channels play the role of <c><![CDATA[Queue]]></c>.
Active consumers explicitly pull data deposited by active suppliers via
the event channels.</item>
<item>The hybrid pull/push model. It allows the channel to pull events from
suppliers and push them to consumers. Event channels play the role of
<c><![CDATA[Intelligent agent]]></c>. Active event channels can pull data from
passive suppliers to push it to passive consumers.</item>
</list>
<p>To get access to all definitions, e.g., exceptions,
include necessary <c><![CDATA[hrl]]></c> files by using:<br></br><c><![CDATA[-include_lib("cosEvent/include/*.hrl").]]></c></p>
<p>There are seven different interfaces supported in the service:</p>
<list type="bulleted">
<item>ProxyPushConsumer</item>
<item>ProxyPullSupplier</item>
<item>ProxyPullConsumer</item>
<item>ProxyPushSupplier</item>
<item>ConsumerAdmin</item>
<item>SupplierAdmin</item>
<item>EventChannel</item>
</list>
<p>IDL specification for CosEventChannelAdmin:</p>
<codeinclude file="../../src/CosEventChannelAdmin.idl" tag="" type="c"></codeinclude>
</description>
</erlref>
|