2020-09-02 23:04:12 +01:00
|
|
|
"""outpost tasks"""
|
2020-09-13 13:29:40 +01:00
|
|
|
from typing import Any
|
|
|
|
|
|
|
|
from asgiref.sync import async_to_sync
|
|
|
|
from channels.layers import get_channel_layer
|
|
|
|
from structlog import get_logger
|
|
|
|
|
|
|
|
from passbook.lib.utils.reflection import path_to_class
|
|
|
|
from passbook.outposts.models import (
|
|
|
|
Outpost,
|
|
|
|
OutpostDeploymentType,
|
|
|
|
OutpostModel,
|
|
|
|
OutpostType,
|
|
|
|
)
|
2020-09-02 23:04:12 +01:00
|
|
|
from passbook.providers.proxy.controllers.kubernetes import ProxyKubernetesController
|
|
|
|
from passbook.root.celery import CELERY_APP
|
|
|
|
|
2020-09-13 13:29:40 +01:00
|
|
|
LOGGER = get_logger()
|
|
|
|
|
2020-09-02 23:04:12 +01:00
|
|
|
|
|
|
|
@CELERY_APP.task(bind=True)
|
|
|
|
# pylint: disable=unused-argument
|
|
|
|
def outpost_k8s_controller(self):
|
|
|
|
"""Launch Kubernetes Controller for all Outposts which are deployed in kubernetes"""
|
|
|
|
for outpost in Outpost.objects.filter(
|
|
|
|
deployment_type=OutpostDeploymentType.KUBERNETES
|
|
|
|
):
|
|
|
|
outpost_k8s_controller_single.delay(outpost.pk.hex, outpost.type)
|
|
|
|
|
|
|
|
|
|
|
|
@CELERY_APP.task(bind=True)
|
|
|
|
# pylint: disable=unused-argument
|
|
|
|
def outpost_k8s_controller_single(self, outpost: str, outpost_type: str):
|
|
|
|
"""Launch Kubernetes manager and reconcile deployment/service/etc"""
|
|
|
|
if outpost_type == OutpostType.PROXY:
|
|
|
|
ProxyKubernetesController(outpost).run()
|
2020-09-13 13:29:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
@CELERY_APP.task()
|
|
|
|
def outpost_send_update(model_class: str, model_pk: Any):
|
|
|
|
"""Send outpost update to all registered outposts, irregardless to which passbook
|
|
|
|
instance they are connected"""
|
|
|
|
model = path_to_class(model_class)
|
|
|
|
outpost_model: OutpostModel = model.objects.get(model_pk)
|
|
|
|
for outpost in outpost_model.outpost_set.all():
|
|
|
|
channel_layer = get_channel_layer()
|
|
|
|
for channel in outpost.channels:
|
|
|
|
LOGGER.debug("sending update", channel=channel)
|
|
|
|
async_to_sync(channel_layer.send)(channel, {"type": "event.update"})
|