authentik/passbook/outposts/controllers/kubernetes.py

88 lines
3.4 KiB
Python
Raw Normal View History

2020-09-02 23:04:12 +01:00
"""Kubernetes deployment controller"""
from io import StringIO
from kubernetes.client import OpenApiException
2020-10-14 16:49:09 +01:00
from kubernetes.config import load_incluster_config, load_kube_config
from kubernetes.config.config_exception import ConfigException
2020-09-02 23:04:12 +01:00
from yaml import dump_all
from passbook.outposts.controllers.base import BaseController, ControllerException
2020-10-14 16:49:09 +01:00
from passbook.outposts.controllers.k8s.deployment import DeploymentReconciler
from passbook.outposts.controllers.k8s.secret import SecretReconciler
from passbook.outposts.controllers.k8s.service import ServiceReconciler
from passbook.outposts.models import Outpost
2020-09-02 23:04:12 +01:00
class KubernetesController(BaseController):
"""Manage deployment of outpost in kubernetes"""
def __init__(self, outpost: Outpost) -> None:
super().__init__(outpost)
2020-10-14 16:49:09 +01:00
try:
load_incluster_config()
except ConfigException:
load_kube_config()
2020-09-02 23:04:12 +01:00
def up(self):
try:
namespace = self.outpost.config.kubernetes_namespace
2020-10-14 16:49:09 +01:00
secret_reconciler = SecretReconciler(self.outpost)
secret_reconciler.namespace = namespace
secret_reconciler.up()
2020-10-14 16:49:09 +01:00
deployment_reconciler = DeploymentReconciler(self.outpost)
deployment_reconciler.namespace = namespace
deployment_reconciler.deployment_ports = self.deployment_ports
deployment_reconciler.up()
2020-10-14 16:49:09 +01:00
service_reconciler = ServiceReconciler(self.outpost)
service_reconciler.namespace = namespace
service_reconciler.deployment_ports = self.deployment_ports
service_reconciler.up()
except OpenApiException as exc:
raise ControllerException from exc
def down(self):
try:
namespace = self.outpost.config.kubernetes_namespace
secret_reconciler = SecretReconciler(self.outpost)
secret_reconciler.namespace = namespace
secret_reconciler.down()
deployment_reconciler = DeploymentReconciler(self.outpost)
deployment_reconciler.namespace = namespace
deployment_reconciler.deployment_ports = self.deployment_ports
deployment_reconciler.down()
service_reconciler = ServiceReconciler(self.outpost)
service_reconciler.namespace = namespace
service_reconciler.deployment_ports = self.deployment_ports
service_reconciler.down()
except OpenApiException as exc:
raise ControllerException from exc
2020-09-02 23:04:12 +01:00
def get_static_deployment(self) -> str:
2020-10-14 16:49:09 +01:00
secret_reconciler = SecretReconciler(self.outpost)
secret_reconciler.namespace = ""
deployment_reconciler = DeploymentReconciler(self.outpost)
deployment_reconciler.namespace = ""
deployment_reconciler.deployment_ports = self.deployment_ports
service_reconciler = ServiceReconciler(self.outpost)
service_reconciler.namespace = ""
service_reconciler.deployment_ports = self.deployment_ports
2020-09-02 23:04:12 +01:00
with StringIO() as _str:
dump_all(
[
2020-10-14 16:49:09 +01:00
secret_reconciler.get_reference_object().to_dict(),
deployment_reconciler.get_reference_object().to_dict(),
service_reconciler.get_reference_object().to_dict(),
2020-09-02 23:04:12 +01:00
],
stream=_str,
default_flow_style=False,
)
return _str.getvalue()