79 lines
2.3 KiB
Python
79 lines
2.3 KiB
Python
from django import forms
|
|
from django.conf import settings
|
|
from django.utils.translation import gettext_lazy as _
|
|
from idhub.models import DID, VerificableCredential
|
|
from oidc4vp.models import Organization
|
|
|
|
|
|
class RequestCredentialForm(forms.Form):
|
|
did = forms.ChoiceField(label=_("Did"), choices=[])
|
|
credential = forms.ChoiceField(label=_("Credential"), choices=[])
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
self.user = kwargs.pop('user', None)
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['did'].choices = [
|
|
(x.did, x.label) for x in DID.objects.filter(user=self.user)
|
|
]
|
|
self.fields['credential'].choices = [
|
|
(x.id, x.type()) for x in VerificableCredential.objects.filter(
|
|
user=self.user,
|
|
status=VerificableCredential.Status.ENABLED
|
|
)
|
|
]
|
|
|
|
def save(self, commit=True):
|
|
did = DID.objects.filter(
|
|
user=self.user,
|
|
did=self.data['did']
|
|
)
|
|
cred = VerificableCredential.objects.filter(
|
|
user=self.user,
|
|
id=self.data['credential'],
|
|
status=VerificableCredential.Status.ENABLED
|
|
)
|
|
if not all([cred.exists(), did.exists()]):
|
|
return
|
|
|
|
did = did[0]
|
|
cred = cred[0]
|
|
try:
|
|
cred.issue(did)
|
|
except Exception:
|
|
return
|
|
|
|
if commit:
|
|
cred.save()
|
|
return cred
|
|
|
|
return
|
|
|
|
|
|
class DemandAuthorizationForm(forms.Form):
|
|
organization = forms.ChoiceField(label=_("Organization"), choices=[])
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
self.user = kwargs.pop('user', None)
|
|
super().__init__(*args, **kwargs)
|
|
self.fields['organization'].choices = [
|
|
(x.id, x.name) for x in Organization.objects.filter()
|
|
if x.response_uri != settings.RESPONSE_URI
|
|
]
|
|
|
|
def save(self, commit=True):
|
|
self.org = Organization.objects.filter(
|
|
id=self.data['organization']
|
|
)
|
|
if not self.org.exists():
|
|
return
|
|
|
|
self.org = self.org[0]
|
|
|
|
if commit:
|
|
url = self.org.demand_authorization()
|
|
if url.status_code == 200:
|
|
return url.json().get('redirect_uri')
|
|
|
|
return
|
|
|