8f83679c48
[2020-12-20 18:01:50,264: WARNING/ForkPoolWorker-7] Pruning UncloudTask object (571ffc76-8b40-4cb6-9658-87030834bc6c)... [2020-12-20 18:01:50,265: ERROR/ForkPoolWorker-7] Task uncloud.tasks.cleanup_tasks[f9fb1480-f122-41c9-bec1-3d6d0f92a22e] raised unexpected: RuntimeError('Never call result.get() within a task!\nSee http://docs.celeryq.org/en/latest/userguide/tasks.html#task-synchronous-subtasks\n') Traceback (most recent call last): File "/home/nico/vcs/uncloud/venv/lib/python3.8/site-packages/celery/app/trace.py", line 405, in trace_task R = retval = fun(*args, **kwargs) File "/home/nico/vcs/uncloud/venv/lib/python3.8/site-packages/celery/app/trace.py", line 697, in __protected_call__ return self.run(*args, **kwargs) File "/home/nico/vcs/uncloud/uncloud/tasks.py", line 13, in cleanup_tasks print(res.get()) File "/home/nico/vcs/uncloud/venv/lib/python3.8/site-packages/celery/result.py", line 209, in get assert_will_not_block() File "/home/nico/vcs/uncloud/venv/lib/python3.8/site-packages/celery/result.py", line 37, in assert_will_not_block raise RuntimeError(E_WOULDBLOCK) RuntimeError: Never call result.get() within a task! See http://docs.celeryq.org/en/latest/userguide/tasks.html#task-synchronous-subtasks
61 lines
1.6 KiB
Python
61 lines
1.6 KiB
Python
from celery import shared_task
|
|
from .models import *
|
|
|
|
from uncloud.models import UncloudTask
|
|
|
|
import os
|
|
import subprocess
|
|
import logging
|
|
import uuid
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
@shared_task
|
|
def whereami():
|
|
print(os.uname())
|
|
return os.uname()
|
|
|
|
def configure_wireguard_server(wireguardvpnpool):
|
|
"""
|
|
- Create wireguard config (DB query -> string)
|
|
- Submit config to cdist worker
|
|
- Change config locally on worker / commit / shared
|
|
|
|
"""
|
|
|
|
config = wireguardvpnpool.wireguard_config
|
|
server = wireguardvpnpool.vpn_server_hostname
|
|
|
|
log.info(f"Configuring VPN server {server} (async)")
|
|
|
|
task_id = uuid.UUID(cdist_configure_wireguard_server.apply_async((config, server)).id)
|
|
UncloudTask.objects.create(task_id=task_id)
|
|
|
|
|
|
@shared_task
|
|
def cdist_configure_wireguard_server(config, server):
|
|
"""
|
|
Create config and configure server.
|
|
|
|
To be executed on the cdist workers.
|
|
"""
|
|
|
|
dirname= "/home/app/.cdist/type/__ungleich_wireguard/files/"
|
|
fname = os.path.join(dirname,server)
|
|
|
|
log.info(f"Configuring VPN server {server} (on cdist host)")
|
|
with open(fname, "w") as fd:
|
|
fd.write(config)
|
|
|
|
|
|
log.debug("git committing wireguard changes")
|
|
subprocess.run(f"cd /aa{dirname} && git pull && git add {server} && git commit -m 'Updating config for ${server}' && git push",
|
|
shell=True, check=True)
|
|
|
|
log.debug(f"Configuring VPN server {server} with cdist")
|
|
subprocess.run(f"cdist config {server}", shell=True, check=True)
|
|
|
|
# FIXME:
|
|
# ensure logs are on the server
|
|
# ensure exit codes are known
|
|
return "All good"
|