@tricoteuses/senat 3.0.2 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/src/ameli.d.ts +66 -0
- package/lib/src/ameli.js +1 -0
- package/lib/src/db_types/ameli.d.ts +1762 -0
- package/lib/src/db_types/ameli.js +1074 -0
- package/lib/src/db_types/debats.d.ts +380 -0
- package/lib/src/db_types/debats.js +266 -0
- package/lib/src/db_types/dosleg.d.ts +2954 -0
- package/lib/src/db_types/dosleg.js +2005 -0
- package/lib/src/db_types/questions.d.ts +699 -0
- package/lib/src/db_types/questions.js +493 -0
- package/lib/src/db_types/sens.d.ts +7843 -0
- package/lib/src/db_types/sens.js +4691 -0
- package/lib/src/debats.d.ts +38 -0
- package/lib/src/debats.js +1 -0
- package/lib/src/documents.d.ts +30 -0
- package/lib/src/documents.js +1 -0
- package/lib/src/dosleg.d.ts +142 -0
- package/lib/src/dosleg.js +193 -0
- package/lib/src/index.d.ts +41 -24
- package/lib/src/index.js +27 -6
- package/lib/src/kanel_types/ameli.d.ts +1762 -0
- package/lib/src/kanel_types/ameli.js +1074 -0
- package/lib/src/kanel_types/debats.d.ts +380 -0
- package/lib/src/kanel_types/debats.js +266 -0
- package/lib/src/kanel_types/dosleg.d.ts +2954 -0
- package/lib/src/kanel_types/dosleg.js +2005 -0
- package/lib/src/kanel_types/questions.d.ts +699 -0
- package/lib/src/kanel_types/questions.js +493 -0
- package/lib/src/kanel_types/sens.d.ts +7843 -0
- package/lib/src/kanel_types/sens.js +4691 -0
- package/lib/src/kysely/index.d.ts +216 -0
- package/lib/src/kysely/index.js +11 -0
- package/lib/src/kysely_types/ameli/Amd.d.ts +91 -0
- package/lib/src/kysely_types/ameli/Amd.js +3 -0
- package/lib/src/kysely_types/ameli/Amdsen.d.ts +24 -0
- package/lib/src/kysely_types/ameli/Amdsen.js +3 -0
- package/lib/src/kysely_types/ameli/Avicom.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Avicom.js +3 -0
- package/lib/src/kysely_types/ameli/Avigvt.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Avigvt.js +3 -0
- package/lib/src/kysely_types/ameli/Cab.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Cab.js +3 -0
- package/lib/src/kysely_types/ameli/ComAmeli.d.ts +22 -0
- package/lib/src/kysely_types/ameli/ComAmeli.js +3 -0
- package/lib/src/kysely_types/ameli/Database.d.ts +3 -0
- package/lib/src/kysely_types/ameli/Database.js +3 -0
- package/lib/src/kysely_types/ameli/Ent.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Ent.js +3 -0
- package/lib/src/kysely_types/ameli/Etatxt.d.ts +15 -0
- package/lib/src/kysely_types/ameli/Etatxt.js +3 -0
- package/lib/src/kysely_types/ameli/Fbu.d.ts +17 -0
- package/lib/src/kysely_types/ameli/Fbu.js +3 -0
- package/lib/src/kysely_types/ameli/GrppolAmeli.d.ts +20 -0
- package/lib/src/kysely_types/ameli/GrppolAmeli.js +3 -0
- package/lib/src/kysely_types/ameli/Gvt.d.ts +18 -0
- package/lib/src/kysely_types/ameli/Gvt.js +3 -0
- package/lib/src/kysely_types/ameli/Intora.d.ts +33 -0
- package/lib/src/kysely_types/ameli/Intora.js +3 -0
- package/lib/src/kysely_types/ameli/Irr.d.ts +21 -0
- package/lib/src/kysely_types/ameli/Irr.js +3 -0
- package/lib/src/kysely_types/ameli/LecAmeli.d.ts +14 -0
- package/lib/src/kysely_types/ameli/LecAmeli.js +3 -0
- package/lib/src/kysely_types/ameli/Mot.d.ts +20 -0
- package/lib/src/kysely_types/ameli/Mot.js +3 -0
- package/lib/src/kysely_types/ameli/Nat.d.ts +13 -0
- package/lib/src/kysely_types/ameli/Nat.js +3 -0
- package/lib/src/kysely_types/ameli/Orarol.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Orarol.js +3 -0
- package/lib/src/kysely_types/ameli/Sai.d.ts +25 -0
- package/lib/src/kysely_types/ameli/Sai.js +3 -0
- package/lib/src/kysely_types/ameli/Saisen.d.ts +15 -0
- package/lib/src/kysely_types/ameli/Saisen.js +3 -0
- package/lib/src/kysely_types/ameli/Sea.d.ts +17 -0
- package/lib/src/kysely_types/ameli/Sea.js +3 -0
- package/lib/src/kysely_types/ameli/SenAmeli.d.ts +36 -0
- package/lib/src/kysely_types/ameli/SenAmeli.js +3 -0
- package/lib/src/kysely_types/ameli/SenatSchema.d.ts +60 -0
- package/lib/src/kysely_types/ameli/SenatSchema.js +3 -0
- package/lib/src/kysely_types/ameli/Ses.d.ts +17 -0
- package/lib/src/kysely_types/ameli/Ses.js +3 -0
- package/lib/src/kysely_types/ameli/Sor.d.ts +16 -0
- package/lib/src/kysely_types/ameli/Sor.js +3 -0
- package/lib/src/kysely_types/ameli/Sub.d.ts +44 -0
- package/lib/src/kysely_types/ameli/Sub.js +3 -0
- package/lib/src/kysely_types/ameli/TxtAmeli.d.ts +77 -0
- package/lib/src/kysely_types/ameli/TxtAmeli.js +3 -0
- package/lib/src/kysely_types/ameli/Typrect.d.ts +14 -0
- package/lib/src/kysely_types/ameli/Typrect.js +3 -0
- package/lib/src/kysely_types/ameli/Typses.d.ts +12 -0
- package/lib/src/kysely_types/ameli/Typses.js +3 -0
- package/lib/src/kysely_types/ameli/Typsub.d.ts +12 -0
- package/lib/src/kysely_types/ameli/Typsub.js +3 -0
- package/lib/src/kysely_types/ameli/WNivrec.d.ts +12 -0
- package/lib/src/kysely_types/ameli/WNivrec.js +3 -0
- package/lib/src/kysely_types/debats/Database.d.ts +3 -0
- package/lib/src/kysely_types/debats/Database.js +3 -0
- package/lib/src/kysely_types/debats/Debats.d.ts +25 -0
- package/lib/src/kysely_types/debats/Debats.js +3 -0
- package/lib/src/kysely_types/debats/Intdivers.d.ts +22 -0
- package/lib/src/kysely_types/debats/Intdivers.js +3 -0
- package/lib/src/kysely_types/debats/Intpjl.d.ts +22 -0
- package/lib/src/kysely_types/debats/Intpjl.js +3 -0
- package/lib/src/kysely_types/debats/Lecassdeb.d.ts +13 -0
- package/lib/src/kysely_types/debats/Lecassdeb.js +3 -0
- package/lib/src/kysely_types/debats/Secdis.d.ts +27 -0
- package/lib/src/kysely_types/debats/Secdis.js +3 -0
- package/lib/src/kysely_types/debats/Secdivers.d.ts +19 -0
- package/lib/src/kysely_types/debats/Secdivers.js +3 -0
- package/lib/src/kysely_types/debats/SenatSchema.d.ts +18 -0
- package/lib/src/kysely_types/debats/SenatSchema.js +3 -0
- package/lib/src/kysely_types/debats/Syndeb.d.ts +12 -0
- package/lib/src/kysely_types/debats/Syndeb.js +3 -0
- package/lib/src/kysely_types/debats/Typsec.d.ts +14 -0
- package/lib/src/kysely_types/debats/Typsec.js +3 -0
- package/lib/src/kysely_types/dosleg/Amescr.d.ts +13 -0
- package/lib/src/kysely_types/dosleg/Amescr.js +3 -0
- package/lib/src/kysely_types/dosleg/Ass.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Ass.js +3 -0
- package/lib/src/kysely_types/dosleg/Aud.d.ts +19 -0
- package/lib/src/kysely_types/dosleg/Aud.js +3 -0
- package/lib/src/kysely_types/dosleg/Auteur.d.ts +34 -0
- package/lib/src/kysely_types/dosleg/Auteur.js +3 -0
- package/lib/src/kysely_types/dosleg/Ble.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Ble.js +3 -0
- package/lib/src/kysely_types/dosleg/Catrap.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Catrap.js +3 -0
- package/lib/src/kysely_types/dosleg/Corscr.d.ts +17 -0
- package/lib/src/kysely_types/dosleg/Corscr.js +3 -0
- package/lib/src/kysely_types/dosleg/Database.d.ts +3 -0
- package/lib/src/kysely_types/dosleg/Database.js +3 -0
- package/lib/src/kysely_types/dosleg/DateSeance.d.ts +16 -0
- package/lib/src/kysely_types/dosleg/DateSeance.js +3 -0
- package/lib/src/kysely_types/dosleg/Deccoc.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Deccoc.js +3 -0
- package/lib/src/kysely_types/dosleg/Denrap.d.ts +26 -0
- package/lib/src/kysely_types/dosleg/Denrap.js +3 -0
- package/lib/src/kysely_types/dosleg/Doc.d.ts +33 -0
- package/lib/src/kysely_types/dosleg/Doc.js +3 -0
- package/lib/src/kysely_types/dosleg/Docatt.d.ts +16 -0
- package/lib/src/kysely_types/dosleg/Docatt.js +3 -0
- package/lib/src/kysely_types/dosleg/Docsea.d.ts +19 -0
- package/lib/src/kysely_types/dosleg/Docsea.js +3 -0
- package/lib/src/kysely_types/dosleg/Ecr.d.ts +26 -0
- package/lib/src/kysely_types/dosleg/Ecr.js +3 -0
- package/lib/src/kysely_types/dosleg/Etaloi.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Etaloi.js +3 -0
- package/lib/src/kysely_types/dosleg/Evtsea.d.ts +18 -0
- package/lib/src/kysely_types/dosleg/Evtsea.js +3 -0
- package/lib/src/kysely_types/dosleg/Forpub.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Forpub.js +3 -0
- package/lib/src/kysely_types/dosleg/Gen.d.ts +11 -0
- package/lib/src/kysely_types/dosleg/Gen.js +3 -0
- package/lib/src/kysely_types/dosleg/Lecass.d.ts +84 -0
- package/lib/src/kysely_types/dosleg/Lecass.js +3 -0
- package/lib/src/kysely_types/dosleg/Lecassrap.d.ts +15 -0
- package/lib/src/kysely_types/dosleg/Lecassrap.js +3 -0
- package/lib/src/kysely_types/dosleg/Lecture.d.ts +16 -0
- package/lib/src/kysely_types/dosleg/Lecture.js +3 -0
- package/lib/src/kysely_types/dosleg/Lnkrap.d.ts +16 -0
- package/lib/src/kysely_types/dosleg/Lnkrap.js +3 -0
- package/lib/src/kysely_types/dosleg/Loi.d.ts +93 -0
- package/lib/src/kysely_types/dosleg/Loi.js +3 -0
- package/lib/src/kysely_types/dosleg/Loithe.d.ts +13 -0
- package/lib/src/kysely_types/dosleg/Loithe.js +3 -0
- package/lib/src/kysely_types/dosleg/Natloi.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Natloi.js +3 -0
- package/lib/src/kysely_types/dosleg/Org.d.ts +48 -0
- package/lib/src/kysely_types/dosleg/Org.js +3 -0
- package/lib/src/kysely_types/dosleg/Orgnomhis.d.ts +28 -0
- package/lib/src/kysely_types/dosleg/Orgnomhis.js +3 -0
- package/lib/src/kysely_types/dosleg/Orippr.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Orippr.js +3 -0
- package/lib/src/kysely_types/dosleg/Oritxt.d.ts +25 -0
- package/lib/src/kysely_types/dosleg/Oritxt.js +3 -0
- package/lib/src/kysely_types/dosleg/Posvot.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Posvot.js +3 -0
- package/lib/src/kysely_types/dosleg/Qua.d.ts +16 -0
- package/lib/src/kysely_types/dosleg/Qua.js +3 -0
- package/lib/src/kysely_types/dosleg/Rap.d.ts +64 -0
- package/lib/src/kysely_types/dosleg/Rap.js +3 -0
- package/lib/src/kysely_types/dosleg/Raporg.d.ts +13 -0
- package/lib/src/kysely_types/dosleg/Raporg.js +3 -0
- package/lib/src/kysely_types/dosleg/Rapthe.d.ts +13 -0
- package/lib/src/kysely_types/dosleg/Rapthe.js +3 -0
- package/lib/src/kysely_types/dosleg/Rolsig.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Rolsig.js +3 -0
- package/lib/src/kysely_types/dosleg/Scr.d.ts +46 -0
- package/lib/src/kysely_types/dosleg/Scr.js +3 -0
- package/lib/src/kysely_types/dosleg/SenatSchema.d.ts +108 -0
- package/lib/src/kysely_types/dosleg/SenatSchema.js +3 -0
- package/lib/src/kysely_types/dosleg/Ses.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Ses.js +3 -0
- package/lib/src/kysely_types/dosleg/Stavot.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Stavot.js +3 -0
- package/lib/src/kysely_types/dosleg/Texte.d.ts +54 -0
- package/lib/src/kysely_types/dosleg/Texte.js +3 -0
- package/lib/src/kysely_types/dosleg/TexteAncien.d.ts +20 -0
- package/lib/src/kysely_types/dosleg/TexteAncien.js +3 -0
- package/lib/src/kysely_types/dosleg/The.d.ts +14 -0
- package/lib/src/kysely_types/dosleg/The.js +3 -0
- package/lib/src/kysely_types/dosleg/Titsen.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Titsen.js +3 -0
- package/lib/src/kysely_types/dosleg/Typatt.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typatt.js +3 -0
- package/lib/src/kysely_types/dosleg/Typaut.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typaut.js +3 -0
- package/lib/src/kysely_types/dosleg/Typdoc.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typdoc.js +3 -0
- package/lib/src/kysely_types/dosleg/Typevtsea.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typevtsea.js +3 -0
- package/lib/src/kysely_types/dosleg/Typlec.d.ts +14 -0
- package/lib/src/kysely_types/dosleg/Typlec.js +3 -0
- package/lib/src/kysely_types/dosleg/Typloi.d.ts +26 -0
- package/lib/src/kysely_types/dosleg/Typloi.js +3 -0
- package/lib/src/kysely_types/dosleg/Typorg.d.ts +20 -0
- package/lib/src/kysely_types/dosleg/Typorg.js +3 -0
- package/lib/src/kysely_types/dosleg/Typrap.d.ts +26 -0
- package/lib/src/kysely_types/dosleg/Typrap.js +3 -0
- package/lib/src/kysely_types/dosleg/Typtxt.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typtxt.js +3 -0
- package/lib/src/kysely_types/dosleg/Typurl.d.ts +12 -0
- package/lib/src/kysely_types/dosleg/Typurl.js +3 -0
- package/lib/src/kysely_types/dosleg/Votsen.d.ts +25 -0
- package/lib/src/kysely_types/dosleg/Votsen.js +3 -0
- package/lib/src/kysely_types/questions/Database.d.ts +3 -0
- package/lib/src/kysely_types/questions/Database.js +3 -0
- package/lib/src/kysely_types/questions/Etatquestion.d.ts +14 -0
- package/lib/src/kysely_types/questions/Etatquestion.js +3 -0
- package/lib/src/kysely_types/questions/Legquestion.d.ts +18 -0
- package/lib/src/kysely_types/questions/Legquestion.js +3 -0
- package/lib/src/kysely_types/questions/Naturequestion.d.ts +15 -0
- package/lib/src/kysely_types/questions/Naturequestion.js +3 -0
- package/lib/src/kysely_types/questions/SenatSchema.d.ts +18 -0
- package/lib/src/kysely_types/questions/SenatSchema.js +3 -0
- package/lib/src/kysely_types/questions/Sortquestion.d.ts +14 -0
- package/lib/src/kysely_types/questions/Sortquestion.js +3 -0
- package/lib/src/kysely_types/questions/TamMinisteres.d.ts +28 -0
- package/lib/src/kysely_types/questions/TamMinisteres.js +3 -0
- package/lib/src/kysely_types/questions/TamQuestions.d.ts +124 -0
- package/lib/src/kysely_types/questions/TamQuestions.js +3 -0
- package/lib/src/kysely_types/questions/TamReponses.d.ts +32 -0
- package/lib/src/kysely_types/questions/TamReponses.js +3 -0
- package/lib/src/kysely_types/questions/The.d.ts +16 -0
- package/lib/src/kysely_types/questions/The.js +3 -0
- package/lib/src/kysely_types/sens/Activite.d.ts +34 -0
- package/lib/src/kysely_types/sens/Activite.js +3 -0
- package/lib/src/kysely_types/sens/ActiviteDelegation.d.ts +15 -0
- package/lib/src/kysely_types/sens/ActiviteDelegation.js +3 -0
- package/lib/src/kysely_types/sens/ActiviteLoi.d.ts +13 -0
- package/lib/src/kysely_types/sens/ActiviteLoi.js +3 -0
- package/lib/src/kysely_types/sens/ActiviteParticipant.d.ts +25 -0
- package/lib/src/kysely_types/sens/ActiviteParticipant.js +3 -0
- package/lib/src/kysely_types/sens/ActiviteSenateur.d.ts +21 -0
- package/lib/src/kysely_types/sens/ActiviteSenateur.js +3 -0
- package/lib/src/kysely_types/sens/ActivitesLiees.d.ts +10 -0
- package/lib/src/kysely_types/sens/ActivitesLiees.js +3 -0
- package/lib/src/kysely_types/sens/Actpro.d.ts +16 -0
- package/lib/src/kysely_types/sens/Actpro.js +3 -0
- package/lib/src/kysely_types/sens/Adresse.d.ts +39 -0
- package/lib/src/kysely_types/sens/Adresse.js +3 -0
- package/lib/src/kysely_types/sens/Asster.d.ts +18 -0
- package/lib/src/kysely_types/sens/Asster.js +3 -0
- package/lib/src/kysely_types/sens/Bur.d.ts +46 -0
- package/lib/src/kysely_types/sens/Bur.js +3 -0
- package/lib/src/kysely_types/sens/CategorieActivite.d.ts +13 -0
- package/lib/src/kysely_types/sens/CategorieActivite.js +3 -0
- package/lib/src/kysely_types/sens/Com.d.ts +48 -0
- package/lib/src/kysely_types/sens/Com.js +3 -0
- package/lib/src/kysely_types/sens/Csp.d.ts +22 -0
- package/lib/src/kysely_types/sens/Csp.js +3 -0
- package/lib/src/kysely_types/sens/Database.d.ts +3 -0
- package/lib/src/kysely_types/sens/Database.js +3 -0
- package/lib/src/kysely_types/sens/Delega.d.ts +46 -0
- package/lib/src/kysely_types/sens/Delega.js +3 -0
- package/lib/src/kysely_types/sens/Design.d.ts +33 -0
- package/lib/src/kysely_types/sens/Design.js +3 -0
- package/lib/src/kysely_types/sens/Designoep.d.ts +36 -0
- package/lib/src/kysely_types/sens/Designoep.js +3 -0
- package/lib/src/kysely_types/sens/Designorg.d.ts +39 -0
- package/lib/src/kysely_types/sens/Designorg.js +3 -0
- package/lib/src/kysely_types/sens/Dpt.d.ts +54 -0
- package/lib/src/kysely_types/sens/Dpt.js +3 -0
- package/lib/src/kysely_types/sens/Dptele.d.ts +35 -0
- package/lib/src/kysely_types/sens/Dptele.js +3 -0
- package/lib/src/kysely_types/sens/Dpttypman.d.ts +14 -0
- package/lib/src/kysely_types/sens/Dpttypman.js +3 -0
- package/lib/src/kysely_types/sens/Ele.d.ts +35 -0
- package/lib/src/kysely_types/sens/Ele.js +3 -0
- package/lib/src/kysely_types/sens/Elucan.d.ts +50 -0
- package/lib/src/kysely_types/sens/Elucan.js +3 -0
- package/lib/src/kysely_types/sens/Eludep.d.ts +49 -0
- package/lib/src/kysely_types/sens/Eludep.js +3 -0
- package/lib/src/kysely_types/sens/Eludiv.d.ts +47 -0
- package/lib/src/kysely_types/sens/Eludiv.js +3 -0
- package/lib/src/kysely_types/sens/Elueur.d.ts +47 -0
- package/lib/src/kysely_types/sens/Elueur.js +3 -0
- package/lib/src/kysely_types/sens/Elureg.d.ts +48 -0
- package/lib/src/kysely_types/sens/Elureg.js +3 -0
- package/lib/src/kysely_types/sens/Elusen.d.ts +52 -0
- package/lib/src/kysely_types/sens/Elusen.js +3 -0
- package/lib/src/kysely_types/sens/Eluter.d.ts +47 -0
- package/lib/src/kysely_types/sens/Eluter.js +3 -0
- package/lib/src/kysely_types/sens/Elutit.d.ts +38 -0
- package/lib/src/kysely_types/sens/Elutit.js +3 -0
- package/lib/src/kysely_types/sens/Eluvil.d.ts +48 -0
- package/lib/src/kysely_types/sens/Eluvil.js +3 -0
- package/lib/src/kysely_types/sens/Etadebman.d.ts +34 -0
- package/lib/src/kysely_types/sens/Etadebman.js +3 -0
- package/lib/src/kysely_types/sens/Etafinman.d.ts +34 -0
- package/lib/src/kysely_types/sens/Etafinman.js +3 -0
- package/lib/src/kysely_types/sens/Etasen.d.ts +34 -0
- package/lib/src/kysely_types/sens/Etasen.js +3 -0
- package/lib/src/kysely_types/sens/FonactParticipant.d.ts +16 -0
- package/lib/src/kysely_types/sens/FonactParticipant.js +3 -0
- package/lib/src/kysely_types/sens/Foncom.d.ts +40 -0
- package/lib/src/kysely_types/sens/Foncom.js +3 -0
- package/lib/src/kysely_types/sens/Fondelega.d.ts +40 -0
- package/lib/src/kysely_types/sens/Fondelega.js +3 -0
- package/lib/src/kysely_types/sens/Fongrppol.d.ts +40 -0
- package/lib/src/kysely_types/sens/Fongrppol.js +3 -0
- package/lib/src/kysely_types/sens/Fongrpsen.d.ts +27 -0
- package/lib/src/kysely_types/sens/Fongrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Fonmemcom.d.ts +37 -0
- package/lib/src/kysely_types/sens/Fonmemcom.js +3 -0
- package/lib/src/kysely_types/sens/Fonmemdelega.d.ts +37 -0
- package/lib/src/kysely_types/sens/Fonmemdelega.js +3 -0
- package/lib/src/kysely_types/sens/Fonmemgrppol.d.ts +35 -0
- package/lib/src/kysely_types/sens/Fonmemgrppol.js +3 -0
- package/lib/src/kysely_types/sens/Fonmemgrpsen.d.ts +32 -0
- package/lib/src/kysely_types/sens/Fonmemgrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Fonmemorg.d.ts +41 -0
- package/lib/src/kysely_types/sens/Fonmemorg.js +3 -0
- package/lib/src/kysely_types/sens/Fonorg.d.ts +40 -0
- package/lib/src/kysely_types/sens/Fonorg.js +3 -0
- package/lib/src/kysely_types/sens/Grppol.d.ts +46 -0
- package/lib/src/kysely_types/sens/Grppol.js +3 -0
- package/lib/src/kysely_types/sens/Grpsenami.d.ts +55 -0
- package/lib/src/kysely_types/sens/Grpsenami.js +3 -0
- package/lib/src/kysely_types/sens/Libcom.d.ts +36 -0
- package/lib/src/kysely_types/sens/Libcom.js +3 -0
- package/lib/src/kysely_types/sens/Libdelega.d.ts +34 -0
- package/lib/src/kysely_types/sens/Libdelega.js +3 -0
- package/lib/src/kysely_types/sens/Libgrppol.d.ts +36 -0
- package/lib/src/kysely_types/sens/Libgrppol.js +3 -0
- package/lib/src/kysely_types/sens/Libgrpsen.d.ts +28 -0
- package/lib/src/kysely_types/sens/Libgrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Liborg.d.ts +34 -0
- package/lib/src/kysely_types/sens/Liborg.js +3 -0
- package/lib/src/kysely_types/sens/Mel.d.ts +19 -0
- package/lib/src/kysely_types/sens/Mel.js +3 -0
- package/lib/src/kysely_types/sens/Memcom.d.ts +37 -0
- package/lib/src/kysely_types/sens/Memcom.js +3 -0
- package/lib/src/kysely_types/sens/Memdelega.d.ts +38 -0
- package/lib/src/kysely_types/sens/Memdelega.js +3 -0
- package/lib/src/kysely_types/sens/Memextpar.d.ts +56 -0
- package/lib/src/kysely_types/sens/Memextpar.js +3 -0
- package/lib/src/kysely_types/sens/Memgrppol.d.ts +38 -0
- package/lib/src/kysely_types/sens/Memgrppol.js +3 -0
- package/lib/src/kysely_types/sens/Memgrpsen.d.ts +30 -0
- package/lib/src/kysely_types/sens/Memgrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Memorg.d.ts +42 -0
- package/lib/src/kysely_types/sens/Memorg.js +3 -0
- package/lib/src/kysely_types/sens/Minind.d.ts +46 -0
- package/lib/src/kysely_types/sens/Minind.js +3 -0
- package/lib/src/kysely_types/sens/Mismin.d.ts +17 -0
- package/lib/src/kysely_types/sens/Mismin.js +3 -0
- package/lib/src/kysely_types/sens/Missen.d.ts +17 -0
- package/lib/src/kysely_types/sens/Missen.js +3 -0
- package/lib/src/kysely_types/sens/Moddes.d.ts +30 -0
- package/lib/src/kysely_types/sens/Moddes.js +3 -0
- package/lib/src/kysely_types/sens/Nation.d.ts +26 -0
- package/lib/src/kysely_types/sens/Nation.js +3 -0
- package/lib/src/kysely_types/sens/Nationgrpsen.d.ts +31 -0
- package/lib/src/kysely_types/sens/Nationgrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Org.d.ts +46 -0
- package/lib/src/kysely_types/sens/Org.js +3 -0
- package/lib/src/kysely_types/sens/Orgext.d.ts +72 -0
- package/lib/src/kysely_types/sens/Orgext.js +3 -0
- package/lib/src/kysely_types/sens/Orgthe.d.ts +12 -0
- package/lib/src/kysely_types/sens/Orgthe.js +3 -0
- package/lib/src/kysely_types/sens/Pcs.d.ts +15 -0
- package/lib/src/kysely_types/sens/Pcs.js +3 -0
- package/lib/src/kysely_types/sens/Pcs24.d.ts +15 -0
- package/lib/src/kysely_types/sens/Pcs24.js +3 -0
- package/lib/src/kysely_types/sens/Pcs42.d.ts +15 -0
- package/lib/src/kysely_types/sens/Pcs42.js +3 -0
- package/lib/src/kysely_types/sens/Pcs8.d.ts +12 -0
- package/lib/src/kysely_types/sens/Pcs8.js +3 -0
- package/lib/src/kysely_types/sens/Pcscatpro.d.ts +15 -0
- package/lib/src/kysely_types/sens/Pcscatpro.js +3 -0
- package/lib/src/kysely_types/sens/Poicon.d.ts +20 -0
- package/lib/src/kysely_types/sens/Poicon.js +3 -0
- package/lib/src/kysely_types/sens/Qua.d.ts +30 -0
- package/lib/src/kysely_types/sens/Qua.js +3 -0
- package/lib/src/kysely_types/sens/Reg.d.ts +38 -0
- package/lib/src/kysely_types/sens/Reg.js +3 -0
- package/lib/src/kysely_types/sens/Sen.d.ts +66 -0
- package/lib/src/kysely_types/sens/Sen.js +3 -0
- package/lib/src/kysely_types/sens/SenatSchema.d.ts +198 -0
- package/lib/src/kysely_types/sens/SenatSchema.js +3 -0
- package/lib/src/kysely_types/sens/Senbur.d.ts +41 -0
- package/lib/src/kysely_types/sens/Senbur.js +3 -0
- package/lib/src/kysely_types/sens/Sennom.d.ts +32 -0
- package/lib/src/kysely_types/sens/Sennom.js +3 -0
- package/lib/src/kysely_types/sens/Senurl.d.ts +35 -0
- package/lib/src/kysely_types/sens/Senurl.js +3 -0
- package/lib/src/kysely_types/sens/Stajur.d.ts +19 -0
- package/lib/src/kysely_types/sens/Stajur.js +3 -0
- package/lib/src/kysely_types/sens/Telephone.d.ts +21 -0
- package/lib/src/kysely_types/sens/Telephone.js +3 -0
- package/lib/src/kysely_types/sens/Temval.d.ts +14 -0
- package/lib/src/kysely_types/sens/Temval.js +3 -0
- package/lib/src/kysely_types/sens/Territ.d.ts +25 -0
- package/lib/src/kysely_types/sens/Territ.js +3 -0
- package/lib/src/kysely_types/sens/Titele.d.ts +32 -0
- package/lib/src/kysely_types/sens/Titele.js +3 -0
- package/lib/src/kysely_types/sens/Typadr.d.ts +20 -0
- package/lib/src/kysely_types/sens/Typadr.js +3 -0
- package/lib/src/kysely_types/sens/Typapppol.d.ts +34 -0
- package/lib/src/kysely_types/sens/Typapppol.js +3 -0
- package/lib/src/kysely_types/sens/Typbister.d.ts +16 -0
- package/lib/src/kysely_types/sens/Typbister.js +3 -0
- package/lib/src/kysely_types/sens/TypeActivite.d.ts +11 -0
- package/lib/src/kysely_types/sens/TypeActivite.js +3 -0
- package/lib/src/kysely_types/sens/TypeActiviteParticipant.d.ts +10 -0
- package/lib/src/kysely_types/sens/TypeActiviteParticipant.js +3 -0
- package/lib/src/kysely_types/sens/TypeActiviteSenateur.d.ts +11 -0
- package/lib/src/kysely_types/sens/TypeActiviteSenateur.js +3 -0
- package/lib/src/kysely_types/sens/TypeCategorie.d.ts +11 -0
- package/lib/src/kysely_types/sens/TypeCategorie.js +3 -0
- package/lib/src/kysely_types/sens/Typele.d.ts +22 -0
- package/lib/src/kysely_types/sens/Typele.js +3 -0
- package/lib/src/kysely_types/sens/Typgrpsen.d.ts +23 -0
- package/lib/src/kysely_types/sens/Typgrpsen.js +3 -0
- package/lib/src/kysely_types/sens/Typman.d.ts +20 -0
- package/lib/src/kysely_types/sens/Typman.js +3 -0
- package/lib/src/kysely_types/sens/Typorg.d.ts +26 -0
- package/lib/src/kysely_types/sens/Typorg.js +3 -0
- package/lib/src/kysely_types/sens/Typurl.d.ts +31 -0
- package/lib/src/kysely_types/sens/Typurl.js +3 -0
- package/lib/src/kysely_types/sens/Typvoi.d.ts +16 -0
- package/lib/src/kysely_types/sens/Typvoi.js +3 -0
- package/lib/src/kysely_types/sens/Zongeo.d.ts +22 -0
- package/lib/src/kysely_types/sens/Zongeo.js +3 -0
- package/lib/src/loaders.d.ts +3 -3
- package/lib/src/loaders.js +1 -1
- package/lib/src/model/agenda.d.ts +1 -1
- package/lib/src/model/commission.d.ts +2 -2
- package/lib/src/model/seance.d.ts +1 -1
- package/lib/src/other_types/agenda.d.ts +45 -0
- package/lib/src/other_types/agenda.js +1 -0
- package/lib/src/other_types/compte_rendu.d.ts +83 -0
- package/lib/src/other_types/compte_rendu.js +1 -0
- package/lib/src/other_types/questions.d.ts +2 -0
- package/lib/src/other_types/questions.js +1 -0
- package/lib/src/other_types/sens.d.ts +8 -0
- package/lib/src/other_types/sens.js +1 -0
- package/lib/src/other_types/sessions.d.ts +6 -0
- package/lib/src/other_types/sessions.js +19 -0
- package/lib/src/other_types/texte.d.ts +72 -0
- package/lib/src/other_types/texte.js +15 -0
- package/lib/src/parsers/texte.d.ts +1 -1
- package/lib/src/parsers/texte.js +1 -1
- package/lib/src/questions.d.ts +53 -0
- package/lib/src/questions.js +1 -0
- package/lib/src/rich_types/agenda.d.ts +45 -0
- package/lib/src/rich_types/agenda.js +1 -0
- package/lib/src/rich_types/ameli.d.ts +70 -0
- package/lib/src/rich_types/ameli.js +1 -0
- package/lib/src/rich_types/compte_rendu.d.ts +83 -0
- package/lib/src/rich_types/compte_rendu.js +1 -0
- package/lib/src/rich_types/debats.d.ts +38 -0
- package/lib/src/rich_types/debats.js +1 -0
- package/lib/src/rich_types/dosleg.d.ts +212 -0
- package/lib/src/rich_types/dosleg.js +193 -0
- package/lib/src/rich_types/questions.d.ts +55 -0
- package/lib/src/rich_types/questions.js +1 -0
- package/lib/src/rich_types/sens.d.ts +104 -0
- package/lib/src/rich_types/sens.js +1 -0
- package/lib/src/rich_types/sessions.d.ts +6 -0
- package/lib/src/rich_types/sessions.js +19 -0
- package/lib/src/rich_types/texte.d.ts +72 -0
- package/lib/src/rich_types/texte.js +15 -0
- package/lib/src/schemas/config.d.ts +9 -0
- package/lib/src/schemas/config.js +10 -0
- package/lib/src/scripts/convert_data.js +6 -6
- package/lib/src/scripts/convert_xml_to_html.js +1 -1
- package/lib/src/scripts/datautil.d.ts +1 -1
- package/lib/src/scripts/retrieve_agenda.js +4 -4
- package/lib/src/scripts/retrieve_cr_commission.js +6 -6
- package/lib/src/scripts/retrieve_cr_seance.d.ts +1 -1
- package/lib/src/scripts/retrieve_cr_seance.js +4 -4
- package/lib/src/scripts/retrieve_documents.d.ts +1 -1
- package/lib/src/scripts/retrieve_documents.js +4 -4
- package/lib/src/scripts/retrieve_open_data.js +72 -8
- package/lib/src/scripts/retrieve_senateurs_photos.js +2 -2
- package/lib/src/scripts/retrieve_videos.js +3 -3
- package/lib/src/scripts/shared/incremental_import_sql.js +22 -7
- package/lib/src/scripts/shared/prefixed_tables.d.ts +2 -1
- package/lib/src/scripts/shared/prefixed_tables.js +4 -3
- package/lib/src/scripts/shared/staging_import.d.ts +1 -1
- package/lib/src/scripts/validate_prefixed_tables.js +12 -11
- package/lib/src/scrutins.d.ts +47 -0
- package/lib/src/scrutins.js +1 -0
- package/lib/src/sens.d.ts +104 -0
- package/lib/src/sens.js +1 -0
- package/lib/src/server/agenda.d.ts +6 -0
- package/lib/src/server/agenda.js +148 -0
- package/lib/src/server/ameli.d.ts +2 -0
- package/lib/src/server/ameli.js +153 -0
- package/lib/src/server/commission.d.ts +19 -0
- package/lib/src/server/commission.js +269 -0
- package/lib/src/server/config.d.ts +43 -0
- package/lib/src/server/config.js +37 -0
- package/lib/src/server/conversion_textes.d.ts +11 -0
- package/lib/src/server/conversion_textes.js +320 -0
- package/lib/src/server/databases_postgres.d.ts +32 -0
- package/lib/src/server/databases_postgres.js +50 -0
- package/lib/src/server/datasets.d.ts +38 -0
- package/lib/src/server/datasets.js +247 -0
- package/lib/src/server/debats.d.ts +2 -0
- package/lib/src/server/debats.js +98 -0
- package/lib/src/server/documents.d.ts +3 -0
- package/lib/src/server/documents.js +132 -0
- package/lib/src/server/dosleg.d.ts +2 -0
- package/lib/src/server/dosleg.js +228 -0
- package/lib/src/server/git.d.ts +27 -0
- package/lib/src/server/git.js +251 -0
- package/lib/src/server/index.d.ts +18 -0
- package/lib/src/server/index.js +16 -0
- package/lib/src/server/loaders.d.ts +52 -0
- package/lib/src/server/loaders.js +260 -0
- package/lib/src/server/questions.d.ts +2 -0
- package/lib/src/server/questions.js +89 -0
- package/lib/src/server/scrutins.d.ts +2 -0
- package/lib/src/server/scrutins.js +114 -0
- package/lib/src/server/seance.d.ts +3 -0
- package/lib/src/server/seance.js +267 -0
- package/lib/src/server/sens.d.ts +9 -0
- package/lib/src/server/sens.js +353 -0
- package/lib/src/types/ameli.d.ts +1761 -4
- package/lib/src/types/ameli.js +1074 -1
- package/lib/src/types/debats.d.ts +380 -2
- package/lib/src/types/debats.js +266 -1
- package/lib/src/types/dosleg.d.ts +2953 -69
- package/lib/src/types/dosleg.js +2005 -1
- package/lib/src/types/questions.d.ts +699 -2
- package/lib/src/types/questions.js +493 -1
- package/lib/src/types/sens.d.ts +7842 -7
- package/lib/src/types/sens.js +4691 -1
- package/lib/src/util.d.ts +1 -0
- package/lib/src/util.js +15 -0
- package/lib/src/utils/cr_spliting.d.ts +1 -1
- package/lib/src/utils/cr_spliting.js +2 -2
- package/lib/src/utils/reunion_odj_building.d.ts +2 -2
- package/lib/src/utils/reunion_odj_building.js +2 -2
- package/lib/src/utils/reunion_parsing.d.ts +2 -2
- package/lib/src/utils/scoring.d.ts +1 -1
- package/lib/src/videos/match.d.ts +1 -1
- package/lib/src/videos/pipeline.d.ts +1 -1
- package/lib/src/videos/pipeline.js +1 -1
- package/lib/src/videos/search.d.ts +1 -1
- package/lib/tests/test_iter_load.test.js +1 -1
- package/lib/tests/validatePrefixedTables.test.js +1 -1
- package/lib/tsconfig.tsbuildinfo +1 -0
- package/package.json +11 -4
|
@@ -0,0 +1,267 @@
|
|
|
1
|
+
import fs from "fs";
|
|
2
|
+
import * as cheerio from "cheerio";
|
|
3
|
+
import { toCRDate } from "../util.js";
|
|
4
|
+
import { makeReunionUid } from "../utils/reunion_parsing.js";
|
|
5
|
+
import { yyyymmddFromPath } from "../utils/date.js";
|
|
6
|
+
import { decodeHtmlEntities, dedupeSpeaker, fixApostrophes, norm } from "../utils/string_cleaning.js";
|
|
7
|
+
export async function parseCompteRenduIntervalFromFile(xmlFilePath, startIndex, endIndex, agendaEventId) {
|
|
8
|
+
try {
|
|
9
|
+
const raw = fs.readFileSync(xmlFilePath, "utf8");
|
|
10
|
+
const $ = cheerio.load(raw, { xml: false });
|
|
11
|
+
const metadonnees = extractMetadonnees($, xmlFilePath);
|
|
12
|
+
const order = $("body *").toArray();
|
|
13
|
+
const idx = new Map(order.map((el, i) => [el, i]));
|
|
14
|
+
const totalNodes = order.length;
|
|
15
|
+
const clampedStart = Math.max(0, Math.min(startIndex, totalNodes - 1));
|
|
16
|
+
const clampedEnd = Math.max(0, Math.min(endIndex, totalNodes - 1));
|
|
17
|
+
const intervals = [
|
|
18
|
+
{
|
|
19
|
+
start: clampedStart,
|
|
20
|
+
end: clampedEnd,
|
|
21
|
+
},
|
|
22
|
+
];
|
|
23
|
+
metadonnees.sommaire = extractSommaireForIntervals($, idx, intervals);
|
|
24
|
+
const points = [];
|
|
25
|
+
let ordre = 0;
|
|
26
|
+
const addPoint = (p) => points.push({ ...p, ordre_absolu_seance: String(++ordre) });
|
|
27
|
+
// Interventions
|
|
28
|
+
$("div.intervenant").each((_, block) => {
|
|
29
|
+
if (!elementInAnyInterval(block, idx, intervals))
|
|
30
|
+
return;
|
|
31
|
+
const $block = $(block);
|
|
32
|
+
$block
|
|
33
|
+
.find([
|
|
34
|
+
"p[class^='titre_S']",
|
|
35
|
+
"p.mention_titre",
|
|
36
|
+
"p.intitule_titre",
|
|
37
|
+
"p.mention_chapitre",
|
|
38
|
+
"p.intitule_chapitre",
|
|
39
|
+
"p.mention_article",
|
|
40
|
+
"p.intitule_article",
|
|
41
|
+
"p.mention_section",
|
|
42
|
+
"p.intitule_section",
|
|
43
|
+
].join(","))
|
|
44
|
+
.remove();
|
|
45
|
+
const firstP = $block.find("p").first();
|
|
46
|
+
if (!firstP || firstP.length === 0)
|
|
47
|
+
return;
|
|
48
|
+
const speakerLabelRaw = firstP.find(".orateur_nom").text() || firstP.find("a.lien_senfic").text() || "";
|
|
49
|
+
const speakerLabel = dedupeSpeaker(speakerLabelRaw);
|
|
50
|
+
const { mat, nom: nomCRI, qua: quaCRI } = readIntervenantMeta($block);
|
|
51
|
+
const qualFromSpans = extractAndRemoveLeadingQualite($, $block);
|
|
52
|
+
const qualite = norm(decodeHtmlEntities(quaCRI || "")) || qualFromSpans;
|
|
53
|
+
const canonicalName = dedupeSpeaker(nomCRI || speakerLabel);
|
|
54
|
+
const role = roleForSpeaker(speakerLabel) || roleForSpeaker(qualite) || roleForSpeaker(quaCRI || "");
|
|
55
|
+
const speechHtml = sanitizeInterventionHtml($, $block);
|
|
56
|
+
const speechText = norm(cheerio.load(speechHtml).text() || "");
|
|
57
|
+
if (!speechText)
|
|
58
|
+
return;
|
|
59
|
+
addPoint({
|
|
60
|
+
code_grammaire: "PAROLE_GENERIQUE",
|
|
61
|
+
roledebat: role,
|
|
62
|
+
orateurs: { orateur: { nom: canonicalName, id: mat || "", qualite } },
|
|
63
|
+
texte: { _: speechHtml },
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
const contenu = {
|
|
67
|
+
quantiemes: {
|
|
68
|
+
journee: metadonnees.dateSeance,
|
|
69
|
+
session: metadonnees.session,
|
|
70
|
+
},
|
|
71
|
+
point: points,
|
|
72
|
+
};
|
|
73
|
+
const yyyymmdd = yyyymmddFromPath(xmlFilePath);
|
|
74
|
+
const dateISO = `${yyyymmdd.slice(0, 4)}-${yyyymmdd.slice(4, 6)}-${yyyymmdd.slice(6, 8)}`;
|
|
75
|
+
const seanceRef = makeReunionUid(dateISO, "SP", agendaEventId, null);
|
|
76
|
+
return {
|
|
77
|
+
uid: `CRSSN${yyyymmdd}E${agendaEventId}`,
|
|
78
|
+
seanceRef,
|
|
79
|
+
sessionRef: metadonnees.session,
|
|
80
|
+
metadonnees,
|
|
81
|
+
contenu,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
catch (e) {
|
|
85
|
+
console.error(`[CRI] parseInterval error file=${xmlFilePath} interval=[${startIndex}..${endIndex}] event=${agendaEventId}:`, e);
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
export function sessionStartYearFromDate(d) {
|
|
90
|
+
// Session (1th oct N → 30 sept N+1)
|
|
91
|
+
const m = d.getMonth();
|
|
92
|
+
const y = d.getFullYear();
|
|
93
|
+
return m >= 9 ? y : y - 1;
|
|
94
|
+
}
|
|
95
|
+
function roleForSpeaker(labelOrQualite) {
|
|
96
|
+
const s = (labelOrQualite || "").toLowerCase();
|
|
97
|
+
if (/^(m\.|mme)?\s*(le|la)\s+pr[ée]sident(e)?\b/.test(s) || /\bpr[ée]sident[e]?\s+de\s+séance\b/.test(s))
|
|
98
|
+
return "président";
|
|
99
|
+
return "";
|
|
100
|
+
}
|
|
101
|
+
function readIntervenantMeta($block) {
|
|
102
|
+
const int = $block.find("cri\\:intervenant").first();
|
|
103
|
+
if (int.length)
|
|
104
|
+
return { mat: int.attr("mat") || undefined, nom: int.attr("nom") || undefined, qua: int.attr("qua") || undefined };
|
|
105
|
+
const html = $block.html() || "";
|
|
106
|
+
const m = html.match(/<!--\s*cri:intervenant\b([^>]+)-->/i);
|
|
107
|
+
if (!m)
|
|
108
|
+
return {};
|
|
109
|
+
const out = {};
|
|
110
|
+
const re = /(\w+)="([^"]*)"/g;
|
|
111
|
+
let a;
|
|
112
|
+
while ((a = re.exec(m[1])))
|
|
113
|
+
out[a[1]] = decodeHtmlEntities(a[2]);
|
|
114
|
+
return { mat: out["mat"], nom: out["nom"], qua: out["qua"] };
|
|
115
|
+
}
|
|
116
|
+
function extractAndRemoveLeadingQualite($, $block) {
|
|
117
|
+
const firstP = $block.find("p").first();
|
|
118
|
+
if (firstP.length === 0)
|
|
119
|
+
return "";
|
|
120
|
+
const parts = [];
|
|
121
|
+
let stop = false;
|
|
122
|
+
firstP.contents().each((_, node) => {
|
|
123
|
+
if (stop)
|
|
124
|
+
return;
|
|
125
|
+
if (node.type === "tag") {
|
|
126
|
+
const $node = $(node);
|
|
127
|
+
if ($node.hasClass("orateur_nom")) {
|
|
128
|
+
$node.remove();
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
if ($node.hasClass("orateur_qualite")) {
|
|
132
|
+
parts.push($node.text() || "");
|
|
133
|
+
$node.remove();
|
|
134
|
+
return;
|
|
135
|
+
}
|
|
136
|
+
const t = norm($node.text() || "");
|
|
137
|
+
if (t)
|
|
138
|
+
stop = true;
|
|
139
|
+
else
|
|
140
|
+
$node.remove();
|
|
141
|
+
}
|
|
142
|
+
else if (node.type === "text") {
|
|
143
|
+
const textNode = node;
|
|
144
|
+
const t = norm(textNode.data || "");
|
|
145
|
+
if (!t || /^[:.,;–—-]+$/.test(t)) {
|
|
146
|
+
textNode.data = "";
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
stop = true;
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
return fixApostrophes(norm(parts.join(" ")));
|
|
153
|
+
}
|
|
154
|
+
function sanitizeInterventionHtml($, $block) {
|
|
155
|
+
const ps = $block.find("p").toArray();
|
|
156
|
+
const cleaned = ps
|
|
157
|
+
.map((p) => {
|
|
158
|
+
const $p = $(p).clone();
|
|
159
|
+
$p.find(".orateur_nom, .orateur_qualite").remove();
|
|
160
|
+
$p.find("a").each((_, a) => {
|
|
161
|
+
const $a = $(a);
|
|
162
|
+
$a.replaceWith($a.text());
|
|
163
|
+
});
|
|
164
|
+
$p.find(".info_entre_parentheses").each((_, el) => {
|
|
165
|
+
const txt = $(el).text();
|
|
166
|
+
$(el).replaceWith($("<em/>").text(txt));
|
|
167
|
+
});
|
|
168
|
+
$p.find("span").each((_, span) => {
|
|
169
|
+
const $s = $(span);
|
|
170
|
+
if (!$s.text().trim())
|
|
171
|
+
$s.remove();
|
|
172
|
+
});
|
|
173
|
+
const inner = ($p.html() || "").trim();
|
|
174
|
+
if (!inner)
|
|
175
|
+
return null;
|
|
176
|
+
return `<p>${inner}</p>`;
|
|
177
|
+
})
|
|
178
|
+
.filter(Boolean);
|
|
179
|
+
return cleaned.join("<br/>");
|
|
180
|
+
}
|
|
181
|
+
function extractSommaireForIntervals($, idx, intervals) {
|
|
182
|
+
const inIv = (el) => elementInAnyInterval(el, idx, intervals);
|
|
183
|
+
const root = $("body");
|
|
184
|
+
const sommaire = { presidentSeance: { _: "" }, sommaire1: [] };
|
|
185
|
+
// (1) Présidence (tm2) — première ligne dans l’intervalle
|
|
186
|
+
const pres = root
|
|
187
|
+
.find("p.tm2")
|
|
188
|
+
.filter((_, el) => inIv(el))
|
|
189
|
+
.first();
|
|
190
|
+
if (pres.length)
|
|
191
|
+
sommaire.presidentSeance = { _: norm(pres.text()) };
|
|
192
|
+
// (2) Paras tm5 présents dans l’intervalle
|
|
193
|
+
const paras = [];
|
|
194
|
+
root.find("p.tm5").each((_, el) => {
|
|
195
|
+
if (!inIv(el))
|
|
196
|
+
return;
|
|
197
|
+
const t = norm($(el).text());
|
|
198
|
+
if (t)
|
|
199
|
+
paras.push({ _: t });
|
|
200
|
+
});
|
|
201
|
+
if (paras.length)
|
|
202
|
+
sommaire.para = paras.length === 1 ? paras[0] : paras;
|
|
203
|
+
// (3) Items de 1er niveau (tm3) présents dans l’intervalle
|
|
204
|
+
const items = [];
|
|
205
|
+
root.find("p.tm3").each((_, el) => {
|
|
206
|
+
if (!inIv(el))
|
|
207
|
+
return;
|
|
208
|
+
const $p = $(el);
|
|
209
|
+
const full = norm($p.text() || "");
|
|
210
|
+
if (!full)
|
|
211
|
+
return;
|
|
212
|
+
const numMatch = full.match(/^(\d+)\s*[.\-–—]\s*/);
|
|
213
|
+
const valeur = numMatch ? numMatch[1] : undefined;
|
|
214
|
+
// prefere intitule in ancre <a> if present
|
|
215
|
+
const a = $p.find("a").first();
|
|
216
|
+
const intituleRaw = a.length ? a.text() : full.replace(/^(\d+)\s*[.\-–—]\s*/, "");
|
|
217
|
+
const intitule = norm(intituleRaw);
|
|
218
|
+
// id_syceron from href="#Niv1_SOMx"
|
|
219
|
+
const href = (a.attr("href") || "").trim();
|
|
220
|
+
const idSyceron = href.startsWith("#") ? href.slice(1) : href;
|
|
221
|
+
const titreStruct = { id_syceron: idSyceron || "", intitule };
|
|
222
|
+
items.push({ valeur_pts_odj: valeur, titreStruct });
|
|
223
|
+
});
|
|
224
|
+
if (items.length)
|
|
225
|
+
sommaire.sommaire1 = items;
|
|
226
|
+
return sommaire;
|
|
227
|
+
}
|
|
228
|
+
function extractMetadonnees($, filePath) {
|
|
229
|
+
let dateText = norm($("h1, h2, .page-title").first().text() || "");
|
|
230
|
+
if (!dateText)
|
|
231
|
+
dateText = norm($("p").first().text() || "");
|
|
232
|
+
const dateMatch = dateText.match(/\b(\d{1,2}\s+\w+\s+\d{4})\b/i);
|
|
233
|
+
const allText = norm($("body").text() || "");
|
|
234
|
+
const sessionMatch = allText.match(/\bsession\s+(\d{4}-\d{4})\b/i);
|
|
235
|
+
let dateSeance = dateMatch?.[1] || "";
|
|
236
|
+
if (!dateSeance) {
|
|
237
|
+
const m = filePath.match(/d(\d{4})(\d{2})(\d{2})\.xml$/i);
|
|
238
|
+
if (m)
|
|
239
|
+
dateSeance = `${m[1]}-${m[2]}-${m[3]}`;
|
|
240
|
+
}
|
|
241
|
+
dateSeance = toCRDate(dateSeance, null);
|
|
242
|
+
return {
|
|
243
|
+
dateSeance,
|
|
244
|
+
dateSeanceJour: dateSeance,
|
|
245
|
+
numSeanceJour: "",
|
|
246
|
+
numSeance: "",
|
|
247
|
+
typeAssemblee: "SN",
|
|
248
|
+
legislature: "",
|
|
249
|
+
session: sessionMatch?.[1] || "",
|
|
250
|
+
nomFichierJo: "",
|
|
251
|
+
validite: "",
|
|
252
|
+
etat: "",
|
|
253
|
+
diffusion: "",
|
|
254
|
+
version: "1.0",
|
|
255
|
+
environnement: "",
|
|
256
|
+
heureGeneration: new Date(),
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
function elementInAnyInterval(el, idx, intervals) {
|
|
260
|
+
const p = idx.get(el);
|
|
261
|
+
if (p == null)
|
|
262
|
+
return false;
|
|
263
|
+
for (const iv of intervals)
|
|
264
|
+
if (p >= iv.start && p < iv.end)
|
|
265
|
+
return true;
|
|
266
|
+
return false;
|
|
267
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { CirconscriptionResult, OrganismeResult, SenateurResult } from "../rich_types/sens.js";
|
|
2
|
+
export declare function findAll(): AsyncGenerator<SenateurResult, void, unknown>;
|
|
3
|
+
export declare function findAllCirconscriptions(): AsyncGenerator<CirconscriptionResult, void, unknown>;
|
|
4
|
+
export declare function findAllOrganismes(): AsyncGenerator<OrganismeResult, void, unknown>;
|
|
5
|
+
export declare function findActif(): AsyncGenerator<{
|
|
6
|
+
senmat: string;
|
|
7
|
+
sennomuse: string | null;
|
|
8
|
+
senprenomuse: string;
|
|
9
|
+
}, void, unknown>;
|
|
@@ -0,0 +1,353 @@
|
|
|
1
|
+
import { sql } from "kysely";
|
|
2
|
+
import { jsonArrayFrom } from "kysely/helpers/postgres";
|
|
3
|
+
import { db, streamRawQuery } from "./databases_postgres.js";
|
|
4
|
+
export async function* findAll() {
|
|
5
|
+
const compiledQuery = db
|
|
6
|
+
.withSchema("senat")
|
|
7
|
+
.selectFrom("sens_sen as sen")
|
|
8
|
+
.leftJoin("sens_etasen as etasen", "etasen.etasencod", "sen.etasencod")
|
|
9
|
+
.leftJoin("sens_pcs as pcs", "pcs.pcscod", "sen.pcscod")
|
|
10
|
+
.leftJoin("sens_pcs42 as pcs42", "pcs42.pcs42cod", "pcs.pcs42cod")
|
|
11
|
+
.leftJoin("sens_pcs24 as pcs24", "pcs24.pcs24cod", "pcs42.pcs24cod")
|
|
12
|
+
.leftJoin("sens_pcs8 as pcs8", "pcs8.pcs8cod", "pcs24.pcs8cod")
|
|
13
|
+
.leftJoin("sens_grppol as grppol", "grppol.grppolcod", "sen.sengrppolcodcou")
|
|
14
|
+
.leftJoin("sens_com as com", "com.orgcod", "sen.sencomcodcou")
|
|
15
|
+
.select((eb) => [
|
|
16
|
+
"sen.senmat as matricule",
|
|
17
|
+
"sen.quacod as qualite",
|
|
18
|
+
"sen.sennomuse as nom_usuel",
|
|
19
|
+
"sen.senprenomuse as prenom_usuel",
|
|
20
|
+
"sen.etasencod as etat",
|
|
21
|
+
sql `to_char(${eb.ref("sen.sendatnai")}, 'YYYY-MM-DD')`.as("date_naissance"),
|
|
22
|
+
sql `to_char(${eb.ref("sen.sendatdec")}, 'YYYY-MM-DD')`.as("date_deces"),
|
|
23
|
+
"sen.sengrppolcodcou as code_groupe_politique",
|
|
24
|
+
"sen.sengrppolliccou as groupe_politique",
|
|
25
|
+
"sen.sencomcodcou as code_commission_permanente",
|
|
26
|
+
"com.comlilmin as commission_permanente",
|
|
27
|
+
sql `${eb.ref("sen.sencirnumcou")}::text`.as("code_circonscription"),
|
|
28
|
+
"sen.sencircou as circonscription",
|
|
29
|
+
"sen.senburliccou as fonction_bureau_senat",
|
|
30
|
+
"sen.senema as courrier_electronique",
|
|
31
|
+
sql `pcs.pcslil`.as("PCS_INSEE"),
|
|
32
|
+
sql `pcs42.pcs42lib`.as("PCS_INSEE_42"),
|
|
33
|
+
sql `pcs24.pcs24lib`.as("PCS_INSEE_24"),
|
|
34
|
+
sql `pcs8.pcs8lil`.as("PCS_INSEE_8"),
|
|
35
|
+
"sen.sendespro as description_profession",
|
|
36
|
+
sql `${eb.ref("sen.sennumsie")}::text`.as("siege"),
|
|
37
|
+
"sen.sendaiurl as url_hatvp",
|
|
38
|
+
// URLs
|
|
39
|
+
jsonArrayFrom(eb
|
|
40
|
+
.withSchema("senat")
|
|
41
|
+
.selectFrom("sens_senurl as senurl")
|
|
42
|
+
.select(["senurl.typurlcod as code_url", "senurl.senurlurl as url", "senurl.senurlnumtri as order_num"])
|
|
43
|
+
.whereRef("senurl.senmat", "=", "sen.senmat")
|
|
44
|
+
.orderBy("senurl.senurlnumtri", "asc")).as("urls"),
|
|
45
|
+
// Mandats sénatoriaux
|
|
46
|
+
jsonArrayFrom(eb
|
|
47
|
+
.withSchema("senat")
|
|
48
|
+
.selectFrom("sens_elusen as elusen")
|
|
49
|
+
.leftJoin("sens_etadebman as etadebman", "etadebman.etadebmancod", "elusen.etadebmancod")
|
|
50
|
+
.leftJoin("sens_etafinman as etafinman", "etafinman.etafinmancod", "elusen.etafinmancod")
|
|
51
|
+
.select([
|
|
52
|
+
sql `elusen.dptnum::text`.as("code_circonscription"),
|
|
53
|
+
sql `to_char(elusen.eludatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
54
|
+
sql `to_char(elusen.eludatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
55
|
+
"elusen.temvalcod as etat",
|
|
56
|
+
"etadebman.etadebmanlib as etat_debut",
|
|
57
|
+
"etafinman.etafinman as etat_fin",
|
|
58
|
+
"elusen.eludatdeb as order_date",
|
|
59
|
+
])
|
|
60
|
+
.whereRef("elusen.senmat", "=", "sen.senmat")
|
|
61
|
+
.orderBy("elusen.eludatdeb", (ob) => ob.desc().nullsLast())).as("mandats_senateur"),
|
|
62
|
+
// Commissions
|
|
63
|
+
jsonArrayFrom(eb
|
|
64
|
+
.withSchema("senat")
|
|
65
|
+
.selectFrom("sens_memcom as memcom")
|
|
66
|
+
.leftJoin("sens_com as com2", "com2.orgcod", "memcom.orgcod")
|
|
67
|
+
.leftJoin("sens_typorg as typorg", "typorg.typorgcod", "com2.typorgcod")
|
|
68
|
+
.select((eb2) => [
|
|
69
|
+
"memcom.orgcod as code_organisme",
|
|
70
|
+
sql `to_char(memcom.memcomdatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
71
|
+
sql `to_char(memcom.memcomdatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
72
|
+
"memcom.temvalcod as etat",
|
|
73
|
+
"com2.comlilmin as libelle",
|
|
74
|
+
"com2.typorgcod as type_code_organisme",
|
|
75
|
+
"typorg.typorglib as type_organisme",
|
|
76
|
+
"memcom.memcomdatdeb as order_date",
|
|
77
|
+
// Fonctions dans la commission
|
|
78
|
+
jsonArrayFrom(eb2
|
|
79
|
+
.withSchema("senat")
|
|
80
|
+
.selectFrom("sens_fonmemcom as fonmemcom")
|
|
81
|
+
.leftJoin("sens_foncom as foncom", "foncom.foncomcod", "fonmemcom.foncomcod")
|
|
82
|
+
.select([
|
|
83
|
+
sql `to_char(fonmemcom.fonmemcomdatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
84
|
+
sql `to_char(fonmemcom.fonmemcomdatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
85
|
+
sql `coalesce(
|
|
86
|
+
nullif(foncom.foncomlib, ''),
|
|
87
|
+
nullif(foncom.foncomlil, ''),
|
|
88
|
+
nullif(foncom.foncomlic, ''))`.as("libelle"),
|
|
89
|
+
"fonmemcom.fonmemcomdatdeb as order_date",
|
|
90
|
+
])
|
|
91
|
+
.whereRef("fonmemcom.memcomid", "=", "memcom.memcomid")
|
|
92
|
+
.orderBy("fonmemcom.fonmemcomdatdeb", (ob) => ob.desc().nullsLast())).as("fonctions"),
|
|
93
|
+
])
|
|
94
|
+
.whereRef("memcom.senmat", "=", "sen.senmat")
|
|
95
|
+
.orderBy("memcom.memcomdatdeb", (ob) => ob.desc().nullsLast())).as("commissions"),
|
|
96
|
+
// Délégations
|
|
97
|
+
jsonArrayFrom(eb
|
|
98
|
+
.withSchema("senat")
|
|
99
|
+
.selectFrom("sens_memdelega as memdelega")
|
|
100
|
+
.leftJoin("sens_delega as delega", "delega.orgcod", "memdelega.orgcod")
|
|
101
|
+
.leftJoin("sens_designorg as designorg", "designorg.designcod", "memdelega.designcod")
|
|
102
|
+
.leftJoin("sens_typorg as typorg2", "typorg2.typorgcod", "delega.typorgcod")
|
|
103
|
+
.select((eb2) => [
|
|
104
|
+
"memdelega.orgcod as code_organisme",
|
|
105
|
+
sql `to_char(memdelega.memdelegadatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
106
|
+
sql `to_char(memdelega.memdelegadatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
107
|
+
"memdelega.temvalcod as etat",
|
|
108
|
+
"delega.evelib as libelle",
|
|
109
|
+
"delega.typorgcod as type_code_organisme",
|
|
110
|
+
"typorg2.typorglib as type_organisme",
|
|
111
|
+
"memdelega.memdelegadatdeb as order_date",
|
|
112
|
+
// Fonctions dans la délégation
|
|
113
|
+
jsonArrayFrom(eb2
|
|
114
|
+
.withSchema("senat")
|
|
115
|
+
.selectFrom("sens_fonmemdelega as fonmemdelega")
|
|
116
|
+
.leftJoin("sens_fondelega as fondelega", "fondelega.fondelcod", "fonmemdelega.fondelcod")
|
|
117
|
+
.select([
|
|
118
|
+
sql `to_char(fonmemdelega.fonmemdeldatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
119
|
+
sql `to_char(fonmemdelega.fonmemdeldatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
120
|
+
sql `coalesce(
|
|
121
|
+
nullif(fondelega.fondellib, ''),
|
|
122
|
+
nullif(fondelega.fondellil, ''),
|
|
123
|
+
nullif(fondelega.fondellic, ''))`.as("libelle"),
|
|
124
|
+
"fonmemdelega.fonmemdeldatdeb as order_date",
|
|
125
|
+
])
|
|
126
|
+
.whereRef("fonmemdelega.memdelegaid", "=", "memdelega.memdelegaid")
|
|
127
|
+
.orderBy("fonmemdelega.fonmemdeldatdeb", (ob) => ob.desc().nullsLast())).as("fonctions"),
|
|
128
|
+
])
|
|
129
|
+
.whereRef("memdelega.senmat", "=", "sen.senmat")
|
|
130
|
+
.orderBy("memdelega.memdelegadatdeb", (ob) => ob.desc().nullsLast())).as("delegations"),
|
|
131
|
+
// Groupes politiques
|
|
132
|
+
jsonArrayFrom(eb
|
|
133
|
+
.withSchema("senat")
|
|
134
|
+
.selectFrom("sens_memgrppol as memgrppol")
|
|
135
|
+
.leftJoin("sens_grppol as grppol2", "grppol2.grppolcod", "memgrppol.grppolcod")
|
|
136
|
+
.leftJoin("sens_typapppol as typapppol", "typapppol.typapppolcod", "memgrppol.typapppolcod")
|
|
137
|
+
.leftJoin("sens_typorg as typorg3", "typorg3.typorgcod", "grppol2.typorgcod")
|
|
138
|
+
.select((eb2) => [
|
|
139
|
+
"memgrppol.grppolcod as code_organisme",
|
|
140
|
+
sql `to_char(memgrppol.memgrppoldatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
141
|
+
sql `to_char(memgrppol.memgrppoldatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
142
|
+
"memgrppol.temvalcod as etat",
|
|
143
|
+
"grppol2.grppollibcou as libelle",
|
|
144
|
+
"grppol2.typorgcod as type_code_organisme",
|
|
145
|
+
"typorg3.typorglib as type_organisme",
|
|
146
|
+
"memgrppol.memgrppoldatdeb as order_date",
|
|
147
|
+
// Fonctions dans le groupe politique
|
|
148
|
+
jsonArrayFrom(eb2
|
|
149
|
+
.withSchema("senat")
|
|
150
|
+
.selectFrom("sens_fonmemgrppol as fonmemgrppol")
|
|
151
|
+
.leftJoin("sens_fongrppol as fongrppol", "fongrppol.fongrppolcod", "fonmemgrppol.fongrppolcod")
|
|
152
|
+
.select([
|
|
153
|
+
sql `to_char(fonmemgrppol.fonmemgrppoldatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
154
|
+
sql `to_char(fonmemgrppol.fonmemgrppoldatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
155
|
+
sql `coalesce(
|
|
156
|
+
nullif(fongrppol.fongrppollib, ''),
|
|
157
|
+
nullif(fongrppol.fongrppollil, ''),
|
|
158
|
+
nullif(fongrppol.fongrppollic, ''))`.as("libelle"),
|
|
159
|
+
"fonmemgrppol.fonmemgrppoldatdeb as order_date",
|
|
160
|
+
])
|
|
161
|
+
.whereRef("fonmemgrppol.memgrppolid", "=", "memgrppol.memgrppolid")
|
|
162
|
+
.orderBy("fonmemgrppol.fonmemgrppoldatdeb", (ob) => ob.desc().nullsLast())).as("fonctions"),
|
|
163
|
+
])
|
|
164
|
+
.whereRef("memgrppol.senmat", "=", "sen.senmat")
|
|
165
|
+
.orderBy("memgrppol.memgrppoldatdeb", (ob) => ob.desc().nullsLast())).as("groupes"),
|
|
166
|
+
// Fonctions au bureau du Sénat
|
|
167
|
+
jsonArrayFrom(eb
|
|
168
|
+
.withSchema("senat")
|
|
169
|
+
.selectFrom("sens_senbur as senbur")
|
|
170
|
+
.leftJoin("sens_bur as bur", "bur.burcod", "senbur.burcod")
|
|
171
|
+
.select([
|
|
172
|
+
sql `to_char(senbur.senburdatdeb, 'YYYY-MM-DD')`.as("date_debut"),
|
|
173
|
+
sql `to_char(senbur.senburdatfin, 'YYYY-MM-DD')`.as("date_fin"),
|
|
174
|
+
sql `coalesce(nullif(bur.burlib, ''), nullif(bur.burlil, ''), nullif(bur.burlic, ''))`.as("libelle"),
|
|
175
|
+
"senbur.senburdatdeb as order_date",
|
|
176
|
+
])
|
|
177
|
+
.whereRef("senbur.senmat", "=", "sen.senmat")
|
|
178
|
+
.orderBy("senbur.senburdatdeb", (ob) => ob.desc().nullsLast())).as("fonctions_bureau"),
|
|
179
|
+
// Points de contact
|
|
180
|
+
jsonArrayFrom(eb
|
|
181
|
+
.withSchema("senat")
|
|
182
|
+
.selectFrom("sens_poicon as poicon")
|
|
183
|
+
.select((eb2) => [
|
|
184
|
+
sql `poicon.poiconid::text`.as("id"),
|
|
185
|
+
"poicon.typpoiconcod as type",
|
|
186
|
+
"poicon.poiconlib as libelle",
|
|
187
|
+
"poicon.poiconnumtri as order_num",
|
|
188
|
+
// Adresses
|
|
189
|
+
jsonArrayFrom(eb2
|
|
190
|
+
.withSchema("senat")
|
|
191
|
+
.selectFrom("sens_adresse as adresse")
|
|
192
|
+
.select([
|
|
193
|
+
"adresse.adrnumvoi as numero_voie",
|
|
194
|
+
"adresse.adrnomvoi as nom_voie",
|
|
195
|
+
"adresse.adrcmp as complement",
|
|
196
|
+
"adresse.adrcmp2 as complement2",
|
|
197
|
+
"adresse.adrcodpos as code_postal",
|
|
198
|
+
"adresse.adrcom as commune",
|
|
199
|
+
"adresse.adrcdxcod as code_cedex",
|
|
200
|
+
"adresse.adrcdxlib as libelle_cedex",
|
|
201
|
+
"adresse.adrburdis as bureau_distributeur",
|
|
202
|
+
"adresse.adrnumtri as order_num",
|
|
203
|
+
])
|
|
204
|
+
.whereRef("adresse.poiconid", "=", "poicon.poiconid")
|
|
205
|
+
.orderBy("adresse.adrnumtri", "asc")).as("adresses"),
|
|
206
|
+
// Téléphones
|
|
207
|
+
jsonArrayFrom(eb2
|
|
208
|
+
.withSchema("senat")
|
|
209
|
+
.selectFrom("sens_telephone as telephone")
|
|
210
|
+
.select([
|
|
211
|
+
"telephone.typtelcod as type",
|
|
212
|
+
"telephone.telnum as numero",
|
|
213
|
+
"telephone.telnumtri as order_num",
|
|
214
|
+
])
|
|
215
|
+
.whereRef("telephone.poiconid", "=", "poicon.poiconid")
|
|
216
|
+
.orderBy("telephone.telnumtri", "asc")).as("telephones"),
|
|
217
|
+
])
|
|
218
|
+
.whereRef("poicon.senmat", "=", "sen.senmat")
|
|
219
|
+
.orderBy("poicon.poiconnumtri", "asc")).as("points_contact"),
|
|
220
|
+
])
|
|
221
|
+
.compile();
|
|
222
|
+
for await (const row of streamRawQuery(compiledQuery)) {
|
|
223
|
+
yield {
|
|
224
|
+
...row,
|
|
225
|
+
commissions: row.commissions ?? [],
|
|
226
|
+
delegations: row.delegations ?? [],
|
|
227
|
+
fonctions_bureau: row.fonctions_bureau ?? [],
|
|
228
|
+
groupes: row.groupes ?? [],
|
|
229
|
+
mandats_senateur: row.mandats_senateur ?? [],
|
|
230
|
+
points_contact: row.points_contact ?? [],
|
|
231
|
+
urls: row.urls ?? [],
|
|
232
|
+
};
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
export async function* findAllCirconscriptions() {
|
|
236
|
+
const compiledQuery = db
|
|
237
|
+
.withSchema("senat")
|
|
238
|
+
.selectFrom("sens_dpt as dpt")
|
|
239
|
+
.leftJoin("sens_reg as reg", "reg.regcod", "dpt.regcod")
|
|
240
|
+
.select((eb) => [
|
|
241
|
+
sql `${eb.ref("dpt.dptnum")}::text`.as("identifiant"),
|
|
242
|
+
"dpt.dptcod as code",
|
|
243
|
+
"dpt.dptlib as libelle_departement",
|
|
244
|
+
"dpt.dptart as article",
|
|
245
|
+
"reg.reglib as libelle_region",
|
|
246
|
+
"dpt.temvalcod as etat",
|
|
247
|
+
sql `to_char(${eb.ref("dpt.dptdatdeb")}, 'YYYY-MM-DD')`.as("date_debut"),
|
|
248
|
+
sql `to_char(${eb.ref("dpt.dptdatfin")}, 'YYYY-MM-DD')`.as("date_fin"),
|
|
249
|
+
sql `${eb.ref("dpt.dptnbrsen")}::text`.as("nombre_senateurs"),
|
|
250
|
+
"dpt.dpturlcmp as url",
|
|
251
|
+
])
|
|
252
|
+
.compile();
|
|
253
|
+
yield* streamRawQuery(compiledQuery);
|
|
254
|
+
}
|
|
255
|
+
export async function* findAllOrganismes() {
|
|
256
|
+
const compiledQuery = db
|
|
257
|
+
.withSchema("senat")
|
|
258
|
+
.selectFrom(db
|
|
259
|
+
.withSchema("senat")
|
|
260
|
+
.selectFrom("sens_com as com")
|
|
261
|
+
.select([
|
|
262
|
+
"com.orgcod",
|
|
263
|
+
"com.evelic",
|
|
264
|
+
"com.evelib",
|
|
265
|
+
"com.evelil",
|
|
266
|
+
"com.typorgcod",
|
|
267
|
+
"com.orgurlsim",
|
|
268
|
+
"com.orgdatcre",
|
|
269
|
+
"com.orgdatfin",
|
|
270
|
+
"com.temvalcod",
|
|
271
|
+
])
|
|
272
|
+
.union(db
|
|
273
|
+
.withSchema("senat")
|
|
274
|
+
.selectFrom("sens_delega as delega")
|
|
275
|
+
.select([
|
|
276
|
+
"delega.orgcod",
|
|
277
|
+
"delega.evelic",
|
|
278
|
+
"delega.evelib",
|
|
279
|
+
"delega.evelil",
|
|
280
|
+
"delega.typorgcod",
|
|
281
|
+
"delega.orgurlsim",
|
|
282
|
+
"delega.orgdatcre",
|
|
283
|
+
"delega.orgdatfin",
|
|
284
|
+
"delega.temvalcod",
|
|
285
|
+
]))
|
|
286
|
+
.union(db
|
|
287
|
+
.withSchema("senat")
|
|
288
|
+
.selectFrom("sens_grppol as grppol")
|
|
289
|
+
.select([
|
|
290
|
+
"grppol.grppolcod as orgcod",
|
|
291
|
+
"grppol.grppolliccou as evelic",
|
|
292
|
+
"grppol.grppollibcou as evelib",
|
|
293
|
+
"grppol.grppollilcou as evelil",
|
|
294
|
+
"grppol.typorgcod",
|
|
295
|
+
"grppol.grppolurlsim as orgurlsim",
|
|
296
|
+
"grppol.grppoldatcre as orgdatcre",
|
|
297
|
+
"grppol.grppoldatfin as orgdatfin",
|
|
298
|
+
"grppol.temvalcod",
|
|
299
|
+
]))
|
|
300
|
+
.union(db
|
|
301
|
+
.withSchema("senat")
|
|
302
|
+
.selectFrom("sens_grpsenami as grpsenami")
|
|
303
|
+
.select([
|
|
304
|
+
"grpsenami.orgcod",
|
|
305
|
+
"grpsenami.evelic",
|
|
306
|
+
"grpsenami.evelib",
|
|
307
|
+
"grpsenami.evelil",
|
|
308
|
+
"grpsenami.typorgcod",
|
|
309
|
+
"grpsenami.orgurlsim",
|
|
310
|
+
"grpsenami.orgdatcre",
|
|
311
|
+
"grpsenami.orgdatfin",
|
|
312
|
+
"grpsenami.temvalcod",
|
|
313
|
+
]))
|
|
314
|
+
.union(db
|
|
315
|
+
.withSchema("senat")
|
|
316
|
+
.selectFrom("sens_org as org")
|
|
317
|
+
.select([
|
|
318
|
+
"org.orgcod",
|
|
319
|
+
"org.evelic",
|
|
320
|
+
"org.evelib",
|
|
321
|
+
"org.evelil",
|
|
322
|
+
"org.typorgcod",
|
|
323
|
+
"org.orgurlsim",
|
|
324
|
+
"org.orgdatcre",
|
|
325
|
+
"org.orgdatfin",
|
|
326
|
+
"org.temvalcod",
|
|
327
|
+
]))
|
|
328
|
+
.as("all_organismes"))
|
|
329
|
+
.leftJoin("sens_typorg as typorg", "typorg.typorgcod", "all_organismes.typorgcod")
|
|
330
|
+
.select((eb) => [
|
|
331
|
+
"all_organismes.orgcod as code",
|
|
332
|
+
"all_organismes.evelic as libelle_court",
|
|
333
|
+
"all_organismes.evelib as libelle",
|
|
334
|
+
sql `rtrim(${eb.ref("all_organismes.evelil")})`.as("libelle_long"),
|
|
335
|
+
"all_organismes.typorgcod as type_code",
|
|
336
|
+
sql `rtrim(${eb.ref("typorg.typorglib")})`.as("type_libelle"),
|
|
337
|
+
sql `'https://www.senat.fr' || ${eb.ref("all_organismes.orgurlsim")}`.as("url"),
|
|
338
|
+
sql `to_char(${eb.ref("all_organismes.orgdatcre")}, 'YYYY-MM-DD')`.as("date_debut"),
|
|
339
|
+
sql `to_char(${eb.ref("all_organismes.orgdatfin")}, 'YYYY-MM-DD')`.as("date_fin"),
|
|
340
|
+
"all_organismes.temvalcod as etat",
|
|
341
|
+
])
|
|
342
|
+
.compile();
|
|
343
|
+
yield* streamRawQuery(compiledQuery);
|
|
344
|
+
}
|
|
345
|
+
export async function* findActif() {
|
|
346
|
+
const compiledQuery = db
|
|
347
|
+
.withSchema("senat")
|
|
348
|
+
.selectFrom("sens_sen as sen")
|
|
349
|
+
.select(["sen.senmat", "sen.sennomuse", "sen.senprenomuse"])
|
|
350
|
+
.where("sen.etasencod", "=", "ACTIF")
|
|
351
|
+
.compile();
|
|
352
|
+
yield* streamRawQuery(compiledQuery);
|
|
353
|
+
}
|