netbox/netbox/core/jobs.py
2024-08-01 14:18:33 -04:00

34 lines
901 B
Python

import logging
from netbox.jobs import JobRunner
from netbox.search.backends import search_backend
from .choices import DataSourceStatusChoices
from .exceptions import SyncError
from .models import DataSource
logger = logging.getLogger(__name__)
class SyncDataSourceJob(JobRunner):
"""
Call sync() on a DataSource.
"""
class Meta:
name = 'Synchronization'
def run(self, *args, **kwargs):
datasource = DataSource.objects.get(pk=self.job.object_id)
try:
datasource.sync()
# Update the search cache for DataFiles belonging to this source
search_backend.cache(datasource.datafiles.iterator())
except Exception as e:
DataSource.objects.filter(pk=datasource.pk).update(status=DataSourceStatusChoices.FAILED)
if type(e) is SyncError:
logging.error(e)
raise e