File size: 1,412 Bytes
4f6ee5b
6c9722e
4f6ee5b
 
 
 
 
6c9722e
 
4f6ee5b
6c9722e
 
 
 
 
 
 
 
 
 
4f6ee5b
6c9722e
4f6ee5b
6c9722e
 
 
 
4f6ee5b
6c9722e
4f6ee5b
6c9722e
 
 
 
4f6ee5b
6c9722e
4f6ee5b
6c9722e
 
 
 
4f6ee5b
6c9722e
4f6ee5b
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

import logging

setup_logging = __import__('logging_config').setup_logging
setup_logging()

logger = logging.getLogger('interactors')

class Interactor:
    def __init__(self, channel, entity):
        self.channel = channel
        self.entity = entity
        self.channel.on('create', self.create)
        self.channel.on('read', self.read)
        self.channel.on('update', self.update)
        self.channel.on('delete', self.delete)

    def create(self, key: str, value: any):
        try:
            self.entity.create(key, value)
            logger.info(f"Create event emitted: {key} = {value}")
        except Exception as e:
            logger.error(f"Error emitting create event: {e}")

    def read(self, key: str):
        try:
            self.entity.read(key)
            logger.info(f"Read event emitted: {key}")
        except Exception as e:
            logger.error(f"Error emitting read event: {e}")

    def update(self, key: str, value: any):
        try:
            self.entity.update(key, value)
            logger.info(f"Update event emitted: {key} = {value}")
        except Exception as e:
            logger.error(f"Error emitting update event: {e}")

    def delete(self, key: str):
        try:
            self.entity.delete(key)
            logger.info(f"Delete event emitted: {key}")
        except Exception as e:
            logger.error(f"Error emitting delete event: {e}")