49 lines
1.6 KiB
Python
49 lines
1.6 KiB
Python
from django.db import models
|
|
from user.models import User
|
|
import jsonfield
|
|
|
|
|
|
class Account(models.Model):
|
|
owner = models.ForeignKey(User, on_delete=models.CASCADE,
|
|
related_name="owned_accounts")
|
|
admin_users = models.ManyToManyField(User, related_name="admin_accounts",
|
|
blank=True)
|
|
view_users = models.ManyToManyField(User, related_name="view_accounts",
|
|
blank=True)
|
|
name = models.CharField(max_length=250)
|
|
|
|
def __str__(self):
|
|
return f"{self.owner}"
|
|
|
|
|
|
class Institution(models.Model):
|
|
name = models.CharField(max_length=255)
|
|
|
|
def __str__(self):
|
|
return f"{self.name}"
|
|
|
|
|
|
class Bank(models.Model):
|
|
qrtr_account = models.ForeignKey(Account, on_delete=models.CASCADE)
|
|
connection = models.ForeignKey('connection.Connection',
|
|
on_delete=models.CASCADE)
|
|
institution = models.ForeignKey(Institution, on_delete=models.CASCADE,
|
|
related_name="banks")
|
|
nickname = models.CharField(max_length=250)
|
|
balance = models.DecimalField(decimal_places=3, max_digits=100)
|
|
ac_type = models.CharField(max_length=250, blank=True)
|
|
ac_subtype = models.CharField(max_length=250, blank=True)
|
|
|
|
def __str__(self):
|
|
return f"{self.nickname}"
|
|
|
|
|
|
class Transaction(models.Model):
|
|
datetime = models.DateTimeField()
|
|
Bank = models.ForeignKey(Bank, on_delete=models.CASCADE,
|
|
related_name='transactions')
|
|
details = jsonfield.JSONField()
|
|
|
|
def __str__(self):
|
|
return f"{self.Bank} - {self.datetime}"
|