import random

from .base import FakeDataGenerator
from terminal.models import *


class StatGenerator(FakeDataGenerator):
    resource = 'stat'

    nodes = [
        {
            'node': 'guacamole-01',
            'ip': '192.168.1.1',
            'component': 'guacamole'
        },
        {
            'node': 'koko-01',
            'ip': '192.168.1.2',
            'component': 'koko'
        },
        {
            'node': 'omnidb-01',
            'ip': '192.168.1.3',
            'component': 'omnidb'
        },
        {
            'node': 'core-01',
            'ip': '192.168.1.4',
            'component': 'core'
        }
    ]
    items_value_range = {
        'cpu_load': (0, 3.0),
        'memory_used_percent': (20, 10.0),
        'disk_used_percent': (30, 80.0),
        'thread': (100, 100),
        'goroutine': (200, 500),
        'replay_upload_health': (0, [0, 1]),
        'command_upload_health': (0, [0, 1]),
        'session_active': (100, 50),
        'session_processed': (400, 400),
        'session_failed': (50, 100),
        'session_succeeded': (500, 300)
    }

    def do_generate(self, batch, batch_size):
        datetime = timezone.now()
        for i in batch:
            datetime = datetime - timezone.timedelta(minutes=1)
            items = []
            for node in self.nodes:
                for key, values in self.items_value_range.items():
                    base, r = values
                    if isinstance(r, int):
                        value = int(random.random() * r)
                    elif isinstance(r, float):
                        value = round(random.random() * r, 2)
                    elif isinstance(r, list):
                        value = random.choice(r)
                    else:
                        continue
                    value += base
                    node.update({
                        'key': key,
                        'value': value,
                        'datetime': datetime
                    })
                    items.append(Stat(**node))
            Stat.objects.bulk_create(items, ignore_conflicts=True)