mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-29 16:03:21 +00:00
201 lines
8.0 KiB
Python
201 lines
8.0 KiB
Python
from django.conf import settings
|
|
from django.views.decorators.csrf import csrf_exempt
|
|
from rest_framework.decorators import api_view
|
|
from rest_framework.response import Response
|
|
from rest_framework import status
|
|
import jwt
|
|
import datetime
|
|
import requests
|
|
from Establishment.models import Establishment
|
|
|
|
@csrf_exempt
|
|
@api_view(['POST'])
|
|
def generate_jwt_token(request):
|
|
# Récupérer l'établissement concerné (par ID ou autre info transmise)
|
|
establishment_id = request.data.get('establishment_id')
|
|
if not establishment_id:
|
|
return Response({'error': 'establishment_id requis'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
try:
|
|
establishment = Establishment.objects.get(id=establishment_id)
|
|
except Establishment.DoesNotExist:
|
|
return Response({'error': "Établissement introuvable"}, status=status.HTTP_404_NOT_FOUND)
|
|
|
|
# Vérifier la clé API reçue dans le header
|
|
api_key = request.headers.get('X-Auth-Token')
|
|
if not api_key or not establishment.api_docuseal or api_key != establishment.api_docuseal:
|
|
return Response({'error': 'Clé API invalide'}, status=status.HTTP_401_UNAUTHORIZED)
|
|
|
|
# Récupérer les données de la requête
|
|
user_email = request.data.get('user_email')
|
|
documents_urls = request.data.get('documents_urls', [])
|
|
template_id = request.data.get('id')
|
|
|
|
if not user_email:
|
|
return Response({'error': 'User email is required'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
# Utiliser la clé API de l'établissement comme secret JWT
|
|
jwt_secret = establishment.api_docuseal
|
|
jwt_algorithm = settings.DOCUSEAL_JWT['ALGORITHM']
|
|
expiration_delta = settings.DOCUSEAL_JWT['EXPIRATION_DELTA']
|
|
|
|
payload = {
|
|
'user_email': user_email,
|
|
'documents_urls': documents_urls,
|
|
'template_id': template_id,
|
|
'exp': datetime.datetime.utcnow() + expiration_delta
|
|
}
|
|
|
|
token = jwt.encode(payload, jwt_secret, algorithm=jwt_algorithm)
|
|
return Response({'token': token}, status=status.HTTP_200_OK)
|
|
|
|
@csrf_exempt
|
|
@api_view(['POST'])
|
|
def clone_template(request):
|
|
# Récupérer l'établissement concerné
|
|
establishment_id = request.data.get('establishment_id')
|
|
print(f"establishment_id : {establishment_id}")
|
|
if not establishment_id:
|
|
return Response({'error': 'establishment_id requis'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
try:
|
|
establishment = Establishment.objects.get(id=establishment_id)
|
|
except Establishment.DoesNotExist:
|
|
return Response({'error': "Établissement introuvable"}, status=status.HTTP_404_NOT_FOUND)
|
|
|
|
# Vérifier la clé API reçue dans le header
|
|
api_key = request.headers.get('X-Auth-Token')
|
|
if not api_key or not establishment.api_docuseal or api_key != establishment.api_docuseal:
|
|
return Response({'error': 'Clé API invalide'}, status=status.HTTP_401_UNAUTHORIZED)
|
|
|
|
# Récupérer les données de la requête
|
|
document_id = request.data.get('templateId')
|
|
email = request.data.get('email')
|
|
is_required = request.data.get('is_required')
|
|
|
|
# Vérifier les données requises
|
|
if not document_id:
|
|
return Response({'error': 'template ID is required'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
# URL de l'API de DocuSeal pour cloner le template
|
|
clone_url = f'https://docuseal.com/api/templates/{document_id}/clone'
|
|
|
|
# Faire la requête pour cloner le template
|
|
try:
|
|
response = requests.post(clone_url, headers={
|
|
'Content-Type': 'application/json',
|
|
'X-Auth-Token': establishment.api_docuseal
|
|
})
|
|
|
|
if response.status_code != status.HTTP_200_OK:
|
|
return Response({'error': 'Failed to clone template'}, status=response.status_code)
|
|
|
|
data = response.json()
|
|
|
|
if is_required:
|
|
# URL de l'API de DocuSeal pour créer une submission
|
|
submission_url = f'https://docuseal.com/api/submissions'
|
|
|
|
try:
|
|
clone_id = data['id']
|
|
response = requests.post(submission_url, json={
|
|
'template_id': clone_id,
|
|
'send_email': False,
|
|
'submitters': [{'email': email}]
|
|
}, headers={
|
|
'Content-Type': 'application/json',
|
|
'X-Auth-Token': establishment.api_docuseal
|
|
})
|
|
|
|
if response.status_code != status.HTTP_200_OK:
|
|
return Response({'error': 'Failed to create submission'}, status=response.status_code)
|
|
|
|
data = response.json()
|
|
data[0]['id'] = clone_id
|
|
return Response(data[0], status=status.HTTP_200_OK)
|
|
|
|
except requests.RequestException as e:
|
|
return Response({'error': str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
|
|
else:
|
|
print(f'NOT REQUIRED -> on ne crée pas de submission')
|
|
return Response(data, status=status.HTTP_200_OK)
|
|
|
|
except requests.RequestException as e:
|
|
return Response({'error': str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
|
|
|
|
@csrf_exempt
|
|
@api_view(['DELETE'])
|
|
def remove_template(request, id):
|
|
# Récupérer l'établissement concerné
|
|
establishment_id = request.GET.get('establishment_id')
|
|
if not establishment_id:
|
|
return Response({'error': 'establishment_id requis'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
try:
|
|
establishment = Establishment.objects.get(id=establishment_id)
|
|
except Establishment.DoesNotExist:
|
|
return Response({'error': "Établissement introuvable"}, status=status.HTTP_404_NOT_FOUND)
|
|
|
|
# Vérifier la clé API reçue dans le header
|
|
api_key = request.headers.get('X-Auth-Token')
|
|
if not api_key or not establishment.api_docuseal or api_key != establishment.api_docuseal:
|
|
return Response({'error': 'Clé API invalide'}, status=status.HTTP_401_UNAUTHORIZED)
|
|
|
|
# URL de l'API de DocuSeal pour supprimer le template
|
|
|
|
clone_url = f'https://docuseal.com/api/templates/{id}'
|
|
|
|
try:
|
|
response = requests.delete(clone_url, headers={
|
|
'X-Auth-Token': establishment.api_docuseal
|
|
})
|
|
|
|
if response.status_code != status.HTTP_200_OK:
|
|
return Response({'error': 'Failed to remove template'}, status=response.status_code)
|
|
|
|
data = response.json()
|
|
return Response(data, status=status.HTTP_200_OK)
|
|
|
|
except requests.RequestException as e:
|
|
return Response({'error': str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
|
|
|
|
@csrf_exempt
|
|
@api_view(['GET'])
|
|
def download_template(request, slug):
|
|
# Récupérer l'établissement concerné
|
|
establishment_id = request.GET.get('establishment_id')
|
|
if not establishment_id:
|
|
return Response({'error': 'establishment_id requis'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
try:
|
|
establishment = Establishment.objects.get(id=establishment_id)
|
|
except Establishment.DoesNotExist:
|
|
return Response({'error': "Établissement introuvable"}, status=status.HTTP_404_NOT_FOUND)
|
|
|
|
# Vérifier la clé API reçue dans le header
|
|
api_key = request.headers.get('X-Auth-Token')
|
|
if not api_key or not establishment.api_docuseal or api_key != establishment.api_docuseal:
|
|
return Response({'error': 'Clé API invalide'}, status=status.HTTP_401_UNAUTHORIZED)
|
|
|
|
# Vérifier les données requises
|
|
if not slug:
|
|
return Response({'error': 'slug is required'}, status=status.HTTP_400_BAD_REQUEST)
|
|
|
|
# URL de l'API de DocuSeal pour télécharger le template
|
|
download_url = f'https://docuseal.com/submitters/{slug}/download'
|
|
|
|
try:
|
|
response = requests.get(download_url, headers={
|
|
'Content-Type': 'application/json',
|
|
'X-Auth-Token': establishment.api_docuseal
|
|
})
|
|
|
|
if response.status_code != status.HTTP_200_OK:
|
|
return Response({'error': 'Failed to download template'}, status=response.status_code)
|
|
|
|
data = response.json()
|
|
return Response(data, status=status.HTTP_200_OK)
|
|
|
|
except requests.RequestException as e:
|
|
return Response({'error': str(e)}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
|