2024-07-10 10:18:29 -03:00
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
from backup.models import BackupProfile
|
|
|
|
from router_manager.models import Router, SSHKey, SUPPORTED_ROUTER_TYPES, RouterGroup
|
|
|
|
import uuid
|
|
|
|
|
|
|
|
|
|
|
|
class CsvData(models.Model):
|
|
|
|
raw_csv_data = models.TextField()
|
|
|
|
import_data = models.JSONField(blank=True, null=True)
|
|
|
|
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
|
|
updated = models.DateTimeField(auto_now=True)
|
|
|
|
uuid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True)
|
|
|
|
|
|
|
|
def __str__(self):
|
2024-07-10 16:53:55 -03:00
|
|
|
return str(self.id)
|
2024-07-10 10:18:29 -03:00
|
|
|
|
|
|
|
|
|
|
|
class ImportTask(models.Model):
|
|
|
|
csv_data = models.ForeignKey(CsvData, on_delete=models.CASCADE)
|
2024-07-10 16:53:55 -03:00
|
|
|
import_id = models.IntegerField(default=0)
|
2024-07-10 10:18:29 -03:00
|
|
|
router = models.ForeignKey(Router, on_delete=models.SET_NULL, blank=True, null=True)
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
ssh_key = models.ForeignKey(SSHKey, on_delete=models.SET_NULL, blank=True, null=True)
|
2024-07-10 11:32:51 -03:00
|
|
|
ssh_key_name = models.CharField(max_length=100, blank=True, null=True)
|
2024-07-10 10:18:29 -03:00
|
|
|
username = models.CharField(max_length=100)
|
|
|
|
password = models.CharField(max_length=100, blank=True, null=True)
|
|
|
|
router_group = models.ForeignKey(RouterGroup, on_delete=models.SET_NULL, blank=True, null=True)
|
2024-07-10 11:32:51 -03:00
|
|
|
router_group_name = models.CharField(max_length=100, blank=True, null=True)
|
2024-07-10 10:18:29 -03:00
|
|
|
address = models.CharField(max_length=100)
|
|
|
|
port = models.IntegerField(default=22)
|
|
|
|
backup_profile = models.ForeignKey(BackupProfile, on_delete=models.SET_NULL, blank=True, null=True)
|
2024-07-10 11:32:51 -03:00
|
|
|
backup_profile_name = models.CharField(max_length=100, blank=True, null=True)
|
2024-07-10 10:18:29 -03:00
|
|
|
router_type = models.CharField(max_length=100, choices=SUPPORTED_ROUTER_TYPES)
|
|
|
|
monitoring = models.BooleanField(default=True)
|
|
|
|
|
|
|
|
import_success = models.BooleanField(default=False)
|
|
|
|
import_error = models.BooleanField(default=False)
|
|
|
|
import_error_message = models.TextField(blank=True, null=True)
|
|
|
|
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
|
|
updated = models.DateTimeField(auto_now=True)
|
|
|
|
uuid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
2024-07-10 16:53:55 -03:00
|
|
|
class Meta:
|
|
|
|
unique_together = ['csv_data', 'import_id']
|