README.md 2.8 KB
Newer Older
Blazej's avatar
Blazej committed
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
82
83
84
85
86
87
88
89
90
91
92
<!--
SPDX-FileCopyrightText: Copyright (c) 2024-2025 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
SPDX-License-Identifier: Apache-2.0

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->

# Event Plane example

A basic example that demonstrates how to use the Event Plane API to create an event plane, register an event, and trigger the event.

## Code overview

### Using context managers (recommended)

```python
async def example_with_context_managers():
    server_url = "tls://localhost:4222"
    component_id = uuid.uuid4()

    async with NatsEventPlane(server_url, component_id) as plane:
        received_events = []

        async def callback(event):
            print(event)
            received_events.append(event)

        event_topic = EventTopic(["test", "event_topic"])
        event_type = "test_event"
        event = b"my_payload"

        # Subscribe using context manager
        async with await plane.subscribe(callback, event_topic=event_topic, event_type=event_type):
            # Publish event
            await plane.publish(event, event_type, event_topic)
            # Allow time for message to propagate
            await asyncio.sleep(2)
```

### Manual resource management

#### 1) Initialize NATS server and create an event plane
```python
    server_url = "tls://localhost:4222" # Optional, default is nats://localhost:4222
    component_id = uuid.uuid4() # Optional, component_id will be generated if not given
    plane = NatsEventPlane(server_url, component_id)
    await plane.connect()
```

#### 2) Define the callback function for receiving events
```python
    received_events = []
    async def callback(event):
        print(event)
        received_events.append(event)
```

#### 3) Prepare the event event_topic, event type, and event payload
```python
    event_topic = EventTopic(["test", "event_topic"])
    event_type = "test_event"
    event = b"my_payload"
```

#### 4) Subscribe to the event event_topic and type and register the callback function
```python
    subscription = await plane.subscribe(callback, event_topic=event_topic, event_type=event_type)
```

#### 5) Publish the event
```python
    await plane.publish(event, event_type, event_topic)
```

#### 6) Clean up resources
```python
    # Unsubscribe when done
    await subscription.unsubscribe()

    # Disconnect from NATS server
    await plane.disconnect()
```