2023-02-02 10:06:23 -05:00
|
|
|
import logging
|
|
|
|
|
|
|
|
from netbox.search.backends import search_backend
|
|
|
|
from .choices import *
|
|
|
|
from .exceptions import SyncError
|
|
|
|
from .models import DataSource
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
2023-03-28 15:47:09 -04:00
|
|
|
def sync_datasource(job, *args, **kwargs):
|
2023-02-02 10:06:23 -05:00
|
|
|
"""
|
|
|
|
Call sync() on a DataSource.
|
|
|
|
"""
|
2023-03-28 15:47:09 -04:00
|
|
|
datasource = DataSource.objects.get(pk=job.object_id)
|
2023-02-02 10:06:23 -05:00
|
|
|
|
|
|
|
try:
|
2023-03-28 15:47:09 -04:00
|
|
|
job.start()
|
2023-02-02 10:06:23 -05:00
|
|
|
datasource.sync()
|
|
|
|
|
|
|
|
# Update the search cache for DataFiles belonging to this source
|
|
|
|
search_backend.cache(datasource.datafiles.iterator())
|
|
|
|
|
2023-03-28 15:47:09 -04:00
|
|
|
job.terminate()
|
2023-02-28 15:19:54 -05:00
|
|
|
|
2023-02-02 10:06:23 -05:00
|
|
|
except SyncError as e:
|
2023-03-28 15:47:09 -04:00
|
|
|
job.terminate(status=JobStatusChoices.STATUS_ERRORED)
|
2023-02-02 10:06:23 -05:00
|
|
|
DataSource.objects.filter(pk=datasource.pk).update(status=DataSourceStatusChoices.FAILED)
|
|
|
|
logging.error(e)
|