@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.
Files changed (566) hide show
  1. package/lib/src/ameli.d.ts +66 -0
  2. package/lib/src/ameli.js +1 -0
  3. package/lib/src/db_types/ameli.d.ts +1762 -0
  4. package/lib/src/db_types/ameli.js +1074 -0
  5. package/lib/src/db_types/debats.d.ts +380 -0
  6. package/lib/src/db_types/debats.js +266 -0
  7. package/lib/src/db_types/dosleg.d.ts +2954 -0
  8. package/lib/src/db_types/dosleg.js +2005 -0
  9. package/lib/src/db_types/questions.d.ts +699 -0
  10. package/lib/src/db_types/questions.js +493 -0
  11. package/lib/src/db_types/sens.d.ts +7843 -0
  12. package/lib/src/db_types/sens.js +4691 -0
  13. package/lib/src/debats.d.ts +38 -0
  14. package/lib/src/debats.js +1 -0
  15. package/lib/src/documents.d.ts +30 -0
  16. package/lib/src/documents.js +1 -0
  17. package/lib/src/dosleg.d.ts +142 -0
  18. package/lib/src/dosleg.js +193 -0
  19. package/lib/src/index.d.ts +41 -24
  20. package/lib/src/index.js +27 -6
  21. package/lib/src/kanel_types/ameli.d.ts +1762 -0
  22. package/lib/src/kanel_types/ameli.js +1074 -0
  23. package/lib/src/kanel_types/debats.d.ts +380 -0
  24. package/lib/src/kanel_types/debats.js +266 -0
  25. package/lib/src/kanel_types/dosleg.d.ts +2954 -0
  26. package/lib/src/kanel_types/dosleg.js +2005 -0
  27. package/lib/src/kanel_types/questions.d.ts +699 -0
  28. package/lib/src/kanel_types/questions.js +493 -0
  29. package/lib/src/kanel_types/sens.d.ts +7843 -0
  30. package/lib/src/kanel_types/sens.js +4691 -0
  31. package/lib/src/kysely/index.d.ts +216 -0
  32. package/lib/src/kysely/index.js +11 -0
  33. package/lib/src/kysely_types/ameli/Amd.d.ts +91 -0
  34. package/lib/src/kysely_types/ameli/Amd.js +3 -0
  35. package/lib/src/kysely_types/ameli/Amdsen.d.ts +24 -0
  36. package/lib/src/kysely_types/ameli/Amdsen.js +3 -0
  37. package/lib/src/kysely_types/ameli/Avicom.d.ts +14 -0
  38. package/lib/src/kysely_types/ameli/Avicom.js +3 -0
  39. package/lib/src/kysely_types/ameli/Avigvt.d.ts +14 -0
  40. package/lib/src/kysely_types/ameli/Avigvt.js +3 -0
  41. package/lib/src/kysely_types/ameli/Cab.d.ts +14 -0
  42. package/lib/src/kysely_types/ameli/Cab.js +3 -0
  43. package/lib/src/kysely_types/ameli/ComAmeli.d.ts +22 -0
  44. package/lib/src/kysely_types/ameli/ComAmeli.js +3 -0
  45. package/lib/src/kysely_types/ameli/Database.d.ts +3 -0
  46. package/lib/src/kysely_types/ameli/Database.js +3 -0
  47. package/lib/src/kysely_types/ameli/Ent.d.ts +14 -0
  48. package/lib/src/kysely_types/ameli/Ent.js +3 -0
  49. package/lib/src/kysely_types/ameli/Etatxt.d.ts +15 -0
  50. package/lib/src/kysely_types/ameli/Etatxt.js +3 -0
  51. package/lib/src/kysely_types/ameli/Fbu.d.ts +17 -0
  52. package/lib/src/kysely_types/ameli/Fbu.js +3 -0
  53. package/lib/src/kysely_types/ameli/GrppolAmeli.d.ts +20 -0
  54. package/lib/src/kysely_types/ameli/GrppolAmeli.js +3 -0
  55. package/lib/src/kysely_types/ameli/Gvt.d.ts +18 -0
  56. package/lib/src/kysely_types/ameli/Gvt.js +3 -0
  57. package/lib/src/kysely_types/ameli/Intora.d.ts +33 -0
  58. package/lib/src/kysely_types/ameli/Intora.js +3 -0
  59. package/lib/src/kysely_types/ameli/Irr.d.ts +21 -0
  60. package/lib/src/kysely_types/ameli/Irr.js +3 -0
  61. package/lib/src/kysely_types/ameli/LecAmeli.d.ts +14 -0
  62. package/lib/src/kysely_types/ameli/LecAmeli.js +3 -0
  63. package/lib/src/kysely_types/ameli/Mot.d.ts +20 -0
  64. package/lib/src/kysely_types/ameli/Mot.js +3 -0
  65. package/lib/src/kysely_types/ameli/Nat.d.ts +13 -0
  66. package/lib/src/kysely_types/ameli/Nat.js +3 -0
  67. package/lib/src/kysely_types/ameli/Orarol.d.ts +14 -0
  68. package/lib/src/kysely_types/ameli/Orarol.js +3 -0
  69. package/lib/src/kysely_types/ameli/Sai.d.ts +25 -0
  70. package/lib/src/kysely_types/ameli/Sai.js +3 -0
  71. package/lib/src/kysely_types/ameli/Saisen.d.ts +15 -0
  72. package/lib/src/kysely_types/ameli/Saisen.js +3 -0
  73. package/lib/src/kysely_types/ameli/Sea.d.ts +17 -0
  74. package/lib/src/kysely_types/ameli/Sea.js +3 -0
  75. package/lib/src/kysely_types/ameli/SenAmeli.d.ts +36 -0
  76. package/lib/src/kysely_types/ameli/SenAmeli.js +3 -0
  77. package/lib/src/kysely_types/ameli/SenatSchema.d.ts +60 -0
  78. package/lib/src/kysely_types/ameli/SenatSchema.js +3 -0
  79. package/lib/src/kysely_types/ameli/Ses.d.ts +17 -0
  80. package/lib/src/kysely_types/ameli/Ses.js +3 -0
  81. package/lib/src/kysely_types/ameli/Sor.d.ts +16 -0
  82. package/lib/src/kysely_types/ameli/Sor.js +3 -0
  83. package/lib/src/kysely_types/ameli/Sub.d.ts +44 -0
  84. package/lib/src/kysely_types/ameli/Sub.js +3 -0
  85. package/lib/src/kysely_types/ameli/TxtAmeli.d.ts +77 -0
  86. package/lib/src/kysely_types/ameli/TxtAmeli.js +3 -0
  87. package/lib/src/kysely_types/ameli/Typrect.d.ts +14 -0
  88. package/lib/src/kysely_types/ameli/Typrect.js +3 -0
  89. package/lib/src/kysely_types/ameli/Typses.d.ts +12 -0
  90. package/lib/src/kysely_types/ameli/Typses.js +3 -0
  91. package/lib/src/kysely_types/ameli/Typsub.d.ts +12 -0
  92. package/lib/src/kysely_types/ameli/Typsub.js +3 -0
  93. package/lib/src/kysely_types/ameli/WNivrec.d.ts +12 -0
  94. package/lib/src/kysely_types/ameli/WNivrec.js +3 -0
  95. package/lib/src/kysely_types/debats/Database.d.ts +3 -0
  96. package/lib/src/kysely_types/debats/Database.js +3 -0
  97. package/lib/src/kysely_types/debats/Debats.d.ts +25 -0
  98. package/lib/src/kysely_types/debats/Debats.js +3 -0
  99. package/lib/src/kysely_types/debats/Intdivers.d.ts +22 -0
  100. package/lib/src/kysely_types/debats/Intdivers.js +3 -0
  101. package/lib/src/kysely_types/debats/Intpjl.d.ts +22 -0
  102. package/lib/src/kysely_types/debats/Intpjl.js +3 -0
  103. package/lib/src/kysely_types/debats/Lecassdeb.d.ts +13 -0
  104. package/lib/src/kysely_types/debats/Lecassdeb.js +3 -0
  105. package/lib/src/kysely_types/debats/Secdis.d.ts +27 -0
  106. package/lib/src/kysely_types/debats/Secdis.js +3 -0
  107. package/lib/src/kysely_types/debats/Secdivers.d.ts +19 -0
  108. package/lib/src/kysely_types/debats/Secdivers.js +3 -0
  109. package/lib/src/kysely_types/debats/SenatSchema.d.ts +18 -0
  110. package/lib/src/kysely_types/debats/SenatSchema.js +3 -0
  111. package/lib/src/kysely_types/debats/Syndeb.d.ts +12 -0
  112. package/lib/src/kysely_types/debats/Syndeb.js +3 -0
  113. package/lib/src/kysely_types/debats/Typsec.d.ts +14 -0
  114. package/lib/src/kysely_types/debats/Typsec.js +3 -0
  115. package/lib/src/kysely_types/dosleg/Amescr.d.ts +13 -0
  116. package/lib/src/kysely_types/dosleg/Amescr.js +3 -0
  117. package/lib/src/kysely_types/dosleg/Ass.d.ts +12 -0
  118. package/lib/src/kysely_types/dosleg/Ass.js +3 -0
  119. package/lib/src/kysely_types/dosleg/Aud.d.ts +19 -0
  120. package/lib/src/kysely_types/dosleg/Aud.js +3 -0
  121. package/lib/src/kysely_types/dosleg/Auteur.d.ts +34 -0
  122. package/lib/src/kysely_types/dosleg/Auteur.js +3 -0
  123. package/lib/src/kysely_types/dosleg/Ble.d.ts +12 -0
  124. package/lib/src/kysely_types/dosleg/Ble.js +3 -0
  125. package/lib/src/kysely_types/dosleg/Catrap.d.ts +12 -0
  126. package/lib/src/kysely_types/dosleg/Catrap.js +3 -0
  127. package/lib/src/kysely_types/dosleg/Corscr.d.ts +17 -0
  128. package/lib/src/kysely_types/dosleg/Corscr.js +3 -0
  129. package/lib/src/kysely_types/dosleg/Database.d.ts +3 -0
  130. package/lib/src/kysely_types/dosleg/Database.js +3 -0
  131. package/lib/src/kysely_types/dosleg/DateSeance.d.ts +16 -0
  132. package/lib/src/kysely_types/dosleg/DateSeance.js +3 -0
  133. package/lib/src/kysely_types/dosleg/Deccoc.d.ts +12 -0
  134. package/lib/src/kysely_types/dosleg/Deccoc.js +3 -0
  135. package/lib/src/kysely_types/dosleg/Denrap.d.ts +26 -0
  136. package/lib/src/kysely_types/dosleg/Denrap.js +3 -0
  137. package/lib/src/kysely_types/dosleg/Doc.d.ts +33 -0
  138. package/lib/src/kysely_types/dosleg/Doc.js +3 -0
  139. package/lib/src/kysely_types/dosleg/Docatt.d.ts +16 -0
  140. package/lib/src/kysely_types/dosleg/Docatt.js +3 -0
  141. package/lib/src/kysely_types/dosleg/Docsea.d.ts +19 -0
  142. package/lib/src/kysely_types/dosleg/Docsea.js +3 -0
  143. package/lib/src/kysely_types/dosleg/Ecr.d.ts +26 -0
  144. package/lib/src/kysely_types/dosleg/Ecr.js +3 -0
  145. package/lib/src/kysely_types/dosleg/Etaloi.d.ts +12 -0
  146. package/lib/src/kysely_types/dosleg/Etaloi.js +3 -0
  147. package/lib/src/kysely_types/dosleg/Evtsea.d.ts +18 -0
  148. package/lib/src/kysely_types/dosleg/Evtsea.js +3 -0
  149. package/lib/src/kysely_types/dosleg/Forpub.d.ts +12 -0
  150. package/lib/src/kysely_types/dosleg/Forpub.js +3 -0
  151. package/lib/src/kysely_types/dosleg/Gen.d.ts +11 -0
  152. package/lib/src/kysely_types/dosleg/Gen.js +3 -0
  153. package/lib/src/kysely_types/dosleg/Lecass.d.ts +84 -0
  154. package/lib/src/kysely_types/dosleg/Lecass.js +3 -0
  155. package/lib/src/kysely_types/dosleg/Lecassrap.d.ts +15 -0
  156. package/lib/src/kysely_types/dosleg/Lecassrap.js +3 -0
  157. package/lib/src/kysely_types/dosleg/Lecture.d.ts +16 -0
  158. package/lib/src/kysely_types/dosleg/Lecture.js +3 -0
  159. package/lib/src/kysely_types/dosleg/Lnkrap.d.ts +16 -0
  160. package/lib/src/kysely_types/dosleg/Lnkrap.js +3 -0
  161. package/lib/src/kysely_types/dosleg/Loi.d.ts +93 -0
  162. package/lib/src/kysely_types/dosleg/Loi.js +3 -0
  163. package/lib/src/kysely_types/dosleg/Loithe.d.ts +13 -0
  164. package/lib/src/kysely_types/dosleg/Loithe.js +3 -0
  165. package/lib/src/kysely_types/dosleg/Natloi.d.ts +12 -0
  166. package/lib/src/kysely_types/dosleg/Natloi.js +3 -0
  167. package/lib/src/kysely_types/dosleg/Org.d.ts +48 -0
  168. package/lib/src/kysely_types/dosleg/Org.js +3 -0
  169. package/lib/src/kysely_types/dosleg/Orgnomhis.d.ts +28 -0
  170. package/lib/src/kysely_types/dosleg/Orgnomhis.js +3 -0
  171. package/lib/src/kysely_types/dosleg/Orippr.d.ts +12 -0
  172. package/lib/src/kysely_types/dosleg/Orippr.js +3 -0
  173. package/lib/src/kysely_types/dosleg/Oritxt.d.ts +25 -0
  174. package/lib/src/kysely_types/dosleg/Oritxt.js +3 -0
  175. package/lib/src/kysely_types/dosleg/Posvot.d.ts +12 -0
  176. package/lib/src/kysely_types/dosleg/Posvot.js +3 -0
  177. package/lib/src/kysely_types/dosleg/Qua.d.ts +16 -0
  178. package/lib/src/kysely_types/dosleg/Qua.js +3 -0
  179. package/lib/src/kysely_types/dosleg/Rap.d.ts +64 -0
  180. package/lib/src/kysely_types/dosleg/Rap.js +3 -0
  181. package/lib/src/kysely_types/dosleg/Raporg.d.ts +13 -0
  182. package/lib/src/kysely_types/dosleg/Raporg.js +3 -0
  183. package/lib/src/kysely_types/dosleg/Rapthe.d.ts +13 -0
  184. package/lib/src/kysely_types/dosleg/Rapthe.js +3 -0
  185. package/lib/src/kysely_types/dosleg/Rolsig.d.ts +12 -0
  186. package/lib/src/kysely_types/dosleg/Rolsig.js +3 -0
  187. package/lib/src/kysely_types/dosleg/Scr.d.ts +46 -0
  188. package/lib/src/kysely_types/dosleg/Scr.js +3 -0
  189. package/lib/src/kysely_types/dosleg/SenatSchema.d.ts +108 -0
  190. package/lib/src/kysely_types/dosleg/SenatSchema.js +3 -0
  191. package/lib/src/kysely_types/dosleg/Ses.d.ts +12 -0
  192. package/lib/src/kysely_types/dosleg/Ses.js +3 -0
  193. package/lib/src/kysely_types/dosleg/Stavot.d.ts +12 -0
  194. package/lib/src/kysely_types/dosleg/Stavot.js +3 -0
  195. package/lib/src/kysely_types/dosleg/Texte.d.ts +54 -0
  196. package/lib/src/kysely_types/dosleg/Texte.js +3 -0
  197. package/lib/src/kysely_types/dosleg/TexteAncien.d.ts +20 -0
  198. package/lib/src/kysely_types/dosleg/TexteAncien.js +3 -0
  199. package/lib/src/kysely_types/dosleg/The.d.ts +14 -0
  200. package/lib/src/kysely_types/dosleg/The.js +3 -0
  201. package/lib/src/kysely_types/dosleg/Titsen.d.ts +12 -0
  202. package/lib/src/kysely_types/dosleg/Titsen.js +3 -0
  203. package/lib/src/kysely_types/dosleg/Typatt.d.ts +12 -0
  204. package/lib/src/kysely_types/dosleg/Typatt.js +3 -0
  205. package/lib/src/kysely_types/dosleg/Typaut.d.ts +12 -0
  206. package/lib/src/kysely_types/dosleg/Typaut.js +3 -0
  207. package/lib/src/kysely_types/dosleg/Typdoc.d.ts +12 -0
  208. package/lib/src/kysely_types/dosleg/Typdoc.js +3 -0
  209. package/lib/src/kysely_types/dosleg/Typevtsea.d.ts +12 -0
  210. package/lib/src/kysely_types/dosleg/Typevtsea.js +3 -0
  211. package/lib/src/kysely_types/dosleg/Typlec.d.ts +14 -0
  212. package/lib/src/kysely_types/dosleg/Typlec.js +3 -0
  213. package/lib/src/kysely_types/dosleg/Typloi.d.ts +26 -0
  214. package/lib/src/kysely_types/dosleg/Typloi.js +3 -0
  215. package/lib/src/kysely_types/dosleg/Typorg.d.ts +20 -0
  216. package/lib/src/kysely_types/dosleg/Typorg.js +3 -0
  217. package/lib/src/kysely_types/dosleg/Typrap.d.ts +26 -0
  218. package/lib/src/kysely_types/dosleg/Typrap.js +3 -0
  219. package/lib/src/kysely_types/dosleg/Typtxt.d.ts +12 -0
  220. package/lib/src/kysely_types/dosleg/Typtxt.js +3 -0
  221. package/lib/src/kysely_types/dosleg/Typurl.d.ts +12 -0
  222. package/lib/src/kysely_types/dosleg/Typurl.js +3 -0
  223. package/lib/src/kysely_types/dosleg/Votsen.d.ts +25 -0
  224. package/lib/src/kysely_types/dosleg/Votsen.js +3 -0
  225. package/lib/src/kysely_types/questions/Database.d.ts +3 -0
  226. package/lib/src/kysely_types/questions/Database.js +3 -0
  227. package/lib/src/kysely_types/questions/Etatquestion.d.ts +14 -0
  228. package/lib/src/kysely_types/questions/Etatquestion.js +3 -0
  229. package/lib/src/kysely_types/questions/Legquestion.d.ts +18 -0
  230. package/lib/src/kysely_types/questions/Legquestion.js +3 -0
  231. package/lib/src/kysely_types/questions/Naturequestion.d.ts +15 -0
  232. package/lib/src/kysely_types/questions/Naturequestion.js +3 -0
  233. package/lib/src/kysely_types/questions/SenatSchema.d.ts +18 -0
  234. package/lib/src/kysely_types/questions/SenatSchema.js +3 -0
  235. package/lib/src/kysely_types/questions/Sortquestion.d.ts +14 -0
  236. package/lib/src/kysely_types/questions/Sortquestion.js +3 -0
  237. package/lib/src/kysely_types/questions/TamMinisteres.d.ts +28 -0
  238. package/lib/src/kysely_types/questions/TamMinisteres.js +3 -0
  239. package/lib/src/kysely_types/questions/TamQuestions.d.ts +124 -0
  240. package/lib/src/kysely_types/questions/TamQuestions.js +3 -0
  241. package/lib/src/kysely_types/questions/TamReponses.d.ts +32 -0
  242. package/lib/src/kysely_types/questions/TamReponses.js +3 -0
  243. package/lib/src/kysely_types/questions/The.d.ts +16 -0
  244. package/lib/src/kysely_types/questions/The.js +3 -0
  245. package/lib/src/kysely_types/sens/Activite.d.ts +34 -0
  246. package/lib/src/kysely_types/sens/Activite.js +3 -0
  247. package/lib/src/kysely_types/sens/ActiviteDelegation.d.ts +15 -0
  248. package/lib/src/kysely_types/sens/ActiviteDelegation.js +3 -0
  249. package/lib/src/kysely_types/sens/ActiviteLoi.d.ts +13 -0
  250. package/lib/src/kysely_types/sens/ActiviteLoi.js +3 -0
  251. package/lib/src/kysely_types/sens/ActiviteParticipant.d.ts +25 -0
  252. package/lib/src/kysely_types/sens/ActiviteParticipant.js +3 -0
  253. package/lib/src/kysely_types/sens/ActiviteSenateur.d.ts +21 -0
  254. package/lib/src/kysely_types/sens/ActiviteSenateur.js +3 -0
  255. package/lib/src/kysely_types/sens/ActivitesLiees.d.ts +10 -0
  256. package/lib/src/kysely_types/sens/ActivitesLiees.js +3 -0
  257. package/lib/src/kysely_types/sens/Actpro.d.ts +16 -0
  258. package/lib/src/kysely_types/sens/Actpro.js +3 -0
  259. package/lib/src/kysely_types/sens/Adresse.d.ts +39 -0
  260. package/lib/src/kysely_types/sens/Adresse.js +3 -0
  261. package/lib/src/kysely_types/sens/Asster.d.ts +18 -0
  262. package/lib/src/kysely_types/sens/Asster.js +3 -0
  263. package/lib/src/kysely_types/sens/Bur.d.ts +46 -0
  264. package/lib/src/kysely_types/sens/Bur.js +3 -0
  265. package/lib/src/kysely_types/sens/CategorieActivite.d.ts +13 -0
  266. package/lib/src/kysely_types/sens/CategorieActivite.js +3 -0
  267. package/lib/src/kysely_types/sens/Com.d.ts +48 -0
  268. package/lib/src/kysely_types/sens/Com.js +3 -0
  269. package/lib/src/kysely_types/sens/Csp.d.ts +22 -0
  270. package/lib/src/kysely_types/sens/Csp.js +3 -0
  271. package/lib/src/kysely_types/sens/Database.d.ts +3 -0
  272. package/lib/src/kysely_types/sens/Database.js +3 -0
  273. package/lib/src/kysely_types/sens/Delega.d.ts +46 -0
  274. package/lib/src/kysely_types/sens/Delega.js +3 -0
  275. package/lib/src/kysely_types/sens/Design.d.ts +33 -0
  276. package/lib/src/kysely_types/sens/Design.js +3 -0
  277. package/lib/src/kysely_types/sens/Designoep.d.ts +36 -0
  278. package/lib/src/kysely_types/sens/Designoep.js +3 -0
  279. package/lib/src/kysely_types/sens/Designorg.d.ts +39 -0
  280. package/lib/src/kysely_types/sens/Designorg.js +3 -0
  281. package/lib/src/kysely_types/sens/Dpt.d.ts +54 -0
  282. package/lib/src/kysely_types/sens/Dpt.js +3 -0
  283. package/lib/src/kysely_types/sens/Dptele.d.ts +35 -0
  284. package/lib/src/kysely_types/sens/Dptele.js +3 -0
  285. package/lib/src/kysely_types/sens/Dpttypman.d.ts +14 -0
  286. package/lib/src/kysely_types/sens/Dpttypman.js +3 -0
  287. package/lib/src/kysely_types/sens/Ele.d.ts +35 -0
  288. package/lib/src/kysely_types/sens/Ele.js +3 -0
  289. package/lib/src/kysely_types/sens/Elucan.d.ts +50 -0
  290. package/lib/src/kysely_types/sens/Elucan.js +3 -0
  291. package/lib/src/kysely_types/sens/Eludep.d.ts +49 -0
  292. package/lib/src/kysely_types/sens/Eludep.js +3 -0
  293. package/lib/src/kysely_types/sens/Eludiv.d.ts +47 -0
  294. package/lib/src/kysely_types/sens/Eludiv.js +3 -0
  295. package/lib/src/kysely_types/sens/Elueur.d.ts +47 -0
  296. package/lib/src/kysely_types/sens/Elueur.js +3 -0
  297. package/lib/src/kysely_types/sens/Elureg.d.ts +48 -0
  298. package/lib/src/kysely_types/sens/Elureg.js +3 -0
  299. package/lib/src/kysely_types/sens/Elusen.d.ts +52 -0
  300. package/lib/src/kysely_types/sens/Elusen.js +3 -0
  301. package/lib/src/kysely_types/sens/Eluter.d.ts +47 -0
  302. package/lib/src/kysely_types/sens/Eluter.js +3 -0
  303. package/lib/src/kysely_types/sens/Elutit.d.ts +38 -0
  304. package/lib/src/kysely_types/sens/Elutit.js +3 -0
  305. package/lib/src/kysely_types/sens/Eluvil.d.ts +48 -0
  306. package/lib/src/kysely_types/sens/Eluvil.js +3 -0
  307. package/lib/src/kysely_types/sens/Etadebman.d.ts +34 -0
  308. package/lib/src/kysely_types/sens/Etadebman.js +3 -0
  309. package/lib/src/kysely_types/sens/Etafinman.d.ts +34 -0
  310. package/lib/src/kysely_types/sens/Etafinman.js +3 -0
  311. package/lib/src/kysely_types/sens/Etasen.d.ts +34 -0
  312. package/lib/src/kysely_types/sens/Etasen.js +3 -0
  313. package/lib/src/kysely_types/sens/FonactParticipant.d.ts +16 -0
  314. package/lib/src/kysely_types/sens/FonactParticipant.js +3 -0
  315. package/lib/src/kysely_types/sens/Foncom.d.ts +40 -0
  316. package/lib/src/kysely_types/sens/Foncom.js +3 -0
  317. package/lib/src/kysely_types/sens/Fondelega.d.ts +40 -0
  318. package/lib/src/kysely_types/sens/Fondelega.js +3 -0
  319. package/lib/src/kysely_types/sens/Fongrppol.d.ts +40 -0
  320. package/lib/src/kysely_types/sens/Fongrppol.js +3 -0
  321. package/lib/src/kysely_types/sens/Fongrpsen.d.ts +27 -0
  322. package/lib/src/kysely_types/sens/Fongrpsen.js +3 -0
  323. package/lib/src/kysely_types/sens/Fonmemcom.d.ts +37 -0
  324. package/lib/src/kysely_types/sens/Fonmemcom.js +3 -0
  325. package/lib/src/kysely_types/sens/Fonmemdelega.d.ts +37 -0
  326. package/lib/src/kysely_types/sens/Fonmemdelega.js +3 -0
  327. package/lib/src/kysely_types/sens/Fonmemgrppol.d.ts +35 -0
  328. package/lib/src/kysely_types/sens/Fonmemgrppol.js +3 -0
  329. package/lib/src/kysely_types/sens/Fonmemgrpsen.d.ts +32 -0
  330. package/lib/src/kysely_types/sens/Fonmemgrpsen.js +3 -0
  331. package/lib/src/kysely_types/sens/Fonmemorg.d.ts +41 -0
  332. package/lib/src/kysely_types/sens/Fonmemorg.js +3 -0
  333. package/lib/src/kysely_types/sens/Fonorg.d.ts +40 -0
  334. package/lib/src/kysely_types/sens/Fonorg.js +3 -0
  335. package/lib/src/kysely_types/sens/Grppol.d.ts +46 -0
  336. package/lib/src/kysely_types/sens/Grppol.js +3 -0
  337. package/lib/src/kysely_types/sens/Grpsenami.d.ts +55 -0
  338. package/lib/src/kysely_types/sens/Grpsenami.js +3 -0
  339. package/lib/src/kysely_types/sens/Libcom.d.ts +36 -0
  340. package/lib/src/kysely_types/sens/Libcom.js +3 -0
  341. package/lib/src/kysely_types/sens/Libdelega.d.ts +34 -0
  342. package/lib/src/kysely_types/sens/Libdelega.js +3 -0
  343. package/lib/src/kysely_types/sens/Libgrppol.d.ts +36 -0
  344. package/lib/src/kysely_types/sens/Libgrppol.js +3 -0
  345. package/lib/src/kysely_types/sens/Libgrpsen.d.ts +28 -0
  346. package/lib/src/kysely_types/sens/Libgrpsen.js +3 -0
  347. package/lib/src/kysely_types/sens/Liborg.d.ts +34 -0
  348. package/lib/src/kysely_types/sens/Liborg.js +3 -0
  349. package/lib/src/kysely_types/sens/Mel.d.ts +19 -0
  350. package/lib/src/kysely_types/sens/Mel.js +3 -0
  351. package/lib/src/kysely_types/sens/Memcom.d.ts +37 -0
  352. package/lib/src/kysely_types/sens/Memcom.js +3 -0
  353. package/lib/src/kysely_types/sens/Memdelega.d.ts +38 -0
  354. package/lib/src/kysely_types/sens/Memdelega.js +3 -0
  355. package/lib/src/kysely_types/sens/Memextpar.d.ts +56 -0
  356. package/lib/src/kysely_types/sens/Memextpar.js +3 -0
  357. package/lib/src/kysely_types/sens/Memgrppol.d.ts +38 -0
  358. package/lib/src/kysely_types/sens/Memgrppol.js +3 -0
  359. package/lib/src/kysely_types/sens/Memgrpsen.d.ts +30 -0
  360. package/lib/src/kysely_types/sens/Memgrpsen.js +3 -0
  361. package/lib/src/kysely_types/sens/Memorg.d.ts +42 -0
  362. package/lib/src/kysely_types/sens/Memorg.js +3 -0
  363. package/lib/src/kysely_types/sens/Minind.d.ts +46 -0
  364. package/lib/src/kysely_types/sens/Minind.js +3 -0
  365. package/lib/src/kysely_types/sens/Mismin.d.ts +17 -0
  366. package/lib/src/kysely_types/sens/Mismin.js +3 -0
  367. package/lib/src/kysely_types/sens/Missen.d.ts +17 -0
  368. package/lib/src/kysely_types/sens/Missen.js +3 -0
  369. package/lib/src/kysely_types/sens/Moddes.d.ts +30 -0
  370. package/lib/src/kysely_types/sens/Moddes.js +3 -0
  371. package/lib/src/kysely_types/sens/Nation.d.ts +26 -0
  372. package/lib/src/kysely_types/sens/Nation.js +3 -0
  373. package/lib/src/kysely_types/sens/Nationgrpsen.d.ts +31 -0
  374. package/lib/src/kysely_types/sens/Nationgrpsen.js +3 -0
  375. package/lib/src/kysely_types/sens/Org.d.ts +46 -0
  376. package/lib/src/kysely_types/sens/Org.js +3 -0
  377. package/lib/src/kysely_types/sens/Orgext.d.ts +72 -0
  378. package/lib/src/kysely_types/sens/Orgext.js +3 -0
  379. package/lib/src/kysely_types/sens/Orgthe.d.ts +12 -0
  380. package/lib/src/kysely_types/sens/Orgthe.js +3 -0
  381. package/lib/src/kysely_types/sens/Pcs.d.ts +15 -0
  382. package/lib/src/kysely_types/sens/Pcs.js +3 -0
  383. package/lib/src/kysely_types/sens/Pcs24.d.ts +15 -0
  384. package/lib/src/kysely_types/sens/Pcs24.js +3 -0
  385. package/lib/src/kysely_types/sens/Pcs42.d.ts +15 -0
  386. package/lib/src/kysely_types/sens/Pcs42.js +3 -0
  387. package/lib/src/kysely_types/sens/Pcs8.d.ts +12 -0
  388. package/lib/src/kysely_types/sens/Pcs8.js +3 -0
  389. package/lib/src/kysely_types/sens/Pcscatpro.d.ts +15 -0
  390. package/lib/src/kysely_types/sens/Pcscatpro.js +3 -0
  391. package/lib/src/kysely_types/sens/Poicon.d.ts +20 -0
  392. package/lib/src/kysely_types/sens/Poicon.js +3 -0
  393. package/lib/src/kysely_types/sens/Qua.d.ts +30 -0
  394. package/lib/src/kysely_types/sens/Qua.js +3 -0
  395. package/lib/src/kysely_types/sens/Reg.d.ts +38 -0
  396. package/lib/src/kysely_types/sens/Reg.js +3 -0
  397. package/lib/src/kysely_types/sens/Sen.d.ts +66 -0
  398. package/lib/src/kysely_types/sens/Sen.js +3 -0
  399. package/lib/src/kysely_types/sens/SenatSchema.d.ts +198 -0
  400. package/lib/src/kysely_types/sens/SenatSchema.js +3 -0
  401. package/lib/src/kysely_types/sens/Senbur.d.ts +41 -0
  402. package/lib/src/kysely_types/sens/Senbur.js +3 -0
  403. package/lib/src/kysely_types/sens/Sennom.d.ts +32 -0
  404. package/lib/src/kysely_types/sens/Sennom.js +3 -0
  405. package/lib/src/kysely_types/sens/Senurl.d.ts +35 -0
  406. package/lib/src/kysely_types/sens/Senurl.js +3 -0
  407. package/lib/src/kysely_types/sens/Stajur.d.ts +19 -0
  408. package/lib/src/kysely_types/sens/Stajur.js +3 -0
  409. package/lib/src/kysely_types/sens/Telephone.d.ts +21 -0
  410. package/lib/src/kysely_types/sens/Telephone.js +3 -0
  411. package/lib/src/kysely_types/sens/Temval.d.ts +14 -0
  412. package/lib/src/kysely_types/sens/Temval.js +3 -0
  413. package/lib/src/kysely_types/sens/Territ.d.ts +25 -0
  414. package/lib/src/kysely_types/sens/Territ.js +3 -0
  415. package/lib/src/kysely_types/sens/Titele.d.ts +32 -0
  416. package/lib/src/kysely_types/sens/Titele.js +3 -0
  417. package/lib/src/kysely_types/sens/Typadr.d.ts +20 -0
  418. package/lib/src/kysely_types/sens/Typadr.js +3 -0
  419. package/lib/src/kysely_types/sens/Typapppol.d.ts +34 -0
  420. package/lib/src/kysely_types/sens/Typapppol.js +3 -0
  421. package/lib/src/kysely_types/sens/Typbister.d.ts +16 -0
  422. package/lib/src/kysely_types/sens/Typbister.js +3 -0
  423. package/lib/src/kysely_types/sens/TypeActivite.d.ts +11 -0
  424. package/lib/src/kysely_types/sens/TypeActivite.js +3 -0
  425. package/lib/src/kysely_types/sens/TypeActiviteParticipant.d.ts +10 -0
  426. package/lib/src/kysely_types/sens/TypeActiviteParticipant.js +3 -0
  427. package/lib/src/kysely_types/sens/TypeActiviteSenateur.d.ts +11 -0
  428. package/lib/src/kysely_types/sens/TypeActiviteSenateur.js +3 -0
  429. package/lib/src/kysely_types/sens/TypeCategorie.d.ts +11 -0
  430. package/lib/src/kysely_types/sens/TypeCategorie.js +3 -0
  431. package/lib/src/kysely_types/sens/Typele.d.ts +22 -0
  432. package/lib/src/kysely_types/sens/Typele.js +3 -0
  433. package/lib/src/kysely_types/sens/Typgrpsen.d.ts +23 -0
  434. package/lib/src/kysely_types/sens/Typgrpsen.js +3 -0
  435. package/lib/src/kysely_types/sens/Typman.d.ts +20 -0
  436. package/lib/src/kysely_types/sens/Typman.js +3 -0
  437. package/lib/src/kysely_types/sens/Typorg.d.ts +26 -0
  438. package/lib/src/kysely_types/sens/Typorg.js +3 -0
  439. package/lib/src/kysely_types/sens/Typurl.d.ts +31 -0
  440. package/lib/src/kysely_types/sens/Typurl.js +3 -0
  441. package/lib/src/kysely_types/sens/Typvoi.d.ts +16 -0
  442. package/lib/src/kysely_types/sens/Typvoi.js +3 -0
  443. package/lib/src/kysely_types/sens/Zongeo.d.ts +22 -0
  444. package/lib/src/kysely_types/sens/Zongeo.js +3 -0
  445. package/lib/src/loaders.d.ts +3 -3
  446. package/lib/src/loaders.js +1 -1
  447. package/lib/src/model/agenda.d.ts +1 -1
  448. package/lib/src/model/commission.d.ts +2 -2
  449. package/lib/src/model/seance.d.ts +1 -1
  450. package/lib/src/other_types/agenda.d.ts +45 -0
  451. package/lib/src/other_types/agenda.js +1 -0
  452. package/lib/src/other_types/compte_rendu.d.ts +83 -0
  453. package/lib/src/other_types/compte_rendu.js +1 -0
  454. package/lib/src/other_types/questions.d.ts +2 -0
  455. package/lib/src/other_types/questions.js +1 -0
  456. package/lib/src/other_types/sens.d.ts +8 -0
  457. package/lib/src/other_types/sens.js +1 -0
  458. package/lib/src/other_types/sessions.d.ts +6 -0
  459. package/lib/src/other_types/sessions.js +19 -0
  460. package/lib/src/other_types/texte.d.ts +72 -0
  461. package/lib/src/other_types/texte.js +15 -0
  462. package/lib/src/parsers/texte.d.ts +1 -1
  463. package/lib/src/parsers/texte.js +1 -1
  464. package/lib/src/questions.d.ts +53 -0
  465. package/lib/src/questions.js +1 -0
  466. package/lib/src/rich_types/agenda.d.ts +45 -0
  467. package/lib/src/rich_types/agenda.js +1 -0
  468. package/lib/src/rich_types/ameli.d.ts +70 -0
  469. package/lib/src/rich_types/ameli.js +1 -0
  470. package/lib/src/rich_types/compte_rendu.d.ts +83 -0
  471. package/lib/src/rich_types/compte_rendu.js +1 -0
  472. package/lib/src/rich_types/debats.d.ts +38 -0
  473. package/lib/src/rich_types/debats.js +1 -0
  474. package/lib/src/rich_types/dosleg.d.ts +212 -0
  475. package/lib/src/rich_types/dosleg.js +193 -0
  476. package/lib/src/rich_types/questions.d.ts +55 -0
  477. package/lib/src/rich_types/questions.js +1 -0
  478. package/lib/src/rich_types/sens.d.ts +104 -0
  479. package/lib/src/rich_types/sens.js +1 -0
  480. package/lib/src/rich_types/sessions.d.ts +6 -0
  481. package/lib/src/rich_types/sessions.js +19 -0
  482. package/lib/src/rich_types/texte.d.ts +72 -0
  483. package/lib/src/rich_types/texte.js +15 -0
  484. package/lib/src/schemas/config.d.ts +9 -0
  485. package/lib/src/schemas/config.js +10 -0
  486. package/lib/src/scripts/convert_data.js +6 -6
  487. package/lib/src/scripts/convert_xml_to_html.js +1 -1
  488. package/lib/src/scripts/datautil.d.ts +1 -1
  489. package/lib/src/scripts/retrieve_agenda.js +4 -4
  490. package/lib/src/scripts/retrieve_cr_commission.js +6 -6
  491. package/lib/src/scripts/retrieve_cr_seance.d.ts +1 -1
  492. package/lib/src/scripts/retrieve_cr_seance.js +4 -4
  493. package/lib/src/scripts/retrieve_documents.d.ts +1 -1
  494. package/lib/src/scripts/retrieve_documents.js +4 -4
  495. package/lib/src/scripts/retrieve_open_data.js +72 -8
  496. package/lib/src/scripts/retrieve_senateurs_photos.js +2 -2
  497. package/lib/src/scripts/retrieve_videos.js +3 -3
  498. package/lib/src/scripts/shared/incremental_import_sql.js +22 -7
  499. package/lib/src/scripts/shared/prefixed_tables.d.ts +2 -1
  500. package/lib/src/scripts/shared/prefixed_tables.js +4 -3
  501. package/lib/src/scripts/shared/staging_import.d.ts +1 -1
  502. package/lib/src/scripts/validate_prefixed_tables.js +12 -11
  503. package/lib/src/scrutins.d.ts +47 -0
  504. package/lib/src/scrutins.js +1 -0
  505. package/lib/src/sens.d.ts +104 -0
  506. package/lib/src/sens.js +1 -0
  507. package/lib/src/server/agenda.d.ts +6 -0
  508. package/lib/src/server/agenda.js +148 -0
  509. package/lib/src/server/ameli.d.ts +2 -0
  510. package/lib/src/server/ameli.js +153 -0
  511. package/lib/src/server/commission.d.ts +19 -0
  512. package/lib/src/server/commission.js +269 -0
  513. package/lib/src/server/config.d.ts +43 -0
  514. package/lib/src/server/config.js +37 -0
  515. package/lib/src/server/conversion_textes.d.ts +11 -0
  516. package/lib/src/server/conversion_textes.js +320 -0
  517. package/lib/src/server/databases_postgres.d.ts +32 -0
  518. package/lib/src/server/databases_postgres.js +50 -0
  519. package/lib/src/server/datasets.d.ts +38 -0
  520. package/lib/src/server/datasets.js +247 -0
  521. package/lib/src/server/debats.d.ts +2 -0
  522. package/lib/src/server/debats.js +98 -0
  523. package/lib/src/server/documents.d.ts +3 -0
  524. package/lib/src/server/documents.js +132 -0
  525. package/lib/src/server/dosleg.d.ts +2 -0
  526. package/lib/src/server/dosleg.js +228 -0
  527. package/lib/src/server/git.d.ts +27 -0
  528. package/lib/src/server/git.js +251 -0
  529. package/lib/src/server/index.d.ts +18 -0
  530. package/lib/src/server/index.js +16 -0
  531. package/lib/src/server/loaders.d.ts +52 -0
  532. package/lib/src/server/loaders.js +260 -0
  533. package/lib/src/server/questions.d.ts +2 -0
  534. package/lib/src/server/questions.js +89 -0
  535. package/lib/src/server/scrutins.d.ts +2 -0
  536. package/lib/src/server/scrutins.js +114 -0
  537. package/lib/src/server/seance.d.ts +3 -0
  538. package/lib/src/server/seance.js +267 -0
  539. package/lib/src/server/sens.d.ts +9 -0
  540. package/lib/src/server/sens.js +353 -0
  541. package/lib/src/types/ameli.d.ts +1761 -4
  542. package/lib/src/types/ameli.js +1074 -1
  543. package/lib/src/types/debats.d.ts +380 -2
  544. package/lib/src/types/debats.js +266 -1
  545. package/lib/src/types/dosleg.d.ts +2953 -69
  546. package/lib/src/types/dosleg.js +2005 -1
  547. package/lib/src/types/questions.d.ts +699 -2
  548. package/lib/src/types/questions.js +493 -1
  549. package/lib/src/types/sens.d.ts +7842 -7
  550. package/lib/src/types/sens.js +4691 -1
  551. package/lib/src/util.d.ts +1 -0
  552. package/lib/src/util.js +15 -0
  553. package/lib/src/utils/cr_spliting.d.ts +1 -1
  554. package/lib/src/utils/cr_spliting.js +2 -2
  555. package/lib/src/utils/reunion_odj_building.d.ts +2 -2
  556. package/lib/src/utils/reunion_odj_building.js +2 -2
  557. package/lib/src/utils/reunion_parsing.d.ts +2 -2
  558. package/lib/src/utils/scoring.d.ts +1 -1
  559. package/lib/src/videos/match.d.ts +1 -1
  560. package/lib/src/videos/pipeline.d.ts +1 -1
  561. package/lib/src/videos/pipeline.js +1 -1
  562. package/lib/src/videos/search.d.ts +1 -1
  563. package/lib/tests/test_iter_load.test.js +1 -1
  564. package/lib/tests/validatePrefixedTables.test.js +1 -1
  565. package/lib/tsconfig.tsbuildinfo +1 -0
  566. 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
+ }