DRY resources.aggregations
This commit is contained in:
parent
48a19d8be9
commit
63c9f381bc
2
TODO.md
2
TODO.md
|
@ -423,5 +423,3 @@ Colaesce('total', 'computed_total')
|
|||
Case
|
||||
|
||||
# case on payment transaction state ? case when trans.amount >
|
||||
|
||||
# Yield multiple values on historic filter on all aggregators
|
||||
|
|
|
@ -34,9 +34,8 @@ class Last(Aggregation):
|
|||
if date is not None:
|
||||
dataset = dataset.filter(created_at__lte=date)
|
||||
return dataset
|
||||
|
||||
def historic_filter(self, dataset):
|
||||
yield (timezone.now(), self.filter(dataset))
|
||||
|
||||
def monthly_historic_filter(self, dataset):
|
||||
now = timezone.now()
|
||||
date = datetime.datetime(
|
||||
year=now.year,
|
||||
|
@ -54,6 +53,10 @@ class Last(Aggregation):
|
|||
yield (date, dataset_copy)
|
||||
date -= relativedelta(months=1)
|
||||
|
||||
def historic_filter(self, dataset):
|
||||
yield (timezone.now(), self.filter(dataset))
|
||||
yield from self.monthly_historic_filter(dataset)
|
||||
|
||||
def compute_usage(self, dataset):
|
||||
values = dataset.values_list('value', flat=True)
|
||||
if values:
|
||||
|
@ -75,22 +78,7 @@ class MonthlySum(Last):
|
|||
)
|
||||
|
||||
def historic_filter(self, dataset):
|
||||
now = timezone.now()
|
||||
date = datetime.datetime(
|
||||
year=now.year,
|
||||
month=now.month,
|
||||
day=1,
|
||||
tzinfo=timezone.utc,
|
||||
)
|
||||
while True:
|
||||
dataset_copy = copy.copy(dataset)
|
||||
dataset_copy = self.filter(dataset_copy, date=date)
|
||||
try:
|
||||
dataset_copy[0]
|
||||
except IndexError:
|
||||
raise StopIteration
|
||||
yield (date, dataset_copy)
|
||||
date -= relativedelta(months=1)
|
||||
yield from self.monthly_historic_filter(dataset)
|
||||
|
||||
|
||||
class MonthlyAvg(MonthlySum):
|
||||
|
|
Loading…
Reference in New Issue