@tricoteuses/senat 2.22.16 → 3.0.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 (345) hide show
  1. package/README.md +168 -0
  2. package/lib/aggregates.d.ts +52 -0
  3. package/lib/aggregates.js +930 -0
  4. package/lib/aggregates.mjs +713 -0
  5. package/lib/aggregates.ts +833 -0
  6. package/lib/config.d.ts +10 -0
  7. package/lib/config.js +16 -0
  8. package/lib/config.mjs +16 -0
  9. package/lib/config.ts +26 -0
  10. package/lib/databases.d.ts +2 -0
  11. package/lib/databases.js +26 -0
  12. package/lib/databases.mjs +57 -0
  13. package/lib/databases.ts +71 -0
  14. package/lib/datasets.d.ts +34 -0
  15. package/lib/datasets.js +233 -0
  16. package/lib/datasets.mjs +78 -0
  17. package/lib/datasets.ts +118 -0
  18. package/lib/fields.d.ts +10 -0
  19. package/lib/fields.js +68 -0
  20. package/lib/fields.mjs +22 -0
  21. package/lib/fields.ts +29 -0
  22. package/lib/git.d.ts +26 -0
  23. package/lib/git.js +167 -0
  24. package/lib/index.d.ts +13 -0
  25. package/lib/index.js +1 -0
  26. package/lib/index.mjs +7 -0
  27. package/lib/index.ts +64 -0
  28. package/lib/inserters.d.ts +98 -0
  29. package/lib/inserters.js +500 -0
  30. package/lib/inserters.mjs +360 -0
  31. package/lib/inserters.ts +521 -0
  32. package/lib/legislatures.json +38 -0
  33. package/lib/loaders.d.ts +58 -0
  34. package/lib/loaders.js +286 -0
  35. package/lib/loaders.mjs +158 -0
  36. package/lib/loaders.ts +271 -0
  37. package/lib/model/agenda.d.ts +6 -0
  38. package/lib/model/agenda.js +148 -0
  39. package/lib/model/ameli.d.ts +51 -0
  40. package/lib/model/ameli.js +149 -0
  41. package/lib/model/ameli.mjs +84 -0
  42. package/lib/model/ameli.ts +100 -0
  43. package/lib/model/commission.d.ts +18 -0
  44. package/lib/model/commission.js +269 -0
  45. package/lib/model/debats.d.ts +67 -0
  46. package/lib/model/debats.js +95 -0
  47. package/lib/model/debats.mjs +43 -0
  48. package/lib/model/debats.ts +68 -0
  49. package/lib/model/documents.d.ts +12 -0
  50. package/lib/model/documents.js +151 -0
  51. package/lib/model/dosleg.d.ts +7 -0
  52. package/lib/model/dosleg.js +326 -0
  53. package/lib/model/dosleg.mjs +196 -0
  54. package/lib/model/dosleg.ts +240 -0
  55. package/lib/model/index.d.ts +7 -0
  56. package/lib/model/index.js +7 -0
  57. package/lib/model/index.mjs +5 -0
  58. package/lib/model/index.ts +15 -0
  59. package/lib/model/questions.d.ts +45 -0
  60. package/lib/model/questions.js +89 -0
  61. package/lib/model/questions.mjs +71 -0
  62. package/lib/model/questions.ts +93 -0
  63. package/lib/model/scrutins.d.ts +13 -0
  64. package/lib/model/scrutins.js +114 -0
  65. package/lib/model/seance.d.ts +3 -0
  66. package/lib/model/seance.js +267 -0
  67. package/lib/model/sens.d.ts +146 -0
  68. package/lib/model/sens.js +454 -0
  69. package/lib/model/sens.mjs +415 -0
  70. package/lib/model/sens.ts +516 -0
  71. package/lib/model/texte.d.ts +7 -0
  72. package/lib/model/texte.js +256 -0
  73. package/lib/model/texte.mjs +208 -0
  74. package/lib/model/texte.ts +229 -0
  75. package/lib/model/util.d.ts +9 -0
  76. package/lib/model/util.js +38 -0
  77. package/lib/model/util.mjs +19 -0
  78. package/lib/model/util.ts +32 -0
  79. package/lib/parsers/texte.d.ts +7 -0
  80. package/lib/parsers/texte.js +228 -0
  81. package/lib/raw_types/ameli.d.ts +914 -0
  82. package/lib/raw_types/ameli.js +5 -0
  83. package/lib/raw_types/ameli.mjs +163 -0
  84. package/lib/raw_types/debats.d.ts +207 -0
  85. package/lib/raw_types/debats.js +5 -0
  86. package/lib/raw_types/debats.mjs +58 -0
  87. package/lib/raw_types/dosleg.d.ts +1619 -0
  88. package/lib/raw_types/dosleg.js +5 -0
  89. package/lib/raw_types/dosleg.mjs +438 -0
  90. package/lib/raw_types/questions.d.ts +419 -0
  91. package/lib/raw_types/questions.js +5 -0
  92. package/lib/raw_types/questions.mjs +11 -0
  93. package/lib/raw_types/senat.d.ts +11368 -0
  94. package/lib/raw_types/senat.js +5 -0
  95. package/lib/raw_types/sens.d.ts +8248 -0
  96. package/lib/raw_types/sens.js +5 -0
  97. package/lib/raw_types/sens.mjs +508 -0
  98. package/lib/raw_types_kysely/ameli.d.ts +915 -0
  99. package/lib/raw_types_kysely/ameli.js +7 -0
  100. package/lib/raw_types_kysely/ameli.mjs +5 -0
  101. package/lib/raw_types_kysely/ameli.ts +951 -0
  102. package/lib/raw_types_kysely/debats.d.ts +207 -0
  103. package/lib/raw_types_kysely/debats.js +7 -0
  104. package/lib/raw_types_kysely/debats.mjs +5 -0
  105. package/lib/raw_types_kysely/debats.ts +222 -0
  106. package/lib/raw_types_kysely/dosleg.d.ts +3532 -0
  107. package/lib/raw_types_kysely/dosleg.js +7 -0
  108. package/lib/raw_types_kysely/dosleg.mjs +5 -0
  109. package/lib/raw_types_kysely/dosleg.ts +3621 -0
  110. package/lib/raw_types_kysely/questions.d.ts +414 -0
  111. package/lib/raw_types_kysely/questions.js +7 -0
  112. package/lib/raw_types_kysely/questions.mjs +5 -0
  113. package/lib/raw_types_kysely/questions.ts +426 -0
  114. package/lib/raw_types_kysely/sens.d.ts +4394 -0
  115. package/lib/raw_types_kysely/sens.js +7 -0
  116. package/lib/raw_types_kysely/sens.mjs +5 -0
  117. package/lib/raw_types_kysely/sens.ts +4499 -0
  118. package/lib/raw_types_schemats/ameli.d.ts +539 -0
  119. package/lib/raw_types_schemats/ameli.js +2 -0
  120. package/lib/raw_types_schemats/ameli.mjs +2 -0
  121. package/lib/raw_types_schemats/ameli.ts +601 -0
  122. package/lib/raw_types_schemats/debats.d.ts +127 -0
  123. package/lib/raw_types_schemats/debats.js +2 -0
  124. package/lib/raw_types_schemats/debats.mjs +2 -0
  125. package/lib/raw_types_schemats/debats.ts +145 -0
  126. package/lib/raw_types_schemats/dosleg.d.ts +977 -0
  127. package/lib/raw_types_schemats/dosleg.js +2 -0
  128. package/lib/raw_types_schemats/dosleg.mjs +2 -0
  129. package/lib/raw_types_schemats/dosleg.ts +2193 -0
  130. package/lib/raw_types_schemats/questions.d.ts +235 -0
  131. package/lib/raw_types_schemats/questions.js +2 -0
  132. package/lib/raw_types_schemats/questions.mjs +2 -0
  133. package/lib/raw_types_schemats/questions.ts +249 -0
  134. package/lib/raw_types_schemats/sens.d.ts +6915 -0
  135. package/lib/raw_types_schemats/sens.js +2 -0
  136. package/lib/raw_types_schemats/sens.mjs +2 -0
  137. package/lib/raw_types_schemats/sens.ts +2907 -0
  138. package/lib/scripts/convert_data.d.ts +1 -0
  139. package/lib/scripts/convert_data.js +354 -0
  140. package/lib/scripts/convert_data.mjs +181 -0
  141. package/lib/scripts/convert_data.ts +243 -0
  142. package/lib/scripts/data-download.d.ts +1 -0
  143. package/lib/scripts/data-download.js +12 -0
  144. package/lib/scripts/datautil.d.ts +8 -0
  145. package/lib/scripts/datautil.js +34 -0
  146. package/lib/scripts/datautil.mjs +16 -0
  147. package/lib/scripts/datautil.ts +19 -0
  148. package/lib/scripts/images/transparent_150x192.jpg +0 -0
  149. package/lib/scripts/images/transparent_155x225.jpg +0 -0
  150. package/lib/scripts/parse_textes.d.ts +1 -0
  151. package/lib/scripts/parse_textes.js +44 -0
  152. package/lib/scripts/parse_textes.mjs +46 -0
  153. package/lib/scripts/parse_textes.ts +65 -0
  154. package/lib/scripts/retrieve_agenda.d.ts +1 -0
  155. package/lib/scripts/retrieve_agenda.js +132 -0
  156. package/lib/scripts/retrieve_cr_commission.d.ts +1 -0
  157. package/lib/scripts/retrieve_cr_commission.js +364 -0
  158. package/lib/scripts/retrieve_cr_seance.d.ts +6 -0
  159. package/lib/scripts/retrieve_cr_seance.js +347 -0
  160. package/lib/scripts/retrieve_documents.d.ts +3 -0
  161. package/lib/scripts/retrieve_documents.js +219 -0
  162. package/lib/scripts/retrieve_documents.mjs +249 -0
  163. package/lib/scripts/retrieve_documents.ts +298 -0
  164. package/lib/scripts/retrieve_open_data.d.ts +1 -0
  165. package/lib/scripts/retrieve_open_data.js +315 -0
  166. package/lib/scripts/retrieve_open_data.mjs +217 -0
  167. package/lib/scripts/retrieve_open_data.ts +268 -0
  168. package/lib/scripts/retrieve_senateurs_photos.d.ts +1 -0
  169. package/lib/scripts/retrieve_senateurs_photos.js +147 -0
  170. package/lib/scripts/retrieve_senateurs_photos.mjs +147 -0
  171. package/lib/scripts/retrieve_senateurs_photos.ts +177 -0
  172. package/lib/scripts/retrieve_videos.d.ts +1 -0
  173. package/lib/scripts/retrieve_videos.js +461 -0
  174. package/lib/scripts/shared/cli_helpers.d.ts +95 -0
  175. package/lib/scripts/shared/cli_helpers.js +91 -0
  176. package/lib/scripts/shared/cli_helpers.ts +36 -0
  177. package/lib/scripts/shared/util.d.ts +4 -0
  178. package/lib/scripts/shared/util.js +35 -0
  179. package/lib/scripts/shared/util.ts +33 -0
  180. package/lib/scripts/test_iter_load.d.ts +1 -0
  181. package/lib/scripts/test_iter_load.js +12 -0
  182. package/lib/src/config.d.ts +22 -0
  183. package/lib/src/config.js +17 -7
  184. package/lib/src/conversion_textes.js +5 -1
  185. package/lib/src/databases.d.ts +2 -1
  186. package/lib/src/databases_postgres.d.ts +4 -0
  187. package/lib/src/databases_postgres.js +23 -0
  188. package/lib/src/datasets.d.ts +4 -0
  189. package/lib/src/datasets.js +16 -2
  190. package/lib/src/git.d.ts +1 -0
  191. package/lib/src/git.js +45 -11
  192. package/lib/src/index.d.ts +19 -8
  193. package/lib/src/index.js +6 -1
  194. package/lib/src/loaders.js +10 -4
  195. package/lib/src/model/agenda.js +2 -2
  196. package/lib/src/model/ameli.d.ts +64 -52
  197. package/lib/src/model/ameli.js +147 -145
  198. package/lib/src/model/ameli_postgres.d.ts +67 -0
  199. package/lib/src/model/ameli_postgres.js +150 -0
  200. package/lib/src/model/commission.d.ts +3 -2
  201. package/lib/src/model/commission.js +2 -2
  202. package/lib/src/model/debats.d.ts +38 -66
  203. package/lib/src/model/debats.js +110 -93
  204. package/lib/src/model/documents.d.ts +32 -12
  205. package/lib/src/model/documents.js +171 -130
  206. package/lib/src/model/dosleg.d.ts +142 -5
  207. package/lib/src/model/dosleg.js +298 -156
  208. package/lib/src/model/questions.d.ts +54 -45
  209. package/lib/src/model/questions.js +89 -87
  210. package/lib/src/model/scrutins.d.ts +48 -13
  211. package/lib/src/model/scrutins.js +118 -111
  212. package/lib/src/model/seance.js +3 -3
  213. package/lib/src/model/sens.d.ts +109 -179
  214. package/lib/src/model/sens.js +384 -484
  215. package/lib/src/model/util.d.ts +0 -8
  216. package/lib/src/model/util.js +0 -23
  217. package/lib/src/parsers/texte.js +7 -7
  218. package/lib/src/raw_types/ameli.d.ts +1651 -803
  219. package/lib/src/raw_types/ameli.js +1816 -5
  220. package/lib/src/raw_types/debats.d.ts +353 -180
  221. package/lib/src/raw_types/debats.js +517 -5
  222. package/lib/src/raw_types/dosleg.d.ts +2862 -1527
  223. package/lib/src/raw_types/dosleg.js +4354 -5
  224. package/lib/src/raw_types/questions.d.ts +671 -395
  225. package/lib/src/raw_types/questions.js +1303 -5
  226. package/lib/src/raw_types/sens.d.ts +7743 -8148
  227. package/lib/src/raw_types/sens.js +10429 -5
  228. package/lib/src/raw_types_schemats/ameli.d.ts +4 -2
  229. package/lib/src/raw_types_schemats/debats.d.ts +2 -2
  230. package/lib/src/raw_types_schemats/dosleg.d.ts +2 -2
  231. package/lib/src/raw_types_schemats/questions.d.ts +2 -2
  232. package/lib/src/raw_types_schemats/sens.d.ts +10 -4216
  233. package/lib/src/scripts/convert_data.js +7 -6
  234. package/lib/src/scripts/convert_xml_to_html.js +2 -2
  235. package/lib/src/scripts/data-download.js +3 -2
  236. package/lib/src/scripts/retrieve_agenda.js +21 -9
  237. package/lib/src/scripts/retrieve_cr_commission.js +17 -17
  238. package/lib/src/scripts/retrieve_cr_seance.d.ts +14 -1
  239. package/lib/src/scripts/retrieve_cr_seance.js +10 -11
  240. package/lib/src/scripts/retrieve_documents.d.ts +11 -2
  241. package/lib/src/scripts/retrieve_documents.js +25 -14
  242. package/lib/src/scripts/retrieve_open_data.js +514 -153
  243. package/lib/src/scripts/retrieve_senateurs_photos.js +25 -11
  244. package/lib/src/scripts/retrieve_videos.js +12 -11
  245. package/lib/src/scripts/shared/cli_helpers.d.ts +1 -6
  246. package/lib/src/scripts/shared/cli_helpers.js +9 -8
  247. package/lib/src/scripts/shared/incremental_import_sql.d.ts +2 -0
  248. package/lib/src/scripts/shared/incremental_import_sql.js +894 -0
  249. package/lib/src/scripts/shared/prefixed_tables.d.ts +10 -0
  250. package/lib/src/scripts/shared/prefixed_tables.js +36 -0
  251. package/lib/src/scripts/shared/schema_version.d.ts +3 -0
  252. package/lib/src/scripts/shared/schema_version.js +97 -0
  253. package/lib/src/scripts/shared/staging_import.d.ts +3 -0
  254. package/lib/src/scripts/shared/staging_import.js +80 -0
  255. package/lib/src/scripts/shared/staging_metadata_sql.d.ts +1 -0
  256. package/lib/src/scripts/shared/staging_metadata_sql.js +221 -0
  257. package/lib/src/scripts/validate_prefixed_tables.d.ts +1 -0
  258. package/lib/src/scripts/validate_prefixed_tables.js +101 -0
  259. package/lib/src/types/ameli.d.ts +4 -4
  260. package/lib/src/types/debats.d.ts +2 -2
  261. package/lib/src/types/dosleg.d.ts +39 -39
  262. package/lib/src/types/questions.d.ts +2 -2
  263. package/lib/src/types/sens.d.ts +0 -2
  264. package/lib/src/types/texte.d.ts +1 -1
  265. package/lib/src/utils/cr_spliting.d.ts +9 -6
  266. package/lib/src/utils/cr_spliting.js +6 -101
  267. package/lib/src/utils/reunion_odj_building.d.ts +7 -3
  268. package/lib/src/utils/reunion_parsing.d.ts +2 -1
  269. package/lib/src/utils/reunion_parsing.js +2 -2
  270. package/lib/src/videos/match.js +8 -5
  271. package/lib/src/videos/pipeline.d.ts +6 -2
  272. package/lib/src/videos/pipeline.js +21 -8
  273. package/lib/src/videos/search.js +6 -2
  274. package/lib/strings.d.ts +1 -0
  275. package/lib/strings.js +18 -0
  276. package/lib/strings.mjs +18 -0
  277. package/lib/strings.ts +26 -0
  278. package/lib/tests/incrementalImportSql.test.d.ts +1 -0
  279. package/lib/tests/incrementalImportSql.test.js +155 -0
  280. package/lib/tests/prefixedTables.test.d.ts +1 -0
  281. package/lib/tests/prefixedTables.test.js +22 -0
  282. package/lib/tests/schemaVersion.test.d.ts +1 -0
  283. package/lib/tests/schemaVersion.test.js +23 -0
  284. package/lib/tests/validatePrefixedTables.test.d.ts +1 -0
  285. package/lib/tests/validatePrefixedTables.test.js +14 -0
  286. package/lib/types/agenda.d.ts +44 -0
  287. package/lib/types/agenda.js +1 -0
  288. package/lib/types/ameli.d.ts +5 -0
  289. package/lib/types/ameli.js +1 -0
  290. package/lib/types/ameli.mjs +13 -0
  291. package/lib/types/ameli.ts +21 -0
  292. package/lib/types/compte_rendu.d.ts +83 -0
  293. package/lib/types/compte_rendu.js +1 -0
  294. package/lib/types/debats.d.ts +2 -0
  295. package/lib/types/debats.js +1 -0
  296. package/lib/types/debats.mjs +2 -0
  297. package/lib/types/debats.ts +6 -0
  298. package/lib/types/dosleg.d.ts +70 -0
  299. package/lib/types/dosleg.js +1 -0
  300. package/lib/types/dosleg.mjs +151 -0
  301. package/lib/types/dosleg.ts +284 -0
  302. package/lib/types/questions.d.ts +2 -0
  303. package/lib/types/questions.js +1 -0
  304. package/lib/types/questions.mjs +1 -0
  305. package/lib/types/questions.ts +3 -0
  306. package/lib/types/sens.d.ts +10 -0
  307. package/lib/types/sens.js +1 -0
  308. package/lib/types/sens.mjs +1 -0
  309. package/lib/types/sens.ts +12 -0
  310. package/lib/types/sessions.d.ts +5 -0
  311. package/lib/types/sessions.js +84 -0
  312. package/lib/types/sessions.mjs +43 -0
  313. package/lib/types/sessions.ts +42 -0
  314. package/lib/types/texte.d.ts +74 -0
  315. package/lib/types/texte.js +16 -0
  316. package/lib/types/texte.mjs +16 -0
  317. package/lib/types/texte.ts +76 -0
  318. package/lib/typings/windows-1252.d.js +2 -0
  319. package/lib/typings/windows-1252.d.mjs +2 -0
  320. package/lib/typings/windows-1252.d.ts +11 -0
  321. package/lib/utils/cr_spliting.d.ts +28 -0
  322. package/lib/utils/cr_spliting.js +265 -0
  323. package/lib/utils/date.d.ts +10 -0
  324. package/lib/utils/date.js +100 -0
  325. package/lib/utils/nvs-timecode.d.ts +7 -0
  326. package/lib/utils/nvs-timecode.js +79 -0
  327. package/lib/utils/reunion_grouping.d.ts +9 -0
  328. package/lib/utils/reunion_grouping.js +361 -0
  329. package/lib/utils/reunion_odj_building.d.ts +5 -0
  330. package/lib/utils/reunion_odj_building.js +154 -0
  331. package/lib/utils/reunion_parsing.d.ts +23 -0
  332. package/lib/utils/reunion_parsing.js +209 -0
  333. package/lib/utils/scoring.d.ts +14 -0
  334. package/lib/utils/scoring.js +147 -0
  335. package/lib/utils/string_cleaning.d.ts +7 -0
  336. package/lib/utils/string_cleaning.js +57 -0
  337. package/lib/validators/config.d.ts +9 -0
  338. package/lib/validators/config.js +10 -0
  339. package/lib/validators/config.mjs +54 -0
  340. package/lib/validators/config.ts +79 -0
  341. package/lib/validators/senat.d.ts +0 -0
  342. package/lib/validators/senat.js +28 -0
  343. package/lib/validators/senat.mjs +24 -0
  344. package/lib/validators/senat.ts +26 -0
  345. package/package.json +11 -11
@@ -1,485 +1,385 @@
1
- import { jsonArrayFrom, jsonObjectFrom } from "kysely/helpers/postgres";
2
- import { dbSenat } from "../databases";
3
- import { concat, nullIf, rtrim, toDateString } from "./util";
4
- function circonscription(dptNum) {
5
- return jsonObjectFrom(dbSenat
6
- .withSchema("sens")
7
- .selectFrom("dpt")
8
- .leftJoin("reg", "dpt.regcod", "reg.regcod")
9
- .where("dpt.dptnum", "=", dptNum)
10
- .select(["dpt.dptcod as code", "dpt.dptlib as libelle_departement", "reg.reglib as libelle_region"]));
11
- }
12
- function textes(actId) {
13
- return jsonArrayFrom(dbSenat
14
- .withSchema("sens")
15
- .selectFrom("activite_loi")
16
- .where("actid", "=", actId)
17
- .select(({ ref }) => [rtrim(ref("loicod")).as("loicod")]));
18
- }
19
- function delegations(actId) {
20
- return jsonArrayFrom(dbSenat.withSchema("sens").selectFrom("activite_delegation").where("actid", "=", actId).orderBy("delegidx", "asc"));
21
- }
22
- function activites(senMat) {
23
- return jsonArrayFrom(dbSenat
24
- .withSchema("sens")
25
- .selectFrom("activite")
26
- .leftJoin("activite_participant", "activite.actid", "activite_participant.actid")
27
- .leftJoin("type_activite", "activite.typactcod", "type_activite.typactcod")
28
- .leftJoin("categorie_activite", "activite.catactcod", "categorie_activite.catactcod")
29
- .where("activite_participant.senmat", "=", senMat)
30
- .select(({ ref }) => [
31
- delegations(ref("activite.actid")).as("delegations"),
32
- textes(ref("activite.actid")).as("textes"),
33
- ])
34
- .orderBy("activite.datdeb", "desc"));
35
- }
36
- function activitesPerso(senMat) {
37
- return jsonArrayFrom(dbSenat
38
- .withSchema("sens")
39
- .selectFrom("activite_senateur")
40
- .leftJoin("type_activite_senateur", "activite_senateur.typactsencod", "type_activite_senateur.typactsencod")
41
- .where("activite_senateur.senmat", "=", senMat)
42
- .orderBy("activite_senateur.datdeb", "desc"));
43
- }
44
- function fonctionsBureau(senMat) {
45
- return jsonArrayFrom(dbSenat
46
- .withSchema("sens")
47
- .selectFrom("senbur")
48
- .leftJoin("bur", "senbur.burcod", "bur.burcod")
49
- .where("senbur.senmat", "=", senMat)
50
- .select(({ eb, ref }) => [
51
- toDateString(ref("senbur.senburdatdeb")).as("date_debut"),
52
- toDateString(ref("senbur.senburdatfin")).as("date_fin"),
53
- eb.fn.coalesce(nullIf(ref("bur.burlib")), nullIf(ref("bur.burlil")), nullIf(ref("bur.burlic"))).as("libelle"),
54
- ])
55
- .orderBy("senbur.senburdatdeb", "desc"));
56
- }
57
- function mandatsEluConseillerGeneral(senMat) {
58
- return jsonArrayFrom(dbSenat
59
- .withSchema("sens")
60
- .selectFrom("elucan")
61
- .leftJoin("typman", "elucan.typmancod", "typman.typmancod")
62
- .where("elucan.senmat", "=", senMat)
63
- .select(({ ref }) => [circonscription(ref("elucan.dptnum").$notNull()).as("circonscription")])
64
- .orderBy("elucan.eludatdeb", "desc"));
65
- }
66
- function mandatsEluDepute(senMat) {
67
- return jsonArrayFrom(dbSenat
68
- .withSchema("sens")
69
- .selectFrom("eludep")
70
- .leftJoin("typman", "eludep.typmancod", "typman.typmancod")
71
- .where("eludep.senmat", "=", senMat)
72
- .select(({ ref }) => [circonscription(ref("eludep.circo").$notNull()).as("circonscription")])
73
- .orderBy("eludep.eludatdeb", "desc"));
74
- }
75
- function mandatsEluDivers(senMat) {
76
- return jsonArrayFrom(dbSenat
77
- .withSchema("sens")
78
- .selectFrom("eludiv")
79
- .leftJoin("typman", "eludiv.typmancod", "typman.typmancod")
80
- .where("eludiv.senmat", "=", senMat)
81
- .orderBy("eludiv.eludatdeb", "desc"));
82
- }
83
- function mandatsEluEuropeen(senMat) {
84
- return jsonArrayFrom(dbSenat
85
- .withSchema("sens")
86
- .selectFrom("elueur")
87
- .leftJoin("nation", "elueur.nationcod", "nation.nationcod")
88
- .leftJoin("typman", "elueur.typmancod", "typman.typmancod")
89
- .where("elueur.senmat", "=", senMat)
90
- .orderBy("elueur.eludatdeb", "desc"));
91
- }
92
- function mandatsEluConseillerRegional(senMat) {
93
- return jsonArrayFrom(dbSenat
94
- .withSchema("sens")
95
- .selectFrom("elureg")
96
- .leftJoin("reg", "elureg.regcod", "reg.regcod")
97
- .leftJoin("typman", "elureg.typmancod", "typman.typmancod")
98
- .where("elureg.senmat", "=", senMat)
99
- .orderBy("elureg.eludatdeb", "desc"));
100
- }
101
- function mandatsEluSenateur(senMat) {
102
- return jsonArrayFrom(dbSenat
103
- .withSchema("sens")
104
- .selectFrom("elusen")
105
- .leftJoin("etadebman", "elusen.etadebmancod", "etadebman.etadebmancod")
106
- .leftJoin("etafinman", "elusen.etafinmancod", "etafinman.etafinmancod")
107
- .leftJoin("typman", "elusen.typmancod", "typman.typmancod")
108
- .where("elusen.senmat", "=", senMat)
109
- .select(({ ref }) => [
110
- "elusen.dptnum as code_circonscription",
111
- toDateString(ref("elusen.eludatdeb")).as("date_debut"),
112
- toDateString(ref("elusen.eludatfin")).as("date_fin"),
113
- "elusen.temvalcod as etat",
114
- "etadebman.etadebmanlib as etat_debut",
115
- "etafinman.etafinman as etat_fin",
116
- ])
117
- .orderBy("elusen.eludatdeb", "desc"));
118
- }
119
- function mandatsEluTerritorial(senMat) {
120
- return jsonArrayFrom(dbSenat
121
- .withSchema("sens")
122
- .selectFrom("eluter")
123
- .leftJoin("asster", "eluter.asstercod", "asster.asstercod")
124
- .leftJoin("typman", "eluter.typmancod", "typman.typmancod")
125
- .where("eluter.senmat", "=", senMat)
126
- .orderBy("eluter.eludatdeb", "desc"));
127
- }
128
- function mandatsEluConseillerMunicipal(senMat) {
129
- return jsonArrayFrom(dbSenat
130
- .withSchema("sens")
131
- .selectFrom("eluvil")
132
- .leftJoin("typman", "eluvil.typmancod", "typman.typmancod")
133
- .where("eluvil.senmat", "=", senMat)
134
- .orderBy("eluvil.eludatdeb", "desc"));
135
- }
136
- function fonctionsMembreCommission(memComId) {
137
- return jsonArrayFrom(dbSenat
138
- .withSchema("sens")
139
- .selectFrom("fonmemcom")
140
- .leftJoin("foncom", "fonmemcom.foncomcod", "foncom.foncomcod")
141
- .where("fonmemcom.memcomid", "=", memComId)
142
- .select(({ eb, ref }) => [
143
- toDateString(ref("fonmemcom.fonmemcomdatdeb")).as("date_debut"),
144
- toDateString(ref("fonmemcom.fonmemcomdatfin")).as("date_fin"),
145
- eb.fn
146
- .coalesce(nullIf(ref("foncom.foncomlib")), nullIf(ref("foncom.foncomlil")), nullIf(ref("foncom.foncomlic")))
147
- .as("libelle"),
148
- ])
149
- .orderBy("fonmemcom.fonmemcomdatdeb", "desc"));
150
- }
151
- function mandatsMembreCommission(senMat) {
152
- return jsonArrayFrom(dbSenat
153
- .withSchema("sens")
154
- .selectFrom("memcom")
155
- .leftJoin("com", "memcom.orgcod", "com.orgcod")
156
- .leftJoin("typorg", "com.typorgcod", "typorg.typorgcod")
157
- .where("memcom.senmat", "=", senMat)
158
- .select(({ ref }) => [
159
- "com.typorgcod as type_code_organisme",
160
- "memcom.orgcod as code_organisme",
161
- "typorg.typorglib as type_organisme",
162
- "com.comlilmin as libelle",
163
- toDateString(ref("memcom.memcomdatdeb")).as("date_debut"),
164
- toDateString(ref("memcom.memcomdatfin")).as("date_fin"),
165
- "memcom.temvalcod as etat",
166
- fonctionsMembreCommission(ref("memcom.memcomid")).as("fonctions"),
167
- ])
168
- .orderBy("memcom.memcomdatdeb", "desc"));
169
- }
170
- function fonctionsMembreDelegation(memDelegaId) {
171
- return jsonArrayFrom(dbSenat
172
- .withSchema("sens")
173
- .selectFrom("fonmemdelega")
174
- .leftJoin("fondelega", "fonmemdelega.fondelcod", "fondelega.fondelcod")
175
- .where("fonmemdelega.memdelegaid", "=", memDelegaId)
176
- .select(({ eb, ref }) => [
177
- toDateString(ref("fonmemdelega.fonmemdeldatdeb")).as("date_debut"),
178
- toDateString(ref("fonmemdelega.fonmemdeldatfin")).as("date_fin"),
179
- eb.fn
180
- .coalesce(nullIf(ref("fondelega.fondellib")), nullIf(ref("fondelega.fondellil")), nullIf(ref("fondelega.fondellic")))
181
- .as("libelle"),
182
- ])
183
- .orderBy("fonmemdelega.fonmemdeldatdeb", "desc"));
184
- }
185
- function mandatsMembreDelegation(senMat) {
186
- return jsonArrayFrom(dbSenat
187
- .withSchema("sens")
188
- .selectFrom("memdelega")
189
- .leftJoin("delega", "memdelega.orgcod", "delega.orgcod")
190
- .leftJoin("designorg", "memdelega.designcod", "designorg.designcod")
191
- .leftJoin("typorg", "delega.typorgcod", "typorg.typorgcod")
192
- .where("memdelega.senmat", "=", senMat)
193
- .select(({ ref }) => [
194
- "delega.typorgcod as type_code_organisme",
195
- "memdelega.orgcod as code_organisme",
196
- "typorg.typorglib as type_organisme",
197
- "delega.evelib as libelle",
198
- toDateString(ref("memdelega.memdelegadatdeb")).as("date_debut"),
199
- toDateString(ref("memdelega.memdelegadatfin")).as("date_fin"),
200
- "memdelega.temvalcod as etat",
201
- fonctionsMembreDelegation(ref("memdelega.memdelegaid")).as("fonctions"),
202
- ])
203
- .orderBy("memdelega.memdelegadatdeb", "desc"));
204
- }
205
- function mandatsMembreExtraParlementaire(senMat) {
206
- return jsonArrayFrom(dbSenat
207
- .withSchema("sens")
208
- .selectFrom("memextpar")
209
- .leftJoin("orgext", "memextpar.orgcod", "orgext.orgcod")
210
- .leftJoin("design", "memextpar.designcod", "design.designcod")
211
- .where("memextpar.senmat", "=", senMat)
212
- .orderBy("memextpar.memextpardatdeb", "desc"));
213
- }
214
- function fonctionsMembreGroupePolitique(memGrpPolId) {
215
- return jsonArrayFrom(dbSenat
216
- .withSchema("sens")
217
- .selectFrom("fonmemgrppol")
218
- .leftJoin("fongrppol", "fonmemgrppol.fongrppolcod", "fongrppol.fongrppolcod")
219
- .where("fonmemgrppol.memgrppolid", "=", memGrpPolId)
220
- .select(({ eb, ref }) => [
221
- toDateString(ref("fonmemgrppol.fonmemgrppoldatdeb")).as("date_debut"),
222
- toDateString(ref("fonmemgrppol.fonmemgrppoldatfin")).as("date_fin"),
223
- eb.fn
224
- .coalesce(nullIf(ref("fongrppol.fongrppollib")), nullIf(ref("fongrppol.fongrppollil")), nullIf(ref("fongrppol.fongrppollic")))
225
- .as("libelle"),
226
- ])
227
- .orderBy("fonmemgrppol.fonmemgrppoldatdeb", "desc"));
228
- }
229
- function mandatsMembreGroupePolitique(senMat) {
230
- return jsonArrayFrom(dbSenat
231
- .withSchema("sens")
232
- .selectFrom("memgrppol")
233
- .leftJoin("grppol", "memgrppol.grppolcod", "grppol.grppolcod")
234
- .leftJoin("typapppol", "memgrppol.typapppolcod", "typapppol.typapppolcod")
235
- .leftJoin("typorg", "grppol.typorgcod", "typorg.typorgcod")
236
- .where("memgrppol.senmat", "=", senMat)
237
- .select(({ ref }) => [
238
- "grppol.typorgcod as type_code_organisme",
239
- "memgrppol.grppolcod as code_organisme",
240
- "typorg.typorglib as type_organisme",
241
- "grppol.grppollibcou as libelle",
242
- toDateString(ref("memgrppol.memgrppoldatdeb")).as("date_debut"),
243
- toDateString(ref("memgrppol.memgrppoldatfin")).as("date_fin"),
244
- "memgrppol.temvalcod as etat",
245
- fonctionsMembreGroupePolitique(ref("memgrppol.memgrppolid")).as("fonctions"),
246
- ])
247
- .orderBy("memgrppol.memgrppoldatdeb", "desc"));
248
- }
249
- function fonctionsMembreGroupeSenatorial(memGrpSenId) {
250
- return jsonArrayFrom(dbSenat
251
- .withSchema("sens")
252
- .selectFrom("fonmemgrpsen")
253
- .leftJoin("fongrpsen", "fonmemgrpsen.fongrpsencod", "fongrpsen.fongrpsencod")
254
- .where("fonmemgrpsen.memgrpsenid", "=", memGrpSenId)
255
- .orderBy("fonmemgrpsen.fonmemgrpsendatdeb", "desc"));
256
- }
257
- function mandatsMembreGroupeSenatorial(senMat) {
258
- return jsonArrayFrom(dbSenat
259
- .withSchema("sens")
260
- .selectFrom("memgrpsen")
261
- .leftJoin("grpsenami", "memgrpsen.orgcod", "grpsenami.orgcod")
262
- .leftJoin("typgrpsen", "grpsenami.typgrpsencod", "typgrpsen.typgrpsencod")
263
- .where("memgrpsen.senmat", "=", senMat)
264
- .select(({ ref }) => [fonctionsMembreGroupeSenatorial(ref("memgrpsen.memgrpsenid")).as("fonctions")])
265
- .orderBy("memgrpsen.memgrpsendatent", "desc"));
266
- }
267
- function fonctionsMembreOrganisme(memOrgId) {
268
- return jsonArrayFrom(dbSenat
269
- .withSchema("sens")
270
- .selectFrom("fonmemorg")
271
- .leftJoin("fonorg", "fonmemorg.fonorgcod", "fonorg.fonorgcod")
272
- .where("fonmemorg.memorgid", "=", memOrgId)
273
- .orderBy("fonmemorg.fonmemorgdatdeb", "desc"));
274
- }
275
- function mandatsMembreOrganisme(senMat) {
276
- return jsonArrayFrom(dbSenat
277
- .withSchema("sens")
278
- .selectFrom("memorg")
279
- .leftJoin("org", "memorg.orgcod", "org.orgcod")
280
- .leftJoin("typorg", "org.typorgcod", "typorg.typorgcod")
281
- .leftJoin("designorg", "memorg.designcod", "designorg.designcod")
282
- .where("memorg.senmat", "=", senMat)
283
- .select(({ ref }) => [fonctionsMembreOrganisme(ref("memorg.memorgid")).as("fonctions")])
284
- .orderBy("memorg.memorgdatdeb", "desc"));
285
- }
286
- function mandatsMinistre(senMat) {
287
- return jsonArrayFrom(dbSenat
288
- .withSchema("sens")
289
- .selectFrom("minind")
290
- .where("minind.senmat", "=", senMat)
291
- .orderBy("minind.mindatdeb", "desc"));
292
- }
293
- function adressesPoicon(poiconId) {
294
- return jsonArrayFrom(dbSenat
295
- .withSchema("sens")
296
- .selectFrom("adresse")
297
- .where("adresse.poiconid", "=", poiconId)
298
- .select([
299
- "adresse.adrnumvoi as numero_voie",
300
- "adresse.adrnomvoi as nom_voie",
301
- "adresse.adrcmp as complement",
302
- "adresse.adrcmp2 as complement2",
303
- "adresse.adrcodpos as code_postal",
304
- "adresse.adrcom as commune",
305
- "adresse.adrcdxcod as code_cedex",
306
- "adresse.adrcdxlib as libelle_cedex",
307
- "adresse.adrburdis as bureau_distributeur",
308
- ])
309
- .orderBy("adresse.adrnumtri", "asc"));
310
- }
311
- function telephonesPoicon(poiconId) {
312
- return jsonArrayFrom(dbSenat
313
- .withSchema("sens")
314
- .selectFrom("telephone")
315
- .where("telephone.poiconid", "=", poiconId)
316
- .select(["telephone.typtelcod as type", "telephone.telnum as numero"])
317
- .orderBy("telephone.telnumtri", "asc"));
318
- }
319
- function pointsContact(senMat) {
320
- return jsonArrayFrom(dbSenat
321
- .withSchema("sens")
322
- .selectFrom("poicon")
323
- .where("poicon.senmat", "=", senMat)
324
- .select(({ ref }) => [
325
- "poicon.poiconid as id",
326
- "poicon.typpoiconcod as type",
327
- "poicon.poiconlib as libelle",
328
- adressesPoicon(ref("poicon.poiconid")).as("adresses"),
329
- telephonesPoicon(ref("poicon.poiconid")).as("telephones"),
330
- ])
331
- .orderBy("poicon.poiconnumtri", "asc"));
332
- }
333
- function urls(senMat) {
334
- return jsonArrayFrom(dbSenat
335
- .withSchema("sens")
336
- .selectFrom("senurl")
337
- .where("senurl.senmat", "=", senMat)
338
- .select(["senurl.typurlcod as code_url", "senurl.senurlurl as url"])
339
- .orderBy("senurl.senurlnumtri", "asc"));
340
- }
341
- const findAllQuery = dbSenat
342
- .withSchema("sens")
343
- .selectFrom("sen")
344
- .leftJoin("etasen", "sen.etasencod", "etasen.etasencod")
345
- .leftJoin("pcs", "sen.pcscod", "pcs.pcscod")
346
- .leftJoin("pcs42", "pcs.pcs42cod", "pcs42.pcs42cod")
347
- .leftJoin("pcs24", "pcs42.pcs24cod", "pcs24.pcs24cod")
348
- .leftJoin("pcs8", "pcs24.pcs8cod", "pcs8.pcs8cod")
349
- .leftJoin("grppol", "sen.sengrppolcodcou", "grppol.grppolcod")
350
- .leftJoin("com", "sen.sencomcodcou", "com.orgcod")
351
- .select(({ ref }) => [
352
- "sen.senmat as matricule",
353
- "sen.quacod as qualite",
354
- "sen.sennomuse as nom_usuel",
355
- "sen.senprenomuse as prenom_usuel",
356
- "sen.etasencod as etat",
357
- toDateString(ref("sen.sendatnai")).as("date_naissance"),
358
- toDateString(ref("sen.sendatdec")).as("date_deces"),
359
- "sen.sengrppolcodcou as code_groupe_politique",
360
- "sen.sengrppolliccou as groupe_politique",
361
- "sen.sencomcodcou as code_commission_permanente",
362
- "com.comlilmin as commission_permanente",
363
- "sen.sencirnumcou as code_circonscription",
364
- "sen.sencircou as circonscription",
365
- "sen.senburliccou as fonction_bureau_senat",
366
- "sen.senema as courrier_electronique",
367
- "pcs.pcslil as PCS_INSEE",
368
- "pcs42.pcs42lib as PCS_INSEE_42",
369
- "pcs24.pcs24lib as PCS_INSEE_24",
370
- "pcs8.pcs8lil as PCS_INSEE_8",
371
- "sen.sendespro as description_profession",
372
- "sen.sennumsie as siege",
373
- "sen.sendaiurl as url_hatvp",
374
- urls(ref("sen.senmat")).as("urls"),
375
- mandatsEluSenateur(ref("sen.senmat")).as("mandats_senateur"),
376
- mandatsMembreCommission(ref("sen.senmat")).as("commissions"),
377
- mandatsMembreDelegation(ref("sen.senmat")).as("delegations"),
378
- mandatsMembreGroupePolitique(ref("sen.senmat")).as("groupes"),
379
- fonctionsBureau(ref("sen.senmat")).as("fonctions_bureau"),
380
- pointsContact(ref("sen.senmat")).as("points_contact"),
381
- ]);
382
- const findAllCirconscriptionsQuery = dbSenat
383
- .withSchema("sens")
384
- .selectFrom("dpt")
385
- .leftJoin("reg", "dpt.regcod", "reg.regcod")
386
- .select(({ ref }) => [
387
- "dpt.dptnum as identifiant",
388
- "dpt.dptcod as code",
389
- "dpt.dptlib as libelle_departement",
390
- "dpt.dptart as article",
391
- "reg.reglib as libelle_region",
392
- "dpt.temvalcod as etat",
393
- toDateString(ref("dpt.dptdatdeb")).as("date_debut"),
394
- toDateString(ref("dpt.dptdatfin")).as("date_fin"),
395
- "dpt.dptnbrsen as nombre_senateurs",
396
- "dpt.dpturlcmp as url",
397
- ]);
398
- const findAllOrganismesQuery = dbSenat
399
- .withSchema("sens")
400
- .selectFrom((eb) => eb
401
- .selectFrom("com")
402
- .select(["orgcod", "evelic", "evelib", "evelil", "typorgcod", "orgurlsim", "orgdatcre", "orgdatfin", "temvalcod"])
403
- .union(eb
404
- .selectFrom("delega")
405
- .select([
406
- "orgcod",
407
- "evelic",
408
- "evelib",
409
- "evelil",
410
- "typorgcod",
411
- "orgurlsim",
412
- "orgdatcre",
413
- "orgdatfin",
414
- "temvalcod",
415
- ]))
416
- .union(eb
417
- .selectFrom("grppol")
418
- .select([
419
- "grppolcod as orgcod",
420
- "grppolliccou as evelic",
421
- "grppollibcou as evelib",
422
- "grppollilcou as evelil",
423
- "typorgcod",
424
- "grppolurlsim as orgurlsim",
425
- "grppoldatcre as orgdatcre",
426
- "grppoldatfin as orgdatfin",
427
- "temvalcod",
428
- ]))
429
- .union(eb
430
- .selectFrom("grpsenami")
431
- .select([
432
- "orgcod",
433
- "evelic",
434
- "evelib",
435
- "evelil",
436
- "typorgcod",
437
- "orgurlsim",
438
- "orgdatcre",
439
- "orgdatfin",
440
- "temvalcod",
441
- ]))
442
- .union(eb
443
- .selectFrom("org")
444
- .select([
445
- "orgcod",
446
- "evelic",
447
- "evelib",
448
- "evelil",
449
- "typorgcod",
450
- "orgurlsim",
451
- "orgdatcre",
452
- "orgdatfin",
453
- "temvalcod",
454
- ]))
455
- .as("all_organismes"))
456
- .leftJoin("typorg", "all_organismes.typorgcod", "typorg.typorgcod")
457
- .select(({ ref, val }) => [
458
- "all_organismes.orgcod as code",
459
- "all_organismes.evelic as libelle_court",
460
- "all_organismes.evelib as libelle",
461
- rtrim(ref("all_organismes.evelil")).as("libelle_long"),
462
- "all_organismes.typorgcod as type_code",
463
- rtrim(ref("typorg.typorglib")).as("type_libelle"),
464
- concat(val("https://www.senat.fr"), ref("all_organismes.orgurlsim")).as("url"),
465
- toDateString(ref("all_organismes.orgdatcre")).as("date_debut"),
466
- toDateString(ref("all_organismes.orgdatfin")).as("date_fin"),
467
- "all_organismes.temvalcod as etat",
468
- ]);
469
- export function findAll() {
470
- return findAllQuery.stream();
471
- }
472
- export function findAllCirconscriptions() {
473
- return findAllCirconscriptionsQuery.stream();
474
- }
475
- export function findAllOrganismes() {
476
- return findAllOrganismesQuery.stream();
477
- }
478
- export function findActif() {
479
- return dbSenat
480
- .withSchema("sens")
481
- .selectFrom("sen")
482
- .where("etasencod", "=", "ACTIF")
483
- .select(["senmat", "sennomuse", "senprenomuse"])
484
- .stream();
1
+ import { streamUnsafeQuery } from "../databases_postgres";
2
+ function bureauFunctionsSql(senMatSql) {
3
+ return `
4
+ (
5
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
6
+ from (
7
+ select
8
+ to_char(senbur.senburdatdeb, 'YYYY-MM-DD') as date_debut,
9
+ to_char(senbur.senburdatfin, 'YYYY-MM-DD') as date_fin,
10
+ coalesce(nullif(bur.burlib, ''), nullif(bur.burlil, ''), nullif(bur.burlic, '')) as libelle,
11
+ senbur.senburdatdeb as order_date
12
+ from senat.sens_senbur as senbur
13
+ left join senat.sens_bur as bur on senbur.burcod = bur.burcod
14
+ where senbur.senmat = ${senMatSql}
15
+ ) as rows
16
+ )
17
+ `;
18
+ }
19
+ function senateurMandatesSql(senMatSql) {
20
+ return `
21
+ (
22
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
23
+ from (
24
+ select
25
+ elusen.dptnum::text as code_circonscription,
26
+ to_char(elusen.eludatdeb, 'YYYY-MM-DD') as date_debut,
27
+ to_char(elusen.eludatfin, 'YYYY-MM-DD') as date_fin,
28
+ elusen.temvalcod as etat,
29
+ etadebman.etadebmanlib as etat_debut,
30
+ etafinman.etafinman as etat_fin,
31
+ elusen.eludatdeb as order_date
32
+ from senat.sens_elusen as elusen
33
+ left join senat.sens_etadebman as etadebman on elusen.etadebmancod = etadebman.etadebmancod
34
+ left join senat.sens_etafinman as etafinman on elusen.etafinmancod = etafinman.etafinmancod
35
+ where elusen.senmat = ${senMatSql}
36
+ ) as rows
37
+ )
38
+ `;
39
+ }
40
+ function commissionFunctionsSql(memComIdSql) {
41
+ return `
42
+ (
43
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
44
+ from (
45
+ select
46
+ to_char(fonmemcom.fonmemcomdatdeb, 'YYYY-MM-DD') as date_debut,
47
+ to_char(fonmemcom.fonmemcomdatfin, 'YYYY-MM-DD') as date_fin,
48
+ coalesce(nullif(foncom.foncomlib, ''), nullif(foncom.foncomlil, ''), nullif(foncom.foncomlic, '')) as libelle,
49
+ fonmemcom.fonmemcomdatdeb as order_date
50
+ from senat.sens_fonmemcom as fonmemcom
51
+ left join senat.sens_foncom as foncom on fonmemcom.foncomcod = foncom.foncomcod
52
+ where fonmemcom.memcomid = ${memComIdSql}
53
+ ) as rows
54
+ )
55
+ `;
56
+ }
57
+ function commissionMandatesSql(senMatSql) {
58
+ return `
59
+ (
60
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
61
+ from (
62
+ select
63
+ memcom.orgcod as code_organisme,
64
+ to_char(memcom.memcomdatdeb, 'YYYY-MM-DD') as date_debut,
65
+ to_char(memcom.memcomdatfin, 'YYYY-MM-DD') as date_fin,
66
+ memcom.temvalcod as etat,
67
+ ${commissionFunctionsSql("memcom.memcomid")} as fonctions,
68
+ com.comlilmin as libelle,
69
+ com.typorgcod as type_code_organisme,
70
+ typorg.typorglib as type_organisme,
71
+ memcom.memcomdatdeb as order_date
72
+ from senat.sens_memcom as memcom
73
+ left join senat.sens_com as com on memcom.orgcod = com.orgcod
74
+ left join senat.sens_typorg as typorg on com.typorgcod = typorg.typorgcod
75
+ where memcom.senmat = ${senMatSql}
76
+ ) as rows
77
+ )
78
+ `;
79
+ }
80
+ function delegationFunctionsSql(memDelegaIdSql) {
81
+ return `
82
+ (
83
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
84
+ from (
85
+ select
86
+ to_char(fonmemdelega.fonmemdeldatdeb, 'YYYY-MM-DD') as date_debut,
87
+ to_char(fonmemdelega.fonmemdeldatfin, 'YYYY-MM-DD') as date_fin,
88
+ coalesce(
89
+ nullif(fondelega.fondellib, ''),
90
+ nullif(fondelega.fondellil, ''),
91
+ nullif(fondelega.fondellic, '')
92
+ ) as libelle,
93
+ fonmemdelega.fonmemdeldatdeb as order_date
94
+ from senat.sens_fonmemdelega as fonmemdelega
95
+ left join senat.sens_fondelega as fondelega on fonmemdelega.fondelcod = fondelega.fondelcod
96
+ where fonmemdelega.memdelegaid = ${memDelegaIdSql}
97
+ ) as rows
98
+ )
99
+ `;
100
+ }
101
+ function delegationMandatesSql(senMatSql) {
102
+ return `
103
+ (
104
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
105
+ from (
106
+ select
107
+ memdelega.orgcod as code_organisme,
108
+ to_char(memdelega.memdelegadatdeb, 'YYYY-MM-DD') as date_debut,
109
+ to_char(memdelega.memdelegadatfin, 'YYYY-MM-DD') as date_fin,
110
+ memdelega.temvalcod as etat,
111
+ ${delegationFunctionsSql("memdelega.memdelegaid")} as fonctions,
112
+ delega.evelib as libelle,
113
+ delega.typorgcod as type_code_organisme,
114
+ typorg.typorglib as type_organisme,
115
+ memdelega.memdelegadatdeb as order_date
116
+ from senat.sens_memdelega as memdelega
117
+ left join senat.sens_delega as delega on memdelega.orgcod = delega.orgcod
118
+ left join senat.sens_designorg as designorg on memdelega.designcod = designorg.designcod
119
+ left join senat.sens_typorg as typorg on delega.typorgcod = typorg.typorgcod
120
+ where memdelega.senmat = ${senMatSql}
121
+ ) as rows
122
+ )
123
+ `;
124
+ }
125
+ function groupFunctionsSql(memGrpPolIdSql) {
126
+ return `
127
+ (
128
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
129
+ from (
130
+ select
131
+ to_char(fonmemgrppol.fonmemgrppoldatdeb, 'YYYY-MM-DD') as date_debut,
132
+ to_char(fonmemgrppol.fonmemgrppoldatfin, 'YYYY-MM-DD') as date_fin,
133
+ coalesce(
134
+ nullif(fongrppol.fongrppollib, ''),
135
+ nullif(fongrppol.fongrppollil, ''),
136
+ nullif(fongrppol.fongrppollic, '')
137
+ ) as libelle,
138
+ fonmemgrppol.fonmemgrppoldatdeb as order_date
139
+ from senat.sens_fonmemgrppol as fonmemgrppol
140
+ left join senat.sens_fongrppol as fongrppol on fonmemgrppol.fongrppolcod = fongrppol.fongrppolcod
141
+ where fonmemgrppol.memgrppolid = ${memGrpPolIdSql}
142
+ ) as rows
143
+ )
144
+ `;
145
+ }
146
+ function groupMandatesSql(senMatSql) {
147
+ return `
148
+ (
149
+ select coalesce(json_agg(rows order by rows.order_date desc nulls last), '[]'::json)
150
+ from (
151
+ select
152
+ memgrppol.grppolcod as code_organisme,
153
+ to_char(memgrppol.memgrppoldatdeb, 'YYYY-MM-DD') as date_debut,
154
+ to_char(memgrppol.memgrppoldatfin, 'YYYY-MM-DD') as date_fin,
155
+ memgrppol.temvalcod as etat,
156
+ ${groupFunctionsSql("memgrppol.memgrppolid")} as fonctions,
157
+ grppol.grppollibcou as libelle,
158
+ grppol.typorgcod as type_code_organisme,
159
+ typorg.typorglib as type_organisme,
160
+ memgrppol.memgrppoldatdeb as order_date
161
+ from senat.sens_memgrppol as memgrppol
162
+ left join senat.sens_grppol as grppol on memgrppol.grppolcod = grppol.grppolcod
163
+ left join senat.sens_typapppol as typapppol on memgrppol.typapppolcod = typapppol.typapppolcod
164
+ left join senat.sens_typorg as typorg on grppol.typorgcod = typorg.typorgcod
165
+ where memgrppol.senmat = ${senMatSql}
166
+ ) as rows
167
+ )
168
+ `;
169
+ }
170
+ function addressesSql(poiconIdSql) {
171
+ return `
172
+ (
173
+ select coalesce(json_agg(rows order by rows.order_num asc nulls last), '[]'::json)
174
+ from (
175
+ select
176
+ adresse.adrnumvoi as numero_voie,
177
+ adresse.adrnomvoi as nom_voie,
178
+ adresse.adrcmp as complement,
179
+ adresse.adrcmp2 as complement2,
180
+ adresse.adrcodpos as code_postal,
181
+ adresse.adrcom as commune,
182
+ adresse.adrcdxcod as code_cedex,
183
+ adresse.adrcdxlib as libelle_cedex,
184
+ adresse.adrburdis as bureau_distributeur,
185
+ adresse.adrnumtri as order_num
186
+ from senat.sens_adresse as adresse
187
+ where adresse.poiconid = ${poiconIdSql}
188
+ ) as rows
189
+ )
190
+ `;
191
+ }
192
+ function phonesSql(poiconIdSql) {
193
+ return `
194
+ (
195
+ select coalesce(json_agg(rows order by rows.order_num asc nulls last), '[]'::json)
196
+ from (
197
+ select
198
+ telephone.typtelcod as type,
199
+ telephone.telnum as numero,
200
+ telephone.telnumtri as order_num
201
+ from senat.sens_telephone as telephone
202
+ where telephone.poiconid = ${poiconIdSql}
203
+ ) as rows
204
+ )
205
+ `;
206
+ }
207
+ function pointsContactSql(senMatSql) {
208
+ return `
209
+ (
210
+ select coalesce(json_agg(rows order by rows.order_num asc nulls last), '[]'::json)
211
+ from (
212
+ select
213
+ poicon.poiconid::text as id,
214
+ poicon.typpoiconcod as type,
215
+ poicon.poiconlib as libelle,
216
+ ${addressesSql("poicon.poiconid")} as adresses,
217
+ ${phonesSql("poicon.poiconid")} as telephones,
218
+ poicon.poiconnumtri as order_num
219
+ from senat.sens_poicon as poicon
220
+ where poicon.senmat = ${senMatSql}
221
+ ) as rows
222
+ )
223
+ `;
224
+ }
225
+ function urlsSql(senMatSql) {
226
+ return `
227
+ (
228
+ select coalesce(json_agg(rows order by rows.order_num asc nulls last), '[]'::json)
229
+ from (
230
+ select
231
+ senurl.typurlcod as code_url,
232
+ senurl.senurlurl as url,
233
+ senurl.senurlnumtri as order_num
234
+ from senat.sens_senurl as senurl
235
+ where senurl.senmat = ${senMatSql}
236
+ ) as rows
237
+ )
238
+ `;
239
+ }
240
+ function buildFindAllSenateursQuery() {
241
+ return {
242
+ params: [],
243
+ query: `
244
+ select
245
+ sen.senmat as matricule,
246
+ sen.quacod as qualite,
247
+ sen.sennomuse as nom_usuel,
248
+ sen.senprenomuse as prenom_usuel,
249
+ sen.etasencod as etat,
250
+ to_char(sen.sendatnai, 'YYYY-MM-DD') as date_naissance,
251
+ to_char(sen.sendatdec, 'YYYY-MM-DD') as date_deces,
252
+ sen.sengrppolcodcou as code_groupe_politique,
253
+ sen.sengrppolliccou as groupe_politique,
254
+ sen.sencomcodcou as code_commission_permanente,
255
+ com.comlilmin as commission_permanente,
256
+ sen.sencirnumcou::text as code_circonscription,
257
+ sen.sencircou as circonscription,
258
+ sen.senburliccou as fonction_bureau_senat,
259
+ sen.senema as courrier_electronique,
260
+ pcs.pcslil as "PCS_INSEE",
261
+ pcs42.pcs42lib as "PCS_INSEE_42",
262
+ pcs24.pcs24lib as "PCS_INSEE_24",
263
+ pcs8.pcs8lil as "PCS_INSEE_8",
264
+ sen.sendespro as description_profession,
265
+ sen.sennumsie::text as siege,
266
+ sen.sendaiurl as url_hatvp,
267
+ ${urlsSql("sen.senmat")} as urls,
268
+ ${senateurMandatesSql("sen.senmat")} as mandats_senateur,
269
+ ${commissionMandatesSql("sen.senmat")} as commissions,
270
+ ${delegationMandatesSql("sen.senmat")} as delegations,
271
+ ${groupMandatesSql("sen.senmat")} as groupes,
272
+ ${bureauFunctionsSql("sen.senmat")} as fonctions_bureau,
273
+ ${pointsContactSql("sen.senmat")} as points_contact
274
+ from senat.sens_sen as sen
275
+ left join senat.sens_etasen as etasen on sen.etasencod = etasen.etasencod
276
+ left join senat.sens_pcs as pcs on sen.pcscod = pcs.pcscod
277
+ left join senat.sens_pcs42 as pcs42 on pcs.pcs42cod = pcs42.pcs42cod
278
+ left join senat.sens_pcs24 as pcs24 on pcs42.pcs24cod = pcs24.pcs24cod
279
+ left join senat.sens_pcs8 as pcs8 on pcs24.pcs8cod = pcs8.pcs8cod
280
+ left join senat.sens_grppol as grppol on sen.sengrppolcodcou = grppol.grppolcod
281
+ left join senat.sens_com as com on sen.sencomcodcou = com.orgcod
282
+ `,
283
+ };
284
+ }
285
+ function buildFindAllCirconscriptionsQuery() {
286
+ return {
287
+ params: [],
288
+ query: `
289
+ select
290
+ dpt.dptnum::text as identifiant,
291
+ dpt.dptcod as code,
292
+ dpt.dptlib as libelle_departement,
293
+ dpt.dptart as article,
294
+ reg.reglib as libelle_region,
295
+ dpt.temvalcod as etat,
296
+ to_char(dpt.dptdatdeb, 'YYYY-MM-DD') as date_debut,
297
+ to_char(dpt.dptdatfin, 'YYYY-MM-DD') as date_fin,
298
+ dpt.dptnbrsen::text as nombre_senateurs,
299
+ dpt.dpturlcmp as url
300
+ from senat.sens_dpt as dpt
301
+ left join senat.sens_reg as reg on dpt.regcod = reg.regcod
302
+ `,
303
+ };
304
+ }
305
+ function buildFindAllOrganismesQuery() {
306
+ return {
307
+ params: [],
308
+ query: `
309
+ select
310
+ all_organismes.orgcod as code,
311
+ all_organismes.evelic as libelle_court,
312
+ all_organismes.evelib as libelle,
313
+ rtrim(all_organismes.evelil) as libelle_long,
314
+ all_organismes.typorgcod as type_code,
315
+ rtrim(typorg.typorglib) as type_libelle,
316
+ 'https://www.senat.fr' || all_organismes.orgurlsim as url,
317
+ to_char(all_organismes.orgdatcre, 'YYYY-MM-DD') as date_debut,
318
+ to_char(all_organismes.orgdatfin, 'YYYY-MM-DD') as date_fin,
319
+ all_organismes.temvalcod as etat
320
+ from (
321
+ select orgcod, evelic, evelib, evelil, typorgcod, orgurlsim, orgdatcre, orgdatfin, temvalcod
322
+ from senat.sens_com as com
323
+ union
324
+ select orgcod, evelic, evelib, evelil, typorgcod, orgurlsim, orgdatcre, orgdatfin, temvalcod
325
+ from senat.sens_delega as delega
326
+ union
327
+ select
328
+ grppolcod as orgcod,
329
+ grppolliccou as evelic,
330
+ grppollibcou as evelib,
331
+ grppollilcou as evelil,
332
+ typorgcod,
333
+ grppolurlsim as orgurlsim,
334
+ grppoldatcre as orgdatcre,
335
+ grppoldatfin as orgdatfin,
336
+ temvalcod
337
+ from senat.sens_grppol as grppol
338
+ union
339
+ select orgcod, evelic, evelib, evelil, typorgcod, orgurlsim, orgdatcre, orgdatfin, temvalcod
340
+ from senat.sens_grpsenami as grpsenami
341
+ union
342
+ select orgcod, evelic, evelib, evelil, typorgcod, orgurlsim, orgdatcre, orgdatfin, temvalcod
343
+ from senat.sens_org as org
344
+ ) as all_organismes
345
+ left join senat.sens_typorg as typorg on all_organismes.typorgcod = typorg.typorgcod
346
+ `,
347
+ };
348
+ }
349
+ function buildFindActifQuery() {
350
+ return {
351
+ params: [],
352
+ query: `
353
+ select senmat, sennomuse, senprenomuse
354
+ from senat.sens_sen as sen
355
+ where etasencod = 'ACTIF'
356
+ `,
357
+ };
358
+ }
359
+ export async function* findAll() {
360
+ const { query, params } = buildFindAllSenateursQuery();
361
+ for await (const row of streamUnsafeQuery(query, params)) {
362
+ yield {
363
+ ...row,
364
+ commissions: row.commissions ?? [],
365
+ delegations: row.delegations ?? [],
366
+ fonctions_bureau: row.fonctions_bureau ?? [],
367
+ groupes: row.groupes ?? [],
368
+ mandats_senateur: row.mandats_senateur ?? [],
369
+ points_contact: row.points_contact ?? [],
370
+ urls: row.urls ?? [],
371
+ };
372
+ }
373
+ }
374
+ export async function* findAllCirconscriptions() {
375
+ const { query, params } = buildFindAllCirconscriptionsQuery();
376
+ yield* streamUnsafeQuery(query, params);
377
+ }
378
+ export async function* findAllOrganismes() {
379
+ const { query, params } = buildFindAllOrganismesQuery();
380
+ yield* streamUnsafeQuery(query, params);
381
+ }
382
+ export async function* findActif() {
383
+ const { query, params } = buildFindActifQuery();
384
+ yield* streamUnsafeQuery(query, params);
485
385
  }