add minint_brexit connector
This commit is contained in:
parent
283dc82970
commit
29e2b7215e
|
@ -4,3 +4,6 @@ if 'passerelle_minint.minint_maarch' not in INSTALLED_APPS:
|
|||
if 'passerelle_minint.minint_seisin' not in INSTALLED_APPS:
|
||||
INSTALLED_APPS += ('passerelle_minint.minint_seisin',)
|
||||
TENANT_APPS += ('passerelle_minint.minint_seisin',)
|
||||
if 'passerelle_minint.minint_brexit' not in INSTALLED_APPS:
|
||||
INSTALLED_APPS += ('passerelle_minint.minint_brexit',)
|
||||
TENANT_APPS += ('passerelle_minint.minint_brexit',)
|
||||
|
|
|
@ -0,0 +1,31 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Generated by Django 1.11.18 on 2020-05-04 13:59
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
('base', '0018_smslog'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='Brexit',
|
||||
fields=[
|
||||
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('title', models.CharField(max_length=50, verbose_name='Title')),
|
||||
('slug', models.SlugField(unique=True, verbose_name='Identifier')),
|
||||
('description', models.TextField(verbose_name='Description')),
|
||||
('url', models.URLField(default=b'IP_INES/action', verbose_name=b'URL')),
|
||||
('users', models.ManyToManyField(blank=True, related_name='_brexit_users_+', related_query_name='+', to='base.ApiUser')),
|
||||
],
|
||||
options={
|
||||
'verbose_name': 'BREXIT - API REST vers MAARCH',
|
||||
},
|
||||
),
|
||||
]
|
|
@ -0,0 +1,73 @@
|
|||
# coding=utf-8
|
||||
import requests
|
||||
|
||||
from django.db import models
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from django.utils.http import urlquote
|
||||
|
||||
from passerelle.base.models import BaseResource
|
||||
from passerelle.utils.api import endpoint
|
||||
from passerelle.utils.jsonresponse import APIError, exception_to_text
|
||||
|
||||
|
||||
class Brexit(BaseResource):
|
||||
category = 'MinInt'
|
||||
api_description = "Ce connecteur permet de vérifier l'existence d'un dossier dans la GED Etranger utilisée pour le BREXIT."
|
||||
|
||||
url = models.URLField('URL', default='IP_INES/action')
|
||||
|
||||
class Meta:
|
||||
verbose_name = 'BREXIT - API REST vers MAARCH'
|
||||
|
||||
@endpoint()
|
||||
def info(self, request):
|
||||
return {'hello': 'world'}
|
||||
|
||||
@endpoint(parameters={
|
||||
'num': {'description': _('Num dossier'), 'example_value': '12345'},
|
||||
'email': {'description': _('Email associe au dossier'), 'example_value': 'franck@interieur.gouv.fr'},
|
||||
})
|
||||
def find_folder(self, request, num, email):
|
||||
|
||||
self.logger.info('MININT BREXIT - find_folder num: %s ; email : %s', num, email)
|
||||
|
||||
try:
|
||||
response = self.requests.get(self.url + '/%s/%s' % (num, email), verify=False)
|
||||
except requests.RequestException as e:
|
||||
raise APIError(u'API-maarch connection error: %s' %
|
||||
exception_to_text(e), data=[])
|
||||
try:
|
||||
data = response.json()
|
||||
except ValueError as e:
|
||||
content = repr(response.content[:1000])
|
||||
raise APIError(
|
||||
u'API-maarch returned non-JSON content with status %s: %s' %
|
||||
(response.status_code, content),
|
||||
data={
|
||||
'status_code': response.status_code,
|
||||
'exception': exception_to_text(e),
|
||||
'content': content,
|
||||
})
|
||||
if response.status_code != 200:
|
||||
if data.get('error') == 'not_found':
|
||||
return {
|
||||
'err': 1,
|
||||
'err_desc': data.get('message', 'not-found'),
|
||||
}
|
||||
raise APIError(
|
||||
u'API-maarch returned a non 200 status %s: %s' %
|
||||
(response.status_code, data),
|
||||
data={
|
||||
'status_code': response.status_code,
|
||||
'content': data,
|
||||
})
|
||||
document_id = data.get('res_id')
|
||||
if document_id is not None:
|
||||
data_response = {'res_id': document_id}
|
||||
else:
|
||||
data_response = {'res_id': 0, 'result': data.get('result'), 'msg': data.get('error')}
|
||||
return {
|
||||
'err': 0,
|
||||
'data': data_response,
|
||||
}
|
||||
|
|
@ -3,6 +3,7 @@ import os
|
|||
INSTALLED_APPS += (
|
||||
'passerelle_minint.minint_maarch',
|
||||
'passerelle_minint.minint_seisin',
|
||||
'passerelle_minint.minint_brexit',
|
||||
)
|
||||
|
||||
DATABASES = {
|
||||
|
|
|
@ -0,0 +1,7 @@
|
|||
import utils
|
||||
|
||||
from passerelle_minint.minint_brexit.models import Brexit
|
||||
|
||||
|
||||
def test_creation(app, db):
|
||||
resource = utils.make_resource(Brexit, url='https://example.com/', slug='brexit')
|
Loading…
Reference in New Issue