@tricoteuses/senat 2.22.12 → 2.22.13

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 (136) hide show
  1. package/lib/config.d.ts +21 -0
  2. package/lib/config.js +27 -0
  3. package/lib/databases.d.ts +2 -0
  4. package/lib/databases.js +26 -0
  5. package/lib/datasets.d.ts +34 -0
  6. package/lib/datasets.js +233 -0
  7. package/lib/git.d.ts +26 -0
  8. package/lib/git.js +167 -0
  9. package/lib/index.d.ts +13 -0
  10. package/lib/index.js +1 -0
  11. package/lib/loaders.d.ts +58 -0
  12. package/lib/loaders.js +286 -0
  13. package/lib/model/agenda.d.ts +6 -0
  14. package/lib/model/agenda.js +148 -0
  15. package/lib/model/ameli.d.ts +51 -0
  16. package/lib/model/ameli.js +147 -0
  17. package/lib/model/commission.d.ts +18 -0
  18. package/lib/model/commission.js +269 -0
  19. package/lib/model/debats.d.ts +67 -0
  20. package/lib/model/debats.js +95 -0
  21. package/lib/model/documents.d.ts +12 -0
  22. package/lib/model/documents.js +138 -0
  23. package/lib/model/dosleg.d.ts +7 -0
  24. package/lib/model/dosleg.js +326 -0
  25. package/lib/model/index.d.ts +7 -0
  26. package/lib/model/index.js +7 -0
  27. package/lib/model/questions.d.ts +45 -0
  28. package/lib/model/questions.js +89 -0
  29. package/lib/model/scrutins.d.ts +13 -0
  30. package/lib/model/scrutins.js +114 -0
  31. package/lib/model/seance.d.ts +3 -0
  32. package/lib/model/seance.js +267 -0
  33. package/lib/model/sens.d.ts +146 -0
  34. package/lib/model/sens.js +454 -0
  35. package/lib/model/texte.d.ts +7 -0
  36. package/lib/model/texte.js +228 -0
  37. package/lib/model/util.d.ts +9 -0
  38. package/lib/model/util.js +38 -0
  39. package/lib/parsers/texte.d.ts +7 -0
  40. package/lib/parsers/texte.js +228 -0
  41. package/lib/raw_types/ameli.d.ts +914 -0
  42. package/lib/raw_types/ameli.js +5 -0
  43. package/lib/raw_types/debats.d.ts +207 -0
  44. package/lib/raw_types/debats.js +5 -0
  45. package/lib/raw_types/dosleg.d.ts +1619 -0
  46. package/lib/raw_types/dosleg.js +5 -0
  47. package/lib/raw_types/questions.d.ts +423 -0
  48. package/lib/raw_types/questions.js +5 -0
  49. package/lib/raw_types/senat.d.ts +11372 -0
  50. package/lib/raw_types/senat.js +5 -0
  51. package/lib/raw_types/sens.d.ts +8248 -0
  52. package/lib/raw_types/sens.js +5 -0
  53. package/lib/raw_types_schemats/ameli.d.ts +539 -0
  54. package/lib/raw_types_schemats/ameli.js +2 -0
  55. package/lib/raw_types_schemats/debats.d.ts +127 -0
  56. package/lib/raw_types_schemats/debats.js +2 -0
  57. package/lib/raw_types_schemats/dosleg.d.ts +977 -0
  58. package/lib/raw_types_schemats/dosleg.js +2 -0
  59. package/lib/raw_types_schemats/questions.d.ts +237 -0
  60. package/lib/raw_types_schemats/questions.js +2 -0
  61. package/lib/raw_types_schemats/sens.d.ts +6915 -0
  62. package/lib/raw_types_schemats/sens.js +2 -0
  63. package/lib/scripts/convert_data.d.ts +1 -0
  64. package/lib/scripts/convert_data.js +354 -0
  65. package/lib/scripts/data-download.d.ts +1 -0
  66. package/lib/scripts/data-download.js +12 -0
  67. package/lib/scripts/datautil.d.ts +8 -0
  68. package/lib/scripts/datautil.js +34 -0
  69. package/lib/scripts/parse_textes.d.ts +1 -0
  70. package/lib/scripts/parse_textes.js +44 -0
  71. package/lib/scripts/retrieve_agenda.d.ts +1 -0
  72. package/lib/scripts/retrieve_agenda.js +132 -0
  73. package/lib/scripts/retrieve_cr_commission.d.ts +1 -0
  74. package/lib/scripts/retrieve_cr_commission.js +364 -0
  75. package/lib/scripts/retrieve_cr_seance.d.ts +6 -0
  76. package/lib/scripts/retrieve_cr_seance.js +347 -0
  77. package/lib/scripts/retrieve_documents.d.ts +3 -0
  78. package/lib/scripts/retrieve_documents.js +219 -0
  79. package/lib/scripts/retrieve_open_data.d.ts +1 -0
  80. package/lib/scripts/retrieve_open_data.js +316 -0
  81. package/lib/scripts/retrieve_senateurs_photos.d.ts +1 -0
  82. package/lib/scripts/retrieve_senateurs_photos.js +147 -0
  83. package/lib/scripts/retrieve_videos.d.ts +1 -0
  84. package/lib/scripts/retrieve_videos.js +461 -0
  85. package/lib/scripts/shared/cli_helpers.d.ts +95 -0
  86. package/lib/scripts/shared/cli_helpers.js +91 -0
  87. package/lib/scripts/shared/util.d.ts +4 -0
  88. package/lib/scripts/shared/util.js +35 -0
  89. package/lib/scripts/test_iter_load.d.ts +1 -0
  90. package/lib/scripts/test_iter_load.js +12 -0
  91. package/lib/src/scripts/retrieve_cr_commission.js +12 -0
  92. package/lib/src/scripts/retrieve_cr_seance.js +12 -0
  93. package/lib/src/scripts/retrieve_videos.js +13 -1
  94. package/lib/src/utils/nvs-timecode.d.ts +17 -0
  95. package/lib/src/utils/nvs-timecode.js +79 -0
  96. package/lib/src/utils/weights_scoring_config.d.ts +2 -0
  97. package/lib/src/utils/weights_scoring_config.js +15 -0
  98. package/lib/strings.d.ts +1 -0
  99. package/lib/strings.js +18 -0
  100. package/lib/types/agenda.d.ts +44 -0
  101. package/lib/types/agenda.js +1 -0
  102. package/lib/types/ameli.d.ts +5 -0
  103. package/lib/types/ameli.js +1 -0
  104. package/lib/types/compte_rendu.d.ts +83 -0
  105. package/lib/types/compte_rendu.js +1 -0
  106. package/lib/types/debats.d.ts +2 -0
  107. package/lib/types/debats.js +1 -0
  108. package/lib/types/dosleg.d.ts +70 -0
  109. package/lib/types/dosleg.js +1 -0
  110. package/lib/types/questions.d.ts +2 -0
  111. package/lib/types/questions.js +1 -0
  112. package/lib/types/sens.d.ts +10 -0
  113. package/lib/types/sens.js +1 -0
  114. package/lib/types/sessions.d.ts +5 -0
  115. package/lib/types/sessions.js +84 -0
  116. package/lib/types/texte.d.ts +74 -0
  117. package/lib/types/texte.js +16 -0
  118. package/lib/utils/cr_spliting.d.ts +28 -0
  119. package/lib/utils/cr_spliting.js +265 -0
  120. package/lib/utils/date.d.ts +10 -0
  121. package/lib/utils/date.js +100 -0
  122. package/lib/utils/nvs-timecode.d.ts +7 -0
  123. package/lib/utils/nvs-timecode.js +79 -0
  124. package/lib/utils/reunion_grouping.d.ts +11 -0
  125. package/lib/utils/reunion_grouping.js +337 -0
  126. package/lib/utils/reunion_odj_building.d.ts +5 -0
  127. package/lib/utils/reunion_odj_building.js +154 -0
  128. package/lib/utils/reunion_parsing.d.ts +23 -0
  129. package/lib/utils/reunion_parsing.js +209 -0
  130. package/lib/utils/scoring.d.ts +14 -0
  131. package/lib/utils/scoring.js +147 -0
  132. package/lib/utils/string_cleaning.d.ts +7 -0
  133. package/lib/utils/string_cleaning.js +57 -0
  134. package/lib/validators/config.d.ts +9 -0
  135. package/lib/validators/config.js +10 -0
  136. package/package.json +1 -1
@@ -0,0 +1,454 @@
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 contacts(senMat) {
294
+ return jsonArrayFrom(dbSenat
295
+ .withSchema("sens")
296
+ .selectFrom("poicon")
297
+ .leftJoin("adresse", "poicon.poiconid", "adresse.poiconid")
298
+ .leftJoin("mel", "poicon.poiconid", "mel.poiconid")
299
+ .leftJoin("telephone", "poicon.poiconid", "telephone.poiconid")
300
+ .where("poicon.senmat", "=", senMat)
301
+ .orderBy("poicon.poiconnumtri", "asc"));
302
+ }
303
+ function urls(senMat) {
304
+ return jsonArrayFrom(dbSenat
305
+ .withSchema("sens")
306
+ .selectFrom("senurl")
307
+ .where("senurl.senmat", "=", senMat)
308
+ .select(["senurl.typurlcod as code_url", "senurl.senurlurl as url"])
309
+ .orderBy("senurl.senurlnumtri", "asc"));
310
+ }
311
+ const findAllQuery = dbSenat
312
+ .withSchema("sens")
313
+ .selectFrom("sen")
314
+ .leftJoin("etasen", "sen.etasencod", "etasen.etasencod")
315
+ .leftJoin("pcs", "sen.pcscod", "pcs.pcscod")
316
+ .leftJoin("pcs42", "pcs.pcs42cod", "pcs42.pcs42cod")
317
+ .leftJoin("pcs24", "pcs42.pcs24cod", "pcs24.pcs24cod")
318
+ .leftJoin("pcs8", "pcs24.pcs8cod", "pcs8.pcs8cod")
319
+ .leftJoin("grppol", "sen.sengrppolcodcou", "grppol.grppolcod")
320
+ .leftJoin("com", "sen.sencomcodcou", "com.orgcod")
321
+ .select(({ ref }) => [
322
+ "sen.senmat as matricule",
323
+ "sen.quacod as qualite",
324
+ "sen.sennomuse as nom_usuel",
325
+ "sen.senprenomuse as prenom_usuel",
326
+ "sen.etasencod as etat",
327
+ toDateString(ref("sen.sendatnai")).as("date_naissance"),
328
+ toDateString(ref("sen.sendatdec")).as("date_deces"),
329
+ "sen.sengrppolcodcou as code_groupe_politique",
330
+ "sen.sengrppolliccou as groupe_politique",
331
+ "sen.sencomcodcou as code_commission_permanente",
332
+ "com.comlilmin as commission_permanente",
333
+ "sen.sencirnumcou as code_circonscription",
334
+ "sen.sencircou as circonscription",
335
+ "sen.senburliccou as fonction_bureau_senat",
336
+ "sen.senema as courrier_electronique",
337
+ "pcs.pcslil as PCS_INSEE",
338
+ "pcs42.pcs42lib as PCS_INSEE_42",
339
+ "pcs24.pcs24lib as PCS_INSEE_24",
340
+ "pcs8.pcs8lil as PCS_INSEE_8",
341
+ "sen.sendespro as description_profession",
342
+ "sen.sennumsie as siege",
343
+ "sen.sendaiurl as url_hatvp",
344
+ urls(ref("sen.senmat")).as("urls"),
345
+ mandatsEluSenateur(ref("sen.senmat")).as("mandats_senateur"),
346
+ mandatsMembreCommission(ref("sen.senmat")).as("commissions"),
347
+ mandatsMembreDelegation(ref("sen.senmat")).as("delegations"),
348
+ mandatsMembreGroupePolitique(ref("sen.senmat")).as("groupes"),
349
+ fonctionsBureau(ref("sen.senmat")).as("fonctions_bureau"),
350
+ ]);
351
+ const findAllCirconscriptionsQuery = dbSenat
352
+ .withSchema("sens")
353
+ .selectFrom("dpt")
354
+ .leftJoin("reg", "dpt.regcod", "reg.regcod")
355
+ .select(({ ref }) => [
356
+ "dpt.dptnum as identifiant",
357
+ "dpt.dptcod as code",
358
+ "dpt.dptlib as libelle_departement",
359
+ "dpt.dptart as article",
360
+ "reg.reglib as libelle_region",
361
+ "dpt.temvalcod as etat",
362
+ toDateString(ref("dpt.dptdatdeb")).as("date_debut"),
363
+ toDateString(ref("dpt.dptdatfin")).as("date_fin"),
364
+ "dpt.dptnbrsen as nombre_senateurs",
365
+ "dpt.dpturlcmp as url",
366
+ ]);
367
+ const findAllOrganismesQuery = dbSenat
368
+ .withSchema("sens")
369
+ .selectFrom((eb) => eb
370
+ .selectFrom("com")
371
+ .select(["orgcod", "evelic", "evelib", "evelil", "typorgcod", "orgurlsim", "orgdatcre", "orgdatfin", "temvalcod"])
372
+ .union(eb
373
+ .selectFrom("delega")
374
+ .select([
375
+ "orgcod",
376
+ "evelic",
377
+ "evelib",
378
+ "evelil",
379
+ "typorgcod",
380
+ "orgurlsim",
381
+ "orgdatcre",
382
+ "orgdatfin",
383
+ "temvalcod",
384
+ ]))
385
+ .union(eb
386
+ .selectFrom("grppol")
387
+ .select([
388
+ "grppolcod as orgcod",
389
+ "grppolliccou as evelic",
390
+ "grppollibcou as evelib",
391
+ "grppollilcou as evelil",
392
+ "typorgcod",
393
+ "grppolurlsim as orgurlsim",
394
+ "grppoldatcre as orgdatcre",
395
+ "grppoldatfin as orgdatfin",
396
+ "temvalcod",
397
+ ]))
398
+ .union(eb
399
+ .selectFrom("grpsenami")
400
+ .select([
401
+ "orgcod",
402
+ "evelic",
403
+ "evelib",
404
+ "evelil",
405
+ "typorgcod",
406
+ "orgurlsim",
407
+ "orgdatcre",
408
+ "orgdatfin",
409
+ "temvalcod",
410
+ ]))
411
+ .union(eb
412
+ .selectFrom("org")
413
+ .select([
414
+ "orgcod",
415
+ "evelic",
416
+ "evelib",
417
+ "evelil",
418
+ "typorgcod",
419
+ "orgurlsim",
420
+ "orgdatcre",
421
+ "orgdatfin",
422
+ "temvalcod",
423
+ ]))
424
+ .as("all_organismes"))
425
+ .leftJoin("typorg", "all_organismes.typorgcod", "typorg.typorgcod")
426
+ .select(({ ref, val }) => [
427
+ "all_organismes.orgcod as code",
428
+ "all_organismes.evelic as libelle_court",
429
+ "all_organismes.evelib as libelle",
430
+ rtrim(ref("all_organismes.evelil")).as("libelle_long"),
431
+ "all_organismes.typorgcod as type_code",
432
+ rtrim(ref("typorg.typorglib")).as("type_libelle"),
433
+ concat(val("https://www.senat.fr"), ref("all_organismes.orgurlsim")).as("url"),
434
+ toDateString(ref("all_organismes.orgdatcre")).as("date_debut"),
435
+ toDateString(ref("all_organismes.orgdatfin")).as("date_fin"),
436
+ "all_organismes.temvalcod as etat",
437
+ ]);
438
+ export function findAll() {
439
+ return findAllQuery.stream();
440
+ }
441
+ export function findAllCirconscriptions() {
442
+ return findAllCirconscriptionsQuery.stream();
443
+ }
444
+ export function findAllOrganismes() {
445
+ return findAllOrganismesQuery.stream();
446
+ }
447
+ export function findActif() {
448
+ return dbSenat
449
+ .withSchema("sens")
450
+ .selectFrom("sen")
451
+ .where("etasencod", "=", "ACTIF")
452
+ .select(["senmat", "sennomuse", "senprenomuse"])
453
+ .stream();
454
+ }
@@ -0,0 +1,7 @@
1
+ import { ExposeDesMotifs, FlatTexte } from "../types/texte";
2
+ export declare function transformTexte(document: Document): FlatTexte | null;
3
+ export declare function transformExposeDesMotifs(document: Document): ExposeDesMotifs | null;
4
+ export declare function parseTexte(texteXml: string): FlatTexte | null;
5
+ export declare function parseTexteFromFile(xmlFilePath: string): Promise<FlatTexte | null>;
6
+ export declare function parseExposeDesMotifs(exposeDesMotifsHtml: string): ExposeDesMotifs | null;
7
+ export declare function parseExposeDesMotifsFromFile(htmlFilePath: string): Promise<ExposeDesMotifs | null>;