|
|
@ -1,7 +1,7 @@
|
|
|
|
import asyncio
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from django.contrib.auth.mixins import LoginRequiredMixin
|
|
|
|
from django.contrib.auth.mixins import LoginRequiredMixin
|
|
|
|
from django.http import HttpResponse
|
|
|
|
from django.http import HttpResponse
|
|
|
|
|
|
|
|
from django.shortcuts import render
|
|
|
|
|
|
|
|
from django.urls import reverse
|
|
|
|
from django.views import View
|
|
|
|
from django.views import View
|
|
|
|
from mixins.views import (
|
|
|
|
from mixins.views import (
|
|
|
|
ObjectCreate,
|
|
|
|
ObjectCreate,
|
|
|
@ -16,25 +16,36 @@ from core.clients.aggregators.nordigen import NordigenClient
|
|
|
|
from core.forms import AggregatorForm
|
|
|
|
from core.forms import AggregatorForm
|
|
|
|
from core.models import Aggregator
|
|
|
|
from core.models import Aggregator
|
|
|
|
from core.util import logs
|
|
|
|
from core.util import logs
|
|
|
|
|
|
|
|
from core.views.helpers import synchronize_async_helper
|
|
|
|
|
|
|
|
|
|
|
|
log = logs.get_logger(__name__)
|
|
|
|
log = logs.get_logger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def synchronize_async_helper(to_await):
|
|
|
|
class RequestBankFetch(LoginRequiredMixin, OTPRequiredMixin, View):
|
|
|
|
async_response = []
|
|
|
|
template_name = "mixins/partials/notify.html"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get(self, request, pk=None):
|
|
|
|
|
|
|
|
if pk:
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
aggregators = [aggregator]
|
|
|
|
|
|
|
|
|
|
|
|
async def run_and_capture_result():
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
r = await to_await
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
async_response.append(r)
|
|
|
|
context = {
|
|
|
|
|
|
|
|
"message": message,
|
|
|
|
|
|
|
|
"class": "danger",
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
aggregators = Aggregator.objects.filter(user=self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
for agg in aggregators:
|
|
|
|
loop = asyncio.get_event_loop()
|
|
|
|
agg.fetch_accounts = True
|
|
|
|
except RuntimeError:
|
|
|
|
agg.save()
|
|
|
|
loop = asyncio.new_event_loop()
|
|
|
|
|
|
|
|
asyncio.set_event_loop(loop)
|
|
|
|
context = {"class": "success", "message": "Fetch requested"}
|
|
|
|
coroutine = run_and_capture_result()
|
|
|
|
return render(request, self.template_name, context)
|
|
|
|
loop.run_until_complete(coroutine)
|
|
|
|
|
|
|
|
return async_response[0]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ReqsList(LoginRequiredMixin, OTPRequiredMixin, ObjectList):
|
|
|
|
class ReqsList(LoginRequiredMixin, OTPRequiredMixin, ObjectList):
|
|
|
@ -52,7 +63,17 @@ class ReqsList(LoginRequiredMixin, OTPRequiredMixin, ObjectList):
|
|
|
|
|
|
|
|
|
|
|
|
def get_context_data(self):
|
|
|
|
def get_context_data(self):
|
|
|
|
context = super().get_context_data()
|
|
|
|
context = super().get_context_data()
|
|
|
|
context["pk"] = self.kwargs.get("pk")
|
|
|
|
pk = self.kwargs.get("pk")
|
|
|
|
|
|
|
|
context["pk"] = pk
|
|
|
|
|
|
|
|
self.extra_buttons = [
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
"url": reverse("bank_fetch", kwargs={"pk": pk}),
|
|
|
|
|
|
|
|
"action": "refresh",
|
|
|
|
|
|
|
|
"method": "get",
|
|
|
|
|
|
|
|
"label": "Fetch account details",
|
|
|
|
|
|
|
|
"icon": "fa-solid fa-refresh",
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
]
|
|
|
|
return context
|
|
|
|
return context
|
|
|
|
|
|
|
|
|
|
|
|
def get_queryset(self, **kwargs):
|
|
|
|
def get_queryset(self, **kwargs):
|
|
|
@ -61,18 +82,16 @@ class ReqsList(LoginRequiredMixin, OTPRequiredMixin, ObjectList):
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
|
self.page_title = (
|
|
|
|
self.page_title = (
|
|
|
|
f"Requisitions for {aggregator.name} ({aggregator.get_service_display()})"
|
|
|
|
f"Requisitions for {aggregator.name} ({aggregator.get_service_display()})"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
self.page_subtitle = f"Stored account details: {len(aggregator.currencies)}"
|
|
|
|
|
|
|
|
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|
reqs = synchronize_async_helper(run.get_requisitions())
|
|
|
|
reqs = synchronize_async_helper(run.get_requisitions())
|
|
|
@ -100,12 +119,9 @@ class AggregatorCountriesList(LoginRequiredMixin, OTPRequiredMixin, ObjectList):
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
@ -141,12 +157,9 @@ class AggregatorCountryBanksList(LoginRequiredMixin, OTPRequiredMixin, ObjectLis
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
|
|
@ -167,12 +180,9 @@ class AggregatorLinkBank(LoginRequiredMixin, OTPRequiredMixin, View):
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
@ -192,12 +202,9 @@ class ReqDelete(LoginRequiredMixin, OTPRequiredMixin, View):
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
@ -219,12 +226,9 @@ class ReqInfo(LoginRequiredMixin, OTPRequiredMixin, ObjectRead):
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
aggregator = Aggregator.get_by_id(pk, self.request.user)
|
|
|
|
|
|
|
|
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
except Aggregator.DoesNotExist:
|
|
|
|
message = "Aggregator does not exist"
|
|
|
|
|
|
|
|
message_class = "danger"
|
|
|
|
|
|
|
|
context = {
|
|
|
|
context = {
|
|
|
|
"message": message,
|
|
|
|
"message": "Aggregator does not exist",
|
|
|
|
"message_class": message_class,
|
|
|
|
"class": "danger",
|
|
|
|
"window_content": self.window_content,
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return self.render_to_response(context)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|
run = synchronize_async_helper(NordigenClient(aggregator))
|
|
|
|