2015-12-09 02:41:58 +00:00
|
|
|
from celery.utils.log import get_task_logger
|
2016-02-03 22:09:11 +00:00
|
|
|
|
2016-02-04 17:31:58 +00:00
|
|
|
from ogn.model import Device, AddressOrigin
|
|
|
|
from ogn.utils import get_ddb
|
2016-02-03 22:09:11 +00:00
|
|
|
|
2015-12-09 02:41:58 +00:00
|
|
|
from ogn.collect.celery import app
|
|
|
|
|
2016-02-03 22:09:11 +00:00
|
|
|
|
2015-12-09 02:41:58 +00:00
|
|
|
logger = get_task_logger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
def update_devices(session, origin, devices):
|
|
|
|
session.query(Device) \
|
|
|
|
.filter(Device.address_origin == origin) \
|
|
|
|
.delete()
|
|
|
|
|
|
|
|
session.bulk_save_objects(devices)
|
|
|
|
session.commit()
|
|
|
|
|
|
|
|
return len(devices)
|
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def import_ddb():
|
|
|
|
"""Import registered devices from the DDB."""
|
|
|
|
|
|
|
|
logger.info("Import registered devices fom the DDB...")
|
|
|
|
counter = update_devices(app.session, AddressOrigin.ogn_ddb, get_ddb())
|
2016-02-03 22:19:25 +00:00
|
|
|
logger.info("Imported {} devices.".format(counter))
|
2015-12-09 02:41:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
@app.task
|
|
|
|
def import_file(path='tests/custom_ddb.txt'):
|
|
|
|
"""Import registered devices from a local file."""
|
|
|
|
|
|
|
|
logger.info("Import registered devices from '{}'...".format(path))
|
|
|
|
counter = update_devices(app.session, AddressOrigin.user_defined, get_ddb(path))
|
2016-02-03 22:19:25 +00:00
|
|
|
logger.info("Imported {} devices.".format(counter))
|