-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathmeasure_volumes.py
More file actions
30 lines (26 loc) · 1.1 KB
/
measure_volumes.py
File metadata and controls
30 lines (26 loc) · 1.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import uuid
import time
import logging
from django.utils import timezone
from django.core.management.base import BaseCommand
from django.conf import settings
from api.models.volume import Volume
from api.tasks import send_measurements
logger = logging.getLogger(__name__)
class Command(BaseCommand):
"""Management command for push data to manager"""
def handle(self, *args, **options):
if settings.WORKFLOW_MANAGER_URL:
timestamp = time.time()
task_id = uuid.uuid4().hex
logger.info(f"pushing {task_id} volumes to workflow_manager when {timezone.now()}")
volume_list = []
for volume in Volume.objects.all():
volume_list.extend(volume.to_measurements(timestamp))
if len(volume_list) % 1000 == 0:
send_measurements.delay(volume_list)
volume_list = []
if len(volume_list) > 0:
send_measurements.delay(volume_list)
logger.info(f"pushed {task_id} volumes to workflow_manager when {timezone.now()}")
self.stdout.write("done")