mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-22 06:01:35 +00:00
77 lines
5.1 KiB
Python
Executable File
77 lines
5.1 KiB
Python
Executable File
from django.db import models
|
|
from django.utils import timezone
|
|
|
|
class AccountingDay(models.Model):
|
|
day = models.DateTimeField(primary_key=True, auto_now=False, auto_now_add=False)
|
|
|
|
# Every field is denominated in Sats with (3 decimals for millisats)
|
|
# Total volume contracted
|
|
contracted = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Number of contracts
|
|
num_contracts = models.BigIntegerField(default=0, null=False, blank=False)
|
|
# Net volume of trading invoices settled (excludes disputes)
|
|
net_settled = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Net volume of trading invoices paid (excludes rewards and disputes)
|
|
net_paid = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Sum of net settled and net paid
|
|
net_balance = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total volume of invoices settled
|
|
inflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total volume of invoices paid
|
|
outflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total cost in routing fees
|
|
routing_fees = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total inflows minus outflows and routing fees
|
|
cashflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance on earned rewards (referral rewards, slashed bonds and solved disputes)
|
|
outstanding_earned_rewards = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance on pending disputes (not resolved yet)
|
|
outstanding_pending_disputes = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Rewards claimed lifetime
|
|
lifetime_rewards_claimed = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance change from last day on earned rewards (referral rewards, slashed bonds and solved disputes)
|
|
earned_rewards = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance change on pending disputes (not resolved yet)
|
|
disputes = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Rewards claimed on day
|
|
rewards_claimed = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
|
|
|
|
|
|
class AccountingMonth(models.Model):
|
|
month = models.DateTimeField(primary_key=True, auto_now=False, auto_now_add=False)
|
|
|
|
# Every field is denominated in Sats with (3 decimals for millisats)
|
|
# Total volume contracted
|
|
contracted = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Number of contracts
|
|
num_contracts = models.BigIntegerField(default=0, null=False, blank=False)
|
|
# Net volume of trading invoices settled (excludes disputes)
|
|
net_settled = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Net volume of trading invoices paid (excludes rewards and disputes)
|
|
net_paid = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Sum of net settled and net paid
|
|
net_balance = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total volume of invoices settled
|
|
inflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total volume of invoices paid
|
|
outflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total cost in routing fees
|
|
routing_fees = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Total inflows minus outflows and routing fees
|
|
cashflow = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance on earned rewards (referral rewards, slashed bonds and solved disputes)
|
|
outstanding_earned_rewards = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance on pending disputes (not resolved yet)
|
|
outstanding_pending_disputes = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Rewards claimed lifetime
|
|
lifetime_rewards_claimed = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance change from last day on earned rewards (referral rewards, slashed bonds and solved disputes)
|
|
earned_rewards = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Balance change on pending disputes (not resolved yet)
|
|
pending_disputes = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
# Rewards claimed on day
|
|
rewards_claimed = models.DecimalField(max_digits=15, decimal_places=3, default=0, null=False, blank=False)
|
|
|
|
class Dispute(models.Model):
|
|
pass |