update tasks
This commit is contained in:
@@ -1,42 +1,8 @@
|
||||
from __future__ import absolute_import, unicode_literals
|
||||
from celery import shared_task
|
||||
from . import models
|
||||
from datetime import datetime
|
||||
from . import utils
|
||||
from billard import utils
|
||||
|
||||
|
||||
@shared_task
|
||||
def process_location_data():
|
||||
data = models.LocationData.objects.filter(processed=False)
|
||||
for ld in data:
|
||||
cli = models.Client.objects.filter(uuid=ld.location_id)
|
||||
if cli.count() < 1:
|
||||
ld.processed = True
|
||||
ld.error_msg = 'No location object found. Stopp processing!'
|
||||
ld.save()
|
||||
# TODO Send error eMail to Admin
|
||||
else:
|
||||
cli = cli[0]
|
||||
ac = models.Accounting.objects.filter(client=cli, desk_no=ld.table_no).order_by('time_from').reverse()
|
||||
if ld.on_off:
|
||||
if ac.count() > 0 and ac[0].time_to is None:
|
||||
ac[0].time_to = datetime.now()
|
||||
ac[0].save()
|
||||
# TODO Send error eMail to Admin
|
||||
acc = models.Accounting(
|
||||
client=cli,
|
||||
desk_no=ld.table_no,
|
||||
time_from=ld.tst,
|
||||
)
|
||||
acc.save()
|
||||
ld.delete()
|
||||
else:
|
||||
acc = ac[0]
|
||||
acc.time_to = ld.tst
|
||||
acc.prize = utils.get_prize_for(
|
||||
start=acc.time_from,
|
||||
end=ld.tst,
|
||||
pph=cli.desk1_prize_ht
|
||||
)
|
||||
acc.save()
|
||||
ld.delete()
|
||||
utils.process_location_data()
|
||||
|
||||
Reference in New Issue
Block a user