2021.4.1 #11

Merged
edraft merged 172 commits from 2021.04.01 into 2021.04 2021-03-21 20:04:24 +01:00
2 changed files with 18 additions and 9 deletions
Showing only changes of commit 01ef965180 - Show all commits

View File

@ -52,17 +52,26 @@ class ServiceProvider(ServiceProviderABC):
def get_db_context(self) -> Callable[DatabaseContextABC]: def get_db_context(self) -> Callable[DatabaseContextABC]:
return self._database_context return self._database_context
def add_transient(self, service_type: Type[ServiceABC], service: Callable[ServiceABC]): def add_transient(self, service_type: Type[ServiceABC], service: Callable[ServiceABC] = None):
if service is None:
self._transient_services[service_type] = service_type
else:
self._transient_services[service_type] = service self._transient_services[service_type] = service
def add_scoped(self, service_type: Type[ServiceABC], service: Callable[ServiceABC]): def add_scoped(self, service_type: Type[ServiceABC], service: Callable[ServiceABC] = None):
if service is None:
self._scoped_services[service_type] = service_type
else:
self._scoped_services[service_type] = service self._scoped_services[service_type] = service
def add_singleton(self, service_type: Type[ServiceABC], service: Callable[ServiceABC]): def add_singleton(self, service_type: Type[ServiceABC], service: Callable[ServiceABC] = None):
for known_service in self._singleton_services: for known_service in self._singleton_services:
if type(known_service) == service_type: if type(known_service) == service_type:
raise Exception(f'Service with type {service_type} already exists') raise Exception(f'Service with type {service_type} already exists')
if service is None:
self._singleton_services[service_type] = self._create_instance(service_type)
else:
self._singleton_services[service_type] = self._create_instance(service) self._singleton_services[service_type] = self._create_instance(service)
def get_service(self, instance_type: Type) -> Callable[ServiceABC]: def get_service(self, instance_type: Type) -> Callable[ServiceABC]:

View File

@ -18,13 +18,13 @@ class ServiceProviderABC(ABC):
def get_db_context(self) -> Callable[DatabaseContextABC]: pass def get_db_context(self) -> Callable[DatabaseContextABC]: pass
@abstractmethod @abstractmethod
def add_transient(self, service_type: Type, service: Callable): pass def add_transient(self, service_type: Type, service: Callable = None): pass
@abstractmethod @abstractmethod
def add_scoped(self, service_type: Type, service: Callable): pass def add_scoped(self, service_type: Type, service: Callable = None): pass
@abstractmethod @abstractmethod
def add_singleton(self, service_type: Type, service: Callable): pass def add_singleton(self, service_type: Type, service: Callable = None): pass
@abstractmethod @abstractmethod
def get_service(self, instance_type: Type) -> Callable[ServiceABC]: pass def get_service(self, instance_type: Type) -> Callable[ServiceABC]: pass