summaryrefslogtreecommitdiff
path: root/ishtar_common/management/commands/migrate_find_container_v4_2.py
blob: ec0d8489ee36b5b04a7ba367b07fc7ccf464604e (plain)
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#!/usr/bin/env python
# -*- coding: utf-8 -*-

import csv
import datetime
import os
import sys

from django.conf import settings
from django.core.management.base import BaseCommand
from django.db.models import Q

from ishtar_common.utils import get_log_time, get_percent, get_eta, BColors
from archaeological_finds.models_finds import Find, FindTreatment

log_path = os.sep.join([settings.ROOT_PATH, "logs"])
if not os.path.exists(log_path):
    os.mkdir(log_path, mode=0o770)


def write_output(base_lbl, idx, total, ref_time):
    lbl = f"\r{BColors.OKBLUE}[{get_percent(idx, total)}] {base_lbl} {idx + 1}/{total}"
    lbl += f" ({get_eta(idx, total, ref_time, datetime.datetime.now())} left){BColors.ENDC}"
    sys.stdout.write(lbl)
    sys.stdout.flush()


def migrate(log=True):
    errors = []
    changed = []
    if not quiet:
        sys.stdout.write(
            f"{BColors.OKGREEN}\r[{get_log_time()}] Set initial location for finds\n{BColors.ENDC}"
        )

    q = Find.objects.filter(Q(container__isnull=False) | Q(container_ref__isnull=False)).filter(
        container_fisrt_full_location=""
    )
    total = q.count()
    ref_time = datetime.datetime.now()
    base_lbl = "Migrate find"
    for idx, find in enumerate(q):
        if not quiet:
            write_output(base_lbl, idx, total, ref_time)
        if find.update_full_location():
            changed.append(("Find", str(find), find.pk))
            find.no_post_process()
            find.save()

    if not quiet:
        sys.stdout.write(
            f"\r{BColors.OKGREEN}[{get_log_time()}] Set initial location for packaging treatment\n{BColors.ENDC}"
        )
    q = FindTreatment.objects
    total = q.count()
    ref_time = datetime.datetime.now()
    base_lbl = "Migrate treatment"
    for idx, treatment in enumerate(q.all()):
        if not quiet:
            write_output(base_lbl, idx, total, ref_time)
        if treatment.generate_full_location():
            changed.append(("Treatment", "-", treatment.pk))
            treatment.save()


    if log and changed:
        filename = f"init_find_container_historic-{get_log_time().replace(':', '')}.csv"
        path = os.sep.join([log_path, filename])
        with open(path, "w+") as fle:
            writer = csv.writer(fle)
            writer.writerow(["model", "name", "id"])
            for change in changed:
                writer.writerow(change)
        if not quiet:
            sys.stdout.write(f"\n[{get_log_time()}] Log: {path} written\n")
    return errors


class Command(BaseCommand):
    help = "v4.2 - initialize find container historic"

    def add_arguments(self, parser):
        parser.add_argument(
            "--quiet", dest="quiet", action="store_true", help="Quiet output"
        )
        parser.add_argument(
            "--log", dest="log", action="store_false", help="Log into a file"
        )

    def handle(self, *args, **options):
        log = options["log"]
        global quiet
        quiet = options["quiet"]
        if not quiet:
            sys.stdout.write(f"{BColors.OKGREEN}[{get_log_time()}] Processing migration\n{BColors.ENDC}")
        settings.USE_BACKGROUND_TASK = False
        errors = migrate(log=log)
        if not errors:
            if not quiet:
                sys.stdout.write(f"{BColors.OKGREEN}[{get_log_time()}] Migration finished\n{BColors.ENDC}")
            sys.exit()
        if not quiet:
            sys.stdout.write("\n".join(errors))
        sys.exit(1)