toulouse_maelis: add PAI webservice (#69045)

This commit is contained in:
Nicolas Roche 2022-09-11 17:06:01 +02:00
parent 50dda588ce
commit c8097f4b2d
6 changed files with 131 additions and 3 deletions

View File

@ -153,6 +153,7 @@ class ToulouseMaelis(BaseResource, HTTPResource):
for child in data['childList']:
add_text_value('Sex', child, ['sexe'])
add_text_value('DietCode', child, ['dietcode'])
add_text_value('PAI', child, ['paiInfoBean', 'code'])
for kind in ('authorized', 'emergency'):
for person in data[kind + 'PersonList']:
add_text_value('Civility', person, ['civility'])
@ -758,6 +759,28 @@ class ToulouseMaelis(BaseResource, HTTPResource):
self.call('Family', 'createOrUpdateChildDiet', personNumber=child_id, code=dietcode)
return {'data': 'ok'}
@endpoint(
display_category='Famille',
description="Créer ou mettre à jour les informations relatives au PAI d'un enfant",
name='update-child-pai',
perm='can_access',
parameters={
'NameID': {'description': 'Publik NameID'},
'child_id': {'description': "Numéro de l'enfant"},
},
post={'request_body': {'schema': {'application/json': schemas.PAIINFO_SCHEMA}}},
)
def update_child_pai(self, request, NameID, child_id, post_data):
self.get_link(NameID)
# use None to empty date passed as an empty string by date filter
for key in 'dateDeb', 'dateFin':
if post_data[key] == '':
post_data[key] = None
self.call('Family', 'updateChildPAI', personNumber=child_id, **post_data)
return {'data': 'ok'}
class Link(models.Model):
resource = models.ForeignKey(ToulouseMaelis, on_delete=models.CASCADE)

View File

@ -459,20 +459,21 @@ PAIINFO_SCHEMA = {
{'type': 'null'},
{
'type': 'object',
'required': ['code'],
'properties': {
'code': {
'description': 'Code',
'oneOf': [{'type': 'null'}, {'type': 'string'}],
'type': 'string',
},
'dateDeb': {
'description': 'Date de début',
'type': 'string',
'pattern': '^[0-9]{4}-[0-9]{2}-[0-9]{2}$',
'pattern': '^([0-9]{4}-[0-9]{2}-[0-9]{2}){0,1}$',
},
'dateFin': {
'description': 'Date de fin',
'type': 'string',
'pattern': '^[0-9]{4}-[0-9]{2}-[0-9]{2}$',
'pattern': '^([0-9]{4}-[0-9]{2}-[0-9]{2}){0,1}$',
},
'description': {
'description': 'Texte libre de description (max 500 caractères)',

View File

@ -0,0 +1,18 @@
<soap-env:Envelope xmlns:soap-env="http://schemas.xmlsoap.org/soap/envelope/">
<soap-env:Header>
<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<wsse:UsernameToken>
<wsse:Username>maelis-webservice</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">maelis-password</wsse:Password>
</wsse:UsernameToken>
</wsse:Security>
</soap-env:Header>
<soap-env:Body>
<ns0:updateChildPAI xmlns:ns0="family.ws.maelis.sigec.com">
<personNumber>613878</personNumber>
<code>PAIALI</code>
<dateDeb>2022-01-01</dateDeb>
<description>some text</description>
</ns0:updateChildPAI>
</soap-env:Body>
</soap-env:Envelope>

View File

@ -0,0 +1,5 @@
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<ns2:updateChildPAIResponse xmlns:ns2="family.ws.maelis.sigec.com"/>
</soap:Body>
</soap:Envelope>

View File

@ -0,0 +1,15 @@
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<soap:Fault>
<faultcode>soap:Server</faultcode>
<faultstring>Une erreur est survenue : java.sql.SQLException: ORA-12899: valeur trop grande pour la colonne "MAELIS"."H_PERS"."ER_DESCPAI" (réelle : 800, maximum : 500)
</faultstring>
<detail>
<ns1:MaelisFamilyException xmlns:ns1="family.ws.maelis.sigec.com">
<message xmlns:ns2="family.ws.maelis.sigec.com">Une erreur est survenue : java.sql.SQLException: ORA-12899: valeur trop grande pour la colonne "MAELIS"."H_PERS"."ER_DESCPAI" (réelle : 800, maximum : 500)
</message>
</ns1:MaelisFamilyException>
</detail>
</soap:Fault>
</soap:Body>
</soap:Envelope>

View File

@ -68,6 +68,8 @@ UPDATE_FAMILY = FakedResponse(content=get_xml_file('R_update_family.xml'), statu
UPDATE_FAMILY_ERR = FakedResponse(content=get_xml_file('R_update_family_error.xml'), status_code=200)
UPDATE_FAMILY_500 = FakedResponse(content=get_xml_file('R_update_family_soap_error.xml'), status_code=500)
UPDATE_DIETCODE = FakedResponse(content=get_xml_file('R_update_child_dietcode.xml'), status_code=200)
UPDATE_PAI = FakedResponse(content=get_xml_file('R_update_child_pai.xml'), status_code=200)
UPDATE_PAI_500 = FakedResponse(content=get_xml_file('R_update_child_pai_soap_error.xml'), status_code=500)
def assert_sent_payload(mocked_post, query_file):
@ -527,6 +529,7 @@ def test_read_family(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-family')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -606,6 +609,7 @@ def test_read_family(mocked_post, mocked_get, con, app):
'subscribeActivityList': [],
'paiInfoBean': {
'code': 'PAIALI',
'code_text': 'ALIMENTAIRE',
'dateDeb': '2022-01-01T00:00:00+01:00',
'dateFin': '2022-12-31T00:00:00+01:00',
'description': 'bla bla PAI',
@ -691,6 +695,7 @@ def test_read_rl1(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-rl')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -712,6 +717,7 @@ def test_read_rl2(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-rl')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -776,6 +782,7 @@ def test_read_rl_not_found(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-rl')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -797,6 +804,7 @@ def test_read_person(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-person')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -834,6 +842,7 @@ def test_read_person_not_found(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-person')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -855,6 +864,7 @@ def test_read_child(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-child')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -884,6 +894,7 @@ def test_read_child_not_found(mocked_post, mocked_get, con, app):
READ_QUALITIES,
READ_CSP,
READ_DIETCODE,
READ_PAI,
]
url = get_endpoint('read-child')
Link.objects.create(resource=con, family_id='1312', name_id='local')
@ -1842,3 +1853,58 @@ def test_update_child_dietcode_not_linked_error(con, app):
resp = app.post_json(url + '?NameID=local&child_id=613878&dietcode=RVS')
assert resp.json['err'] == 'not-linked'
assert resp.json['err_desc'] == 'User not linked to family'
@mock.patch('passerelle.utils.Request.get')
@mock.patch('passerelle.utils.Request.post')
def test_update_child_pai(mocked_post, mocked_get, con, app):
mocked_get.return_value = FAMILY_SERVICE_WSDL
mocked_post.return_value = UPDATE_PAI
url = get_endpoint('update-child-pai')
params = {
'code': 'PAIALI',
'dateDeb': '2022-01-01',
'dateFin': '',
'description': 'some text',
}
Link.objects.create(resource=con, family_id='1312', name_id='local')
resp = app.post_json(url + '?NameID=local&child_id=613878', params=params)
assert_sent_payload(mocked_post, 'Q_update_child_pai.xml')
assert resp.json['err'] == 0
assert resp.json['data'] == 'ok'
def test_update_child_pai_not_linked_error(con, app):
url = get_endpoint('update-child-pai')
params = {
'code': 'PAIALI',
'dateDeb': '2022-01-01',
'dateFin': '',
'description': 'some text',
}
resp = app.post_json(url + '?NameID=local&child_id=613878', params=params)
assert resp.json['err'] == 'not-linked'
assert resp.json['err_desc'] == 'User not linked to family'
@mock.patch('passerelle.utils.Request.get')
@mock.patch('passerelle.utils.Request.post')
def test_update_child_pai_soap_error(mocked_post, mocked_get, con, app):
mocked_get.return_value = FAMILY_SERVICE_WSDL
mocked_post.return_value = UPDATE_PAI_500
url = get_endpoint('update-child-pai')
params = {
'code': 'PAIALI',
'dateDeb': '2022-01-01',
'dateFin': '',
'description': 'a' * 501,
}
Link.objects.create(resource=con, family_id='1312', name_id='local')
resp = app.post_json(url + '?NameID=local&child_id=613878', params=params)
assert resp.json['err'] == 'Family-updateChildPAI-soap:Server'
assert 'Une erreur est survenue' in resp.json['err_desc']
assert 'valeur trop grande' in resp.json['err_desc']
assert 'maximum : 500' in resp.json['err_desc']