local_tasks.py 2.11 KB
Newer Older
1 2 3
from logging import getLogger
from socket import gethostname

4
import django.conf
5 6 7 8
from django.core.cache import cache

from manager.mancelery import celery

9
settings = django.conf.settings.FIREWALL_SETTINGS
10
logger = getLogger(__name__)
11

12

13 14 15
def _apply_once(name, queues, task, data):
    """Reload given networking component if needed.
    """
16

17 18 19 20 21 22
    lockname = "%s_lock" % name
    if not cache.get(lockname):
        return
    cache.delete(lockname)

    for queue in queues:
23
        task.apply_async(args=data(), queue=queue)
24
    logger.info("%s configuration is reloaded.", name)
25

26

27 28 29 30 31
@celery.task(ignore_result=True)
def periodic_task():
    from firewall.fw import Firewall, dhcp, dns, ipset, vlan
    from remote_tasks import (reload_dns, reload_dhcp, reload_firewall,
                              reload_firewall_vlan, reload_blacklist)
32

33 34 35 36
    firewall_queues = [("%s.firewall" % i) for i in
                       settings.get('firewall_queues', [gethostname()])]
    dns_queues = [("%s.dns" % i) for i in
                  settings.get('dns_queues', [gethostname()])]
37

38 39 40 41 42 43 44 45 46 47
    _apply_once('dns', dns_queues, reload_dns,
                lambda: (dns(), ))
    _apply_once('dhcp', firewall_queues, reload_dhcp,
                lambda: (dhcp(), ))
    _apply_once('firewall', firewall_queues, reload_firewall,
                lambda: (Firewall(proto=4).get(), Firewall(proto=6).get()))
    _apply_once('firewall_vlan', firewall_queues, reload_firewall_vlan,
                lambda: (vlan(), ))
    _apply_once('blacklist', firewall_queues, reload_blacklist,
                lambda: (list(ipset()), ))
48

49

50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
@celery.task
def reloadtask(type='Host'):
    reload = {
        'Host': ['dns', 'dhcp', 'firewall'],
        'Record': ['dns'],
        'Domain': ['dns'],
        'Vlan': ['dns', 'dhcp', 'firewall', 'firewall_vlan'],
        'Firewall': ['firewall'],
        'Rule': ['firewall'],
        'SwitchPort': ['firewall_vlan'],
        'EthernetDevice': ['firewall_vlan'],
    }[type]
    logger.info("Reload %s on next periodic iteration applying change to %s.",
                ", ".join(reload), type)
    for i in reload:
        cache.add("%s_lock" % i, "true", 30)