from pip_services3_commons.config import IConfigurable, ConfigParams, IExecutable
from pip_services3_commons.refer import IReferenceable, IReferences, Descriptor, IUnreferenceable
from pip_services3_commons.run import IOpenable, ICleanable
from pip_services3_components.log import ConsoleLogger, LogLevel
class MyComponentB(IReferenceable, IUnreferenceable, IConfigurable, IOpenable, ICleanable):
_param1 = 'ABC2'
_param2 = 456
_opened = False
dummy_variable = "resource variable"
def __init__(self):
"""
Creates a new instance of the component.
"""
self._status = "Created"
logger.info(None, "MyComponentB has been created.")
def configure(self, config):
self._param1 = config.get_as_string_with_default("param1", self._param1)
self._param2 = config.get_as_integer_with_default("param2", self._param2)
logger.info(None, "MyComponentB has been configured.")
def set_references(self, references):
pass
def is_open(self):
pass
def open(self, correlation_id):
pass
def close(self, correlation_id):
pass
def my_task(self, correlation_id):
pass
def unset_references(self):
"""
Unsets (clears) previously set references to dependent components.
"""
pass
def clear(self, correlation_id):
"""
Clears component state.
:param correlation_id: (optional) transaction id to trace execution through call chain.
"""
pass
class MyComponentA(IReferenceable, IUnreferenceable, IConfigurable, IOpenable, ICleanable, IExecutable):
_param1 = 'ABC'
_param2 = 123
_another_component: MyComponentB
_open = False
_status = None
def __init__(self):
"""
Creates a new instance of the component.
"""
self._status = "Created"
logger.info(None, "MyComponentA has been created.")
def configure(self, config):
self._param1 = config.get_as_string_with_default("param1", 'ABC')
self._param2 = config.get_as_integer_with_default("param2", 123)
self._status = "Configured"
logger.info(None,"MyComponentA has been configured.")
def set_references(self, references):
self._another_component = references.get_one_required(
Descriptor("myservice", "mycomponent-b", "*", "*", "1.0")
)
self._status = "Configured"
logger.info(None,"MyComponentA's references have been defined.")
def is_open(self):
return self._open
def open(self, correlation_id):
self._open = True
self._status = "Open"
logger.info(None,"MyComponentA has been opened.")
# artificial problem
self.my_task(correlation_id)
def close(self, correlation_id):
self._opened = False
self._status = "Closed"
logger.info(correlation_id,"MyComponentA has been closed.")
def my_task(self, correlation_id):
# create an artificial problem
try:
raise Exception('Logging demo', 'Error created')
except Exception as inst:
logger.error(correlation_id, inst, "Error created.")
def unset_references(self):
"""
Unsets (clears) previously set references to dependent components.
"""
self._another_component = None
self._status = "Un-referenced"
logger.info(None, "References cleared")
def clear(self, correlation_id):
"""
Clears component state.
:param correlation_id: (optional) transaction id to trace execution through call chain.
"""
self.dummy_variable = None
self._status = None
logger.info(correlation_id, "Resources cleared")