toulouse-maelis: add endpoint to read basket (#73961)
This commit is contained in:
parent
39164f0467
commit
a1f8ec9841
|
@ -556,6 +556,17 @@ class ToulouseMaelis(BaseResource, HTTPResource):
|
|||
data = serialize_object(response)
|
||||
return data
|
||||
|
||||
def get_basket_raw(self, family_id):
|
||||
response = self.call(
|
||||
'Activity',
|
||||
'getFamilyBasket',
|
||||
getFamilyBasketRequestBean={
|
||||
'numFamily': family_id,
|
||||
},
|
||||
)
|
||||
data = serialize_object(response)
|
||||
return data
|
||||
|
||||
@endpoint(
|
||||
display_category='Famille',
|
||||
description='Liste des catégories',
|
||||
|
@ -2636,6 +2647,20 @@ class ToulouseMaelis(BaseResource, HTTPResource):
|
|||
},
|
||||
}
|
||||
|
||||
@endpoint(
|
||||
display_category='Inscriptions',
|
||||
description="Lecture du pannier de la famille",
|
||||
name='get-basket',
|
||||
perm='can_access',
|
||||
parameters={
|
||||
'NameID': {'description': 'Publik NameID'},
|
||||
'family_id': {'description': 'Numéro de DUI'},
|
||||
},
|
||||
)
|
||||
def get_basket(self, request, NameID=None, family_id=None):
|
||||
family_id = family_id or self.get_link(NameID).family_id
|
||||
return {'data': self.get_basket_raw(family_id)}
|
||||
|
||||
|
||||
class Link(models.Model):
|
||||
resource = models.ForeignKey(ToulouseMaelis, on_delete=models.CASCADE)
|
||||
|
|
|
@ -0,0 +1,97 @@
|
|||
<?xml version="1.0" encoding="utf8"?>
|
||||
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
|
||||
<soap:Body>
|
||||
<ns2:getFamilyBasketResponse xmlns:ns2="activity.ws.maelis.sigec.com" xmlns:ns3="bean.persistence.activity.ws.maelis.sigec.com" xmlns:ns4="bean.persistence.school.ws.maelis.sigec.com">
|
||||
<getFamilyBasketResultBean>
|
||||
<basket>
|
||||
<dateAdd>2023-01-28T23:56:23+01:00</dateAdd>
|
||||
<dateMaj>2023-01-28T23:56:23+01:00</dateMaj>
|
||||
<delai>0</delai>
|
||||
<id>S10053200723</id>
|
||||
<idFam>S10053183425</idFam>
|
||||
<lignes>
|
||||
<dateMaj>2023-01-28T23:56:23+01:00</dateMaj>
|
||||
<id>S10053203120</id>
|
||||
<idIns>S10053203118</idIns>
|
||||
<idInsLieu>S10053203119</idInsLieu>
|
||||
<idPanier>S10053200723</idPanier>
|
||||
<inscription>
|
||||
<dateDeb>2023-02-20T00:00:00+01:00</dateDeb>
|
||||
<dateFin>2023-02-24T00:00:00+01:00</dateFin>
|
||||
<idAct>A10053187065</idAct>
|
||||
<idInsAct>S10053203118</idInsAct>
|
||||
<idInsLieu>S10053203119</idInsLieu>
|
||||
<idLieu>A10053179604</idLieu>
|
||||
<idRegie>A10049327667</idRegie>
|
||||
<idUnit>A10053187085</idUnit>
|
||||
<libAct>Vacances Hivers 2023</libAct>
|
||||
<libLieu>ALEX JANY</libLieu>
|
||||
<libUnit>Semaine 1</libUnit>
|
||||
</inscription>
|
||||
<personneInfo>
|
||||
<dateBirth>2014-04-01T00:00:00+02:00</dateBirth>
|
||||
<firstname>BART</firstname>
|
||||
<lastname>NICO</lastname>
|
||||
<numPerson>246711</numPerson>
|
||||
<sexe>M</sexe>
|
||||
</personneInfo>
|
||||
</lignes>
|
||||
<lignes>
|
||||
<dateMaj>2023-01-28T23:50:34+01:00</dateMaj>
|
||||
<id>S10053203105</id>
|
||||
<idIns>S10053203103</idIns>
|
||||
<idInsLieu>S10053203104</idInsLieu>
|
||||
<idPanier>S10053200723</idPanier>
|
||||
<inscription>
|
||||
<dateDeb>2023-02-01T00:00:00+01:00</dateDeb>
|
||||
<dateFin>2023-06-30T00:00:00+02:00</dateFin>
|
||||
<idAct>A10051141965</idAct>
|
||||
<idInsAct>S10053203103</idInsAct>
|
||||
<idInsLieu>S10053203104</idInsLieu>
|
||||
<idLieu>A10053179226</idLieu>
|
||||
<idRegie>A10049327675</idRegie>
|
||||
<idUnit>A10051141970</idUnit>
|
||||
<libAct>Vitrail Fusing 1/2 Je Adultes 2022/2023 - Mardi 14h-17h</libAct>
|
||||
<libLieu>Centre Culturel ALBAN MINVILLE</libLieu>
|
||||
<libUnit>Inscription 2ème semestre</libUnit>
|
||||
</inscription>
|
||||
<personneInfo>
|
||||
<dateBirth>2014-04-01T00:00:00+02:00</dateBirth>
|
||||
<firstname>BART</firstname>
|
||||
<lastname>NICO</lastname>
|
||||
<numPerson>246711</numPerson>
|
||||
<sexe>M</sexe>
|
||||
</personneInfo>
|
||||
</lignes>
|
||||
<lignes>
|
||||
<dateMaj>2023-01-26T17:39:40+01:00</dateMaj>
|
||||
<id>S10053200724</id>
|
||||
<idIns>S10053200721</idIns>
|
||||
<idInsLieu>S10053200722</idInsLieu>
|
||||
<idPanier>S10053200723</idPanier>
|
||||
<inscription>
|
||||
<dateDeb>2022-09-01T00:00:00+02:00</dateDeb>
|
||||
<dateFin>2023-08-31T00:00:00+02:00</dateFin>
|
||||
<idAct>A10051141965</idAct>
|
||||
<idInsAct>S10053200721</idInsAct>
|
||||
<idInsLieu>S10053200722</idInsLieu>
|
||||
<idLieu>A10053179226</idLieu>
|
||||
<idRegie>A10049327675</idRegie>
|
||||
<idUnit>A10051141990</idUnit>
|
||||
<libAct>Vitrail Fusing 1/2 Je Adultes 2022/2023 - Mardi 14h-17h</libAct>
|
||||
<libLieu>Centre Culturel ALBAN MINVILLE</libLieu>
|
||||
<libUnit>Inscription 1er semestre</libUnit>
|
||||
</inscription>
|
||||
<personneInfo>
|
||||
<dateBirth>2014-04-01T00:00:00+02:00</dateBirth>
|
||||
<firstname>BART</firstname>
|
||||
<lastname>NICO</lastname>
|
||||
<numPerson>246711</numPerson>
|
||||
<sexe>M</sexe>
|
||||
</personneInfo>
|
||||
</lignes>
|
||||
</basket>
|
||||
</getFamilyBasketResultBean>
|
||||
</ns2:getFamilyBasketResponse>
|
||||
</soap:Body>
|
||||
</soap:Envelope>
|
|
@ -5887,3 +5887,66 @@ def test_read_activity_list(con, app, freezer):
|
|||
},
|
||||
'err': 0,
|
||||
}
|
||||
|
||||
|
||||
def test_get_basket(activity_service, con, app):
|
||||
activity_service.add_soap_response('getFamilyBasket', get_xml_file('R_get_family_basket.xml'))
|
||||
url = get_endpoint('get-basket')
|
||||
|
||||
resp = app.get(url + '?family_id=311352')
|
||||
assert resp.json['err'] == 0
|
||||
Link.objects.create(resource=con, family_id='311352', name_id='local')
|
||||
|
||||
resp = app.get(url + '?NameID=local')
|
||||
assert resp.json['err'] == 0
|
||||
data = resp.json['data']
|
||||
assert len(data['lignes']) == 3
|
||||
del data['lignes'][2]
|
||||
del data['lignes'][1]
|
||||
assert data == {
|
||||
'dateAdd': '2023-01-28T23:56:23+01:00',
|
||||
'dateMaj': '2023-01-28T23:56:23+01:00',
|
||||
'delai': 0,
|
||||
'id': 'S10053200723',
|
||||
'idFam': 'S10053183425',
|
||||
'lignes': [
|
||||
{
|
||||
'datEchn': None,
|
||||
'dateMaj': '2023-01-28T23:56:23+01:00',
|
||||
'id': 'S10053203120',
|
||||
'idIns': 'S10053203118',
|
||||
'idInsLieu': 'S10053203119',
|
||||
'idPanier': 'S10053200723',
|
||||
'inscription': {
|
||||
'dateDeb': '2023-02-20T00:00:00+01:00',
|
||||
'dateFin': '2023-02-24T00:00:00+01:00',
|
||||
'idAct': 'A10053187065',
|
||||
'idInsAct': 'S10053203118',
|
||||
'idInsLieu': 'S10053203119',
|
||||
'idLieu': 'A10053179604',
|
||||
'idRegie': 'A10049327667',
|
||||
'idUnit': 'A10053187085',
|
||||
'libAct': 'Vacances Hivers 2023',
|
||||
'libLieu': 'ALEX JANY',
|
||||
'libUnit': 'Semaine 1',
|
||||
},
|
||||
'montant': None,
|
||||
'personneInfo': {
|
||||
'dateBirth': '2014-04-01T00:00:00+02:00',
|
||||
'firstname': 'BART',
|
||||
'lastname': 'NICO',
|
||||
'numPerson': 246711,
|
||||
'sexe': 'M',
|
||||
},
|
||||
'prixUnit': None,
|
||||
'qte': None,
|
||||
},
|
||||
],
|
||||
}
|
||||
|
||||
|
||||
def test_get_basket_not_linked_error(con, app):
|
||||
url = get_endpoint('get-basket')
|
||||
resp = app.get(url + '?NameID=local')
|
||||
assert resp.json['err'] == 'not-linked'
|
||||
assert resp.json['err_desc'] == 'User not linked to family'
|
||||
|
|
Loading…
Reference in New Issue