authentik/passbook/outposts/controllers/base.py

42 lines
1.2 KiB
Python
Raw Normal View History

2020-09-02 23:04:12 +01:00
"""Base Controller"""
from typing import Dict, List
2020-09-02 23:04:12 +01:00
from structlog import get_logger
from structlog.testing import capture_logs
2020-09-02 23:04:12 +01:00
from passbook.lib.sentry import SentryIgnoredException
2020-09-02 23:04:12 +01:00
from passbook.outposts.models import Outpost
class ControllerException(SentryIgnoredException):
"""Exception raise when anything fails during controller run"""
2020-09-02 23:04:12 +01:00
class BaseController:
"""Base Outpost deployment controller"""
deployment_ports: Dict[str, int]
outpost: Outpost
def __init__(self, outpost_pk: str):
self.outpost = Outpost.objects.get(pk=outpost_pk)
self.logger = get_logger(
controller=self.__class__.__name__, outpost=self.outpost
)
self.deployment_ports = {}
def run(self):
"""Called by scheduled task to reconcile deployment/service/etc"""
raise NotImplementedError
def run_with_logs(self) -> List[str]:
"""Call .run() but capture all log output and return it."""
with capture_logs() as logs:
self.run()
return logs
2020-09-02 23:04:12 +01:00
def get_static_deployment(self) -> str:
"""Return a static deployment configuration"""
raise NotImplementedError