@tricoteuses/senat 1.3.1 → 1.3.2

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 (253) hide show
  1. package/lib/config.d.ts +1 -0
  2. package/lib/config.js +14 -45
  3. package/lib/databases.js +86 -143
  4. package/lib/datasets.js +78 -83
  5. package/lib/index.d.ts +7 -4
  6. package/lib/index.js +42 -419
  7. package/lib/loaders.js +149 -654
  8. package/lib/model/ameli.js +83 -21
  9. package/lib/model/debats.js +0 -1
  10. package/lib/model/dosleg.d.ts +1 -1
  11. package/lib/model/dosleg.js +179 -73
  12. package/lib/model/index.d.ts +3 -3
  13. package/lib/model/index.js +12 -46
  14. package/lib/model/questions.js +68 -39
  15. package/lib/model/sens.js +383 -113
  16. package/lib/model/texte.js +220 -290
  17. package/lib/model/util.js +9 -26
  18. package/lib/raw_types/ameli.js +5 -6
  19. package/lib/raw_types/debats.js +5 -6
  20. package/lib/raw_types/dosleg.js +5 -6
  21. package/lib/raw_types/questions.js +5 -6
  22. package/lib/raw_types/sens.js +5 -6
  23. package/lib/raw_types_schemats/ameli.js +1 -43
  24. package/lib/raw_types_schemats/debats.js +1 -22
  25. package/lib/raw_types_schemats/dosleg.js +1 -96
  26. package/lib/raw_types_schemats/questions.js +1 -22
  27. package/lib/raw_types_schemats/sens.js +1 -112
  28. package/lib/scripts/convert_data.js +181 -631
  29. package/lib/scripts/datautil.js +17 -60
  30. package/lib/scripts/parse_textes.js +46 -129
  31. package/lib/scripts/retrieve_documents.js +247 -513
  32. package/lib/scripts/retrieve_open_data.js +211 -368
  33. package/lib/scripts/retrieve_senateurs_photos.js +144 -239
  34. package/lib/scripts/shared/cli_helpers.js +30 -30
  35. package/lib/scripts/shared/util.js +28 -94
  36. package/lib/strings.js +20 -45
  37. package/lib/types/ameli.d.ts +1 -1
  38. package/lib/types/ameli.js +14 -25
  39. package/lib/types/debats.d.ts +1 -1
  40. package/lib/types/debats.js +3 -21
  41. package/lib/types/dosleg.d.ts +1 -1
  42. package/lib/types/dosleg.js +152 -119
  43. package/lib/types/questions.d.ts +1 -1
  44. package/lib/types/questions.js +1 -13
  45. package/lib/types/sens.d.ts +1 -1
  46. package/lib/types/sens.js +1 -13
  47. package/lib/types/sessions.js +44 -49
  48. package/lib/types/texte.js +17 -22
  49. package/lib/validators/config.js +47 -111
  50. package/lib/validators/senat.js +1 -5
  51. package/package.json +16 -38
  52. package/lib/aggregates.d.ts +0 -52
  53. package/lib/aggregates.mjs +0 -930
  54. package/lib/aggregates.ts +0 -833
  55. package/lib/config.mjs +0 -16
  56. package/lib/config.ts +0 -26
  57. package/lib/data/legislatures.json +0 -38
  58. package/lib/databases.mjs +0 -57
  59. package/lib/databases.ts +0 -71
  60. package/lib/datasets.mjs +0 -78
  61. package/lib/datasets.ts +0 -118
  62. package/lib/fields.d.ts +0 -10
  63. package/lib/fields.mjs +0 -68
  64. package/lib/fields.ts +0 -29
  65. package/lib/index.mjs +0 -4
  66. package/lib/index.ts +0 -42
  67. package/lib/inserters.d.ts +0 -98
  68. package/lib/inserters.mjs +0 -500
  69. package/lib/inserters.ts +0 -521
  70. package/lib/loaders.mjs +0 -158
  71. package/lib/loaders.ts +0 -271
  72. package/lib/model/ameli.mjs +0 -84
  73. package/lib/model/ameli.ts +0 -100
  74. package/lib/model/debats.mjs +0 -1
  75. package/lib/model/debats.ts +0 -0
  76. package/lib/model/dosleg.mjs +0 -196
  77. package/lib/model/dosleg.ts +0 -240
  78. package/lib/model/index.mjs +0 -4
  79. package/lib/model/index.ts +0 -14
  80. package/lib/model/questions.mjs +0 -71
  81. package/lib/model/questions.ts +0 -93
  82. package/lib/model/sens.mjs +0 -415
  83. package/lib/model/sens.ts +0 -516
  84. package/lib/model/texte.mjs +0 -208
  85. package/lib/model/texte.ts +0 -229
  86. package/lib/model/util.mjs +0 -19
  87. package/lib/model/util.ts +0 -32
  88. package/lib/raw_types/ameli.mjs +0 -5
  89. package/lib/raw_types/ameli.ts +0 -951
  90. package/lib/raw_types/debats.mjs +0 -5
  91. package/lib/raw_types/debats.ts +0 -222
  92. package/lib/raw_types/dosleg.mjs +0 -5
  93. package/lib/raw_types/dosleg.ts +0 -3625
  94. package/lib/raw_types/questions.mjs +0 -5
  95. package/lib/raw_types/questions.ts +0 -427
  96. package/lib/raw_types/sens.mjs +0 -5
  97. package/lib/raw_types/sens.ts +0 -4499
  98. package/lib/raw_types_kysely/ameli.d.ts +0 -6
  99. package/lib/raw_types_kysely/ameli.mjs +0 -7
  100. package/lib/raw_types_kysely/ameli.ts +0 -6
  101. package/lib/raw_types_kysely/debats.d.ts +0 -6
  102. package/lib/raw_types_kysely/debats.mjs +0 -7
  103. package/lib/raw_types_kysely/debats.ts +0 -6
  104. package/lib/raw_types_kysely/dosleg.d.ts +0 -6
  105. package/lib/raw_types_kysely/dosleg.mjs +0 -7
  106. package/lib/raw_types_kysely/dosleg.ts +0 -6
  107. package/lib/raw_types_kysely/questions.d.ts +0 -6
  108. package/lib/raw_types_kysely/questions.mjs +0 -7
  109. package/lib/raw_types_kysely/questions.ts +0 -6
  110. package/lib/raw_types_kysely/sens.d.ts +0 -6
  111. package/lib/raw_types_kysely/sens.mjs +0 -7
  112. package/lib/raw_types_kysely/sens.ts +0 -6
  113. package/lib/raw_types_kysely/texte.d.ts +0 -45
  114. package/lib/raw_types_kysely/texte.mjs +0 -7
  115. package/lib/raw_types_kysely/texte.ts +0 -53
  116. package/lib/raw_types_schemats/ameli.mjs +0 -2
  117. package/lib/raw_types_schemats/ameli.ts +0 -601
  118. package/lib/raw_types_schemats/debats.mjs +0 -2
  119. package/lib/raw_types_schemats/debats.ts +0 -145
  120. package/lib/raw_types_schemats/dosleg.mjs +0 -2
  121. package/lib/raw_types_schemats/dosleg.ts +0 -2195
  122. package/lib/raw_types_schemats/questions.mjs +0 -2
  123. package/lib/raw_types_schemats/questions.ts +0 -251
  124. package/lib/raw_types_schemats/sens.mjs +0 -2
  125. package/lib/raw_types_schemats/sens.ts +0 -2907
  126. package/lib/scripts/convert_data.mjs +0 -181
  127. package/lib/scripts/convert_data.ts +0 -243
  128. package/lib/scripts/datautil.mjs +0 -16
  129. package/lib/scripts/datautil.ts +0 -19
  130. package/lib/scripts/images/transparent_150x192.jpg +0 -0
  131. package/lib/scripts/images/transparent_155x225.jpg +0 -0
  132. package/lib/scripts/parse_textes.mjs +0 -46
  133. package/lib/scripts/parse_textes.ts +0 -65
  134. package/lib/scripts/retrieve_documents.mjs +0 -249
  135. package/lib/scripts/retrieve_documents.ts +0 -298
  136. package/lib/scripts/retrieve_open_data.mjs +0 -217
  137. package/lib/scripts/retrieve_open_data.ts +0 -274
  138. package/lib/scripts/retrieve_senateurs_photos.mjs +0 -147
  139. package/lib/scripts/retrieve_senateurs_photos.ts +0 -177
  140. package/lib/scripts/retrieve_textes.d.ts +0 -1
  141. package/lib/scripts/retrieve_textes.mjs +0 -328
  142. package/lib/scripts/retrieve_textes.ts +0 -143
  143. package/lib/scripts/shared/cli_helpers.ts +0 -36
  144. package/lib/scripts/shared/util.ts +0 -33
  145. package/lib/src/aggregates.d.ts +0 -52
  146. package/lib/src/aggregates.mjs +0 -726
  147. package/lib/src/config.d.ts +0 -2
  148. package/lib/src/config.mjs +0 -16
  149. package/lib/src/databases.d.ts +0 -18
  150. package/lib/src/databases.mjs +0 -55
  151. package/lib/src/datasets.d.ts +0 -28
  152. package/lib/src/datasets.mjs +0 -78
  153. package/lib/src/fields.d.ts +0 -10
  154. package/lib/src/fields.mjs +0 -22
  155. package/lib/src/index.d.ts +0 -8
  156. package/lib/src/index.mjs +0 -7
  157. package/lib/src/inserters.d.ts +0 -98
  158. package/lib/src/inserters.mjs +0 -360
  159. package/lib/src/loaders.d.ts +0 -36
  160. package/lib/src/loaders.mjs +0 -107
  161. package/lib/src/model/ameli.d.ts +0 -4
  162. package/lib/src/model/ameli.js +0 -57
  163. package/lib/src/model/debats.d.ts +0 -4
  164. package/lib/src/model/debats.js +0 -43
  165. package/lib/src/model/dosleg.d.ts +0 -197
  166. package/lib/src/model/dosleg.js +0 -169
  167. package/lib/src/model/index.d.ts +0 -4
  168. package/lib/src/model/index.js +0 -4
  169. package/lib/src/model/questions.d.ts +0 -89
  170. package/lib/src/model/questions.js +0 -76
  171. package/lib/src/model/sens.d.ts +0 -390
  172. package/lib/src/model/sens.js +0 -339
  173. package/lib/src/model/texte.d.ts +0 -7
  174. package/lib/src/model/texte.js +0 -183
  175. package/lib/src/raw_types_kysely/ameli.d.ts +0 -915
  176. package/lib/src/raw_types_kysely/ameli.js +0 -5
  177. package/lib/src/raw_types_kysely/debats.d.ts +0 -207
  178. package/lib/src/raw_types_kysely/debats.js +0 -5
  179. package/lib/src/raw_types_kysely/dosleg.d.ts +0 -3532
  180. package/lib/src/raw_types_kysely/dosleg.js +0 -5
  181. package/lib/src/raw_types_kysely/questions.d.ts +0 -414
  182. package/lib/src/raw_types_kysely/questions.js +0 -5
  183. package/lib/src/raw_types_kysely/sens.d.ts +0 -4394
  184. package/lib/src/raw_types_kysely/sens.js +0 -5
  185. package/lib/src/raw_types_schemats/ameli.d.ts +0 -541
  186. package/lib/src/raw_types_schemats/ameli.js +0 -2
  187. package/lib/src/raw_types_schemats/debats.d.ts +0 -127
  188. package/lib/src/raw_types_schemats/debats.js +0 -2
  189. package/lib/src/raw_types_schemats/dosleg.d.ts +0 -2027
  190. package/lib/src/raw_types_schemats/dosleg.js +0 -2
  191. package/lib/src/raw_types_schemats/questions.d.ts +0 -231
  192. package/lib/src/raw_types_schemats/questions.js +0 -2
  193. package/lib/src/raw_types_schemats/sens.d.ts +0 -2709
  194. package/lib/src/raw_types_schemats/sens.js +0 -2
  195. package/lib/src/scripts/convert_data.d.ts +0 -1
  196. package/lib/src/scripts/convert_data.js +0 -95
  197. package/lib/src/scripts/datautil.d.ts +0 -5
  198. package/lib/src/scripts/datautil.js +0 -16
  199. package/lib/src/scripts/parse_textes.d.ts +0 -1
  200. package/lib/src/scripts/parse_textes.js +0 -47
  201. package/lib/src/scripts/retrieve_documents.d.ts +0 -1
  202. package/lib/src/scripts/retrieve_documents.js +0 -258
  203. package/lib/src/scripts/retrieve_open_data.d.ts +0 -1
  204. package/lib/src/scripts/retrieve_open_data.js +0 -214
  205. package/lib/src/scripts/retrieve_senateurs_photos.d.ts +0 -1
  206. package/lib/src/scripts/retrieve_senateurs_photos.js +0 -147
  207. package/lib/src/scripts/shared/cli_helpers.d.ts +0 -44
  208. package/lib/src/scripts/shared/cli_helpers.js +0 -32
  209. package/lib/src/scripts/shared/util.d.ts +0 -3
  210. package/lib/src/scripts/shared/util.js +0 -28
  211. package/lib/src/strings.d.ts +0 -1
  212. package/lib/src/strings.mjs +0 -18
  213. package/lib/src/types/ameli.d.ts +0 -10
  214. package/lib/src/types/ameli.js +0 -13
  215. package/lib/src/types/debats.d.ts +0 -4
  216. package/lib/src/types/debats.js +0 -2
  217. package/lib/src/types/dosleg.d.ts +0 -98
  218. package/lib/src/types/dosleg.js +0 -151
  219. package/lib/src/types/questions.d.ts +0 -2
  220. package/lib/src/types/questions.js +0 -1
  221. package/lib/src/types/sens.d.ts +0 -10
  222. package/lib/src/types/sens.js +0 -1
  223. package/lib/src/types/sessions.d.ts +0 -42
  224. package/lib/src/types/sessions.js +0 -43
  225. package/lib/src/types/texte.d.ts +0 -61
  226. package/lib/src/types/texte.js +0 -16
  227. package/lib/src/validators/config.d.ts +0 -1
  228. package/lib/src/validators/config.js +0 -54
  229. package/lib/src/validators/senat.d.ts +0 -0
  230. package/lib/src/validators/senat.js +0 -24
  231. package/lib/strings.mjs +0 -18
  232. package/lib/strings.ts +0 -26
  233. package/lib/types/ameli.mjs +0 -13
  234. package/lib/types/ameli.ts +0 -21
  235. package/lib/types/debats.mjs +0 -2
  236. package/lib/types/debats.ts +0 -6
  237. package/lib/types/dosleg.mjs +0 -151
  238. package/lib/types/dosleg.ts +0 -284
  239. package/lib/types/questions.mjs +0 -1
  240. package/lib/types/questions.ts +0 -3
  241. package/lib/types/sens.mjs +0 -1
  242. package/lib/types/sens.ts +0 -12
  243. package/lib/types/sessions.mjs +0 -43
  244. package/lib/types/sessions.ts +0 -42
  245. package/lib/types/texte.mjs +0 -16
  246. package/lib/types/texte.ts +0 -76
  247. package/lib/typings/windows-1252.d.js +0 -2
  248. package/lib/typings/windows-1252.d.mjs +0 -2
  249. package/lib/typings/windows-1252.d.ts +0 -11
  250. package/lib/validators/config.mjs +0 -54
  251. package/lib/validators/config.ts +0 -79
  252. package/lib/validators/senat.mjs +0 -24
  253. package/lib/validators/senat.ts +0 -26
@@ -1,240 +0,0 @@
1
- import { Expression, InferResult, NotNull, sql } from "kysely"
2
- import { jsonArrayFrom } from "kysely/helpers/postgres"
3
-
4
- import { dbDosleg } from "../databases"
5
- import { concat, removeSubstring, rtrim, toDateString } from "./util"
6
-
7
- function orderOrdreOrigineTexte (expr: Expression<string | null | undefined>) {
8
- return sql`array_position(array['0','2','1'], ${expr})`
9
- }
10
-
11
- function datesSeances (lectureAssembleeId: Expression<string>) {
12
- return jsonArrayFrom(
13
- dbDosleg.selectFrom("date_seance")
14
- .where("date_seance.lecidt", "=", lectureAssembleeId)
15
- .select(({ ref }) => [
16
- toDateString(ref("date_seance.date_s")).as("date"),
17
- ]),
18
- )
19
- }
20
-
21
- function organismesRapport (rapportId: Expression<string>) {
22
- return jsonArrayFrom(
23
- dbDosleg.selectFrom("org")
24
- .leftJoin("raporg", "raporg.orgcod", "org.orgcod")
25
- .where("raporg.rapcod", "=", rapportId)
26
- .select([
27
- "org.orgnom as libelle",
28
- ]),
29
- )
30
- }
31
-
32
- function auteursRapport (rapportId: Expression<string>) {
33
- return jsonArrayFrom(
34
- dbDosleg.selectFrom("auteur")
35
- .leftJoin("ecr", "ecr.autcod", "auteur.autcod")
36
- .where("ecr.rapcod", "=", rapportId)
37
- .select([
38
- "auteur.prenom as prenom",
39
- "auteur.nomuse as nom_usuel",
40
- "auteur.autmat as matricule",
41
- ])
42
- .orderBy("ecr.ecrnumtri", "asc"),
43
- )
44
- }
45
-
46
- function rapports (lectureAssembleeId: Expression<string>) {
47
- return jsonArrayFrom(
48
- dbDosleg.selectFrom("rap")
49
- .leftJoin("lecassrap", "lecassrap.rapcod", "rap.rapcod")
50
- .leftJoin("denrap", "denrap.coddenrap", "rap.coddenrap")
51
- .where("lecassrap.lecassidt", "=", lectureAssembleeId)
52
- .select(({ eb, ref, val }) => [
53
- "rap.rapnum as numero",
54
- rtrim(ref("denrap.libdenrap")).as("type_rapport"),
55
- eb.case()
56
- .when("rap.typurl", "=", "I")
57
- .then(concat(val("https://www.senat.fr/rap/"), rtrim(ref("rap.rapurl"))))
58
- .else(rtrim(ref("rap.rapurl")))
59
- .end()
60
- .as("url"),
61
- toDateString(ref("rap.date_depot")).as("date_depot"),
62
- auteursRapport(ref("rap.rapcod")).as("auteurs"),
63
- organismesRapport(ref("rap.rapcod")).as("organismes"),
64
- ]),
65
- )
66
- }
67
-
68
- function auteursTexte (texteId: Expression<string>) {
69
- return jsonArrayFrom(
70
- dbDosleg.selectFrom("auteur")
71
- .leftJoin("ecr", "ecr.autcod", "auteur.autcod")
72
- .where("ecr.texcod", "=", texteId)
73
- .select([
74
- "auteur.prenom as prenom",
75
- "auteur.nomuse as nom_usuel",
76
- "auteur.autmat as matricule",
77
- ])
78
- .orderBy("ecr.ecrnumtri", "asc"),
79
- )
80
- }
81
-
82
- function textes (lectureAssembleeId: Expression<string>) {
83
- return jsonArrayFrom(
84
- dbDosleg.selectFrom("texte")
85
- .leftJoin("oritxt", "oritxt.oritxtcod", "texte.oritxtcod")
86
- .leftJoin("typtxt", "typtxt.typtxtcod", "texte.typtxtcod")
87
- .where("texte.lecassidt", "=", lectureAssembleeId)
88
- .select(({ eb, ref, val }) => [
89
- "texte.texnum as numero",
90
- eb.case()
91
- .when("texte.typurl", "=", "I")
92
- .then(removeSubstring(ref("texte.texurl"), val(".html")))
93
- .else(null)
94
- .end()
95
- .as("id"),
96
- eb.case()
97
- .when("texte.typurl", "=", "I")
98
- .then(concat(val("https://www.senat.fr/leg/"), rtrim(ref("texte.texurl"))))
99
- .else(rtrim(ref("texte.texurl")))
100
- .end()
101
- .as("url"),
102
- rtrim(ref("oritxt.oritxtlib")).as("origine_texte"),
103
- rtrim(ref("typtxt.typtxtlib")).as("type_texte"),
104
- toDateString(ref("texte.txtoritxtdat")).as("date"),
105
- "sesann as session",
106
- auteursTexte(ref("texte.texcod")).as("auteurs"),
107
- ])
108
- .orderBy(({ ref }) => orderOrdreOrigineTexte(ref("oritxt.oriordre")))
109
- )
110
- }
111
-
112
- function lecturesAssemblee (lectureId: Expression<string>) {
113
- return jsonArrayFrom(
114
- dbDosleg.selectFrom("lecass")
115
- .where("lecass.lecidt", "=", lectureId)
116
- .leftJoin("ass", "ass.codass", "lecass.codass")
117
- .leftJoin("org", "org.orgcod", "lecass.orgcod")
118
- .select(({ ref }) => [
119
- rtrim(ref("ass.libass")).as("assemblee"),
120
- "org.orgnom as libelle_organisme",
121
- "org.orgcod as code_organisme",
122
- "lecass.ordreass as ordre_lecture_assemblee",
123
- textes(ref("lecass.lecassidt")).as("textes"),
124
- rapports(ref("lecass.lecassidt")).as("rapports"),
125
- datesSeances(ref("lecass.lecassidt")).as("dates_seances"),
126
- ])
127
- .orderBy("lecass.ordreass", "asc"),
128
- )
129
- }
130
-
131
- function lectures (loiId: Expression<string>) {
132
- return jsonArrayFrom(
133
- dbDosleg.selectFrom("lecture")
134
- .leftJoin("typlec", "typlec.typleccod", "lecture.typleccod")
135
- .where("lecture.loicod", "=", loiId)
136
- .select(({ ref }) => [
137
- rtrim(ref("typlec.typleclib")).as("type_lecture"),
138
- rtrim(ref("lecture.leccom")).as("libelle"),
139
- "typlec.typlecord as ordre_lecture",
140
- lecturesAssemblee(ref("lecture.lecidt")).as("lectures_assemblee"),
141
- ])
142
- .orderBy("typlec.typlecord", "asc"),
143
- )
144
- }
145
-
146
- function themes (loiId: Expression<string>) {
147
- return jsonArrayFrom(
148
- dbDosleg.selectFrom("the")
149
- .leftJoin("loithe", "loithe.thecle", "the.thecle")
150
- .where("loithe.loicod", "=", loiId)
151
- .select([
152
- "the.thelib as libelle",
153
- ]),
154
- )
155
- }
156
-
157
- const findAllQuery = dbDosleg
158
- .selectFrom("loi")
159
- .leftJoin("typloi", "typloi.typloicod", "loi.typloicod")
160
- .leftJoin("etaloi", "etaloi.etaloicod", "loi.etaloicod")
161
- .select(({ eb, ref, val }) => [
162
- "loi.signet as signet",
163
- concat(val("https://www.senat.fr/dossier-legislatif/"), ref("loi.signet"), val(".html")).as("url"),
164
- concat(rtrim(ref("typloi.typloiden")), val(" "), rtrim(ref("loi.loitit"))).as("titre"),
165
- rtrim(ref("loi.loient")).as("titre_court"),
166
- rtrim(ref("typloi.groupe")).as("code_nature_dossier"),
167
- rtrim(ref("typloi.typloilib")).as("libelle_type_dossier"),
168
- rtrim(ref("etaloi.etaloilib")).as("etat_dossier"),
169
- "loi.url_an as url_dossier_assemblee_nationale",
170
- toDateString(ref("loi.date_decision")).as("date_decision_CoC"),
171
- "loi.num_decision as num_decision_CoC",
172
- "loi.deccocurl as url_decision_CoC",
173
- toDateString(ref("loi.saisine_date")).as("date_saisine_CoC"),
174
- "loi.saisine_par as condition_saisine_CoC",
175
- toDateString(ref("loi.date_loi")).as("date_promulgation"),
176
- "loi.numero as numero_loi",
177
- eb.case()
178
- .when("loi.loititjo", "is not", null)
179
- .then(concat(rtrim(ref("typloi.typloiden")), val(" "), rtrim(ref("loi.loititjo"))))
180
- .else("")
181
- .end()
182
- .as("titre_JO"),
183
- toDateString(ref("loi.loidatjo")).as("date_publication_JO"),
184
- "loi.loinumjo as numero_JO",
185
- "loi.url_jo as url_JO",
186
- lectures(ref("loi.loicod")).as("lectures"),
187
- themes(ref("loi.loicod")).as("themes"),
188
- ])
189
- .$narrowType<{ signet: NotNull }>()
190
-
191
- export function findAll () {
192
- return findAllQuery.stream()
193
- }
194
-
195
- export function findSenatTexteUrls (sessions: string[] = []): AsyncIterableIterator<{
196
- session: string | null | undefined,
197
- url: string,
198
- hasExposeDesMotifs: boolean,
199
- }> {
200
- return dbDosleg
201
- .selectFrom("texte")
202
- .where("texurl", "is not", null)
203
- .where("typurl", "=", "I")
204
- .$if(sessions.length > 0, (qb) => qb
205
- .where("sesann", "in", sessions),
206
- )
207
- .select(({ eb, ref }) => [
208
- "sesann as session",
209
- rtrim(ref("texurl")).as("url"),
210
- eb.case()
211
- .when("oritxtcod", "=", "1")
212
- .then(true)
213
- .else(false)
214
- .end()
215
- .as("hasExposeDesMotifs"),
216
- ])
217
- .$narrowType<{ url: NotNull }>()
218
- .stream()
219
- }
220
-
221
- export function findSenatRapportUrls (sessions: string[] = []): AsyncIterableIterator<{
222
- url: string,
223
- session: string | null | undefined
224
- }> {
225
- return dbDosleg
226
- .selectFrom("rap")
227
- .where("rapurl", "is not", null)
228
- .where("typurl", "=", "I")
229
- .$if(sessions.length > 0, (qb) => qb
230
- .where("sesann", "in", sessions),
231
- )
232
- .select(({ ref }) => [
233
- rtrim(ref("rapurl")).as("url"),
234
- "sesann as session",
235
- ])
236
- .$narrowType<{ url: NotNull }>()
237
- .stream()
238
- }
239
-
240
- export type DossierLegislatifResult = InferResult<typeof findAllQuery>[0]
@@ -1,4 +0,0 @@
1
- export { findAll as findAllAmendements, } from "./ameli";
2
- export { findAll as findAllLois, } from "./dosleg";
3
- export { findAll as findAllQuestions, } from "./questions";
4
- export { findAll as findAllSens, findAllCirconscriptions, findAllOrganismes, } from "./sens";
@@ -1,14 +0,0 @@
1
- export {
2
- findAll as findAllAmendements,
3
- } from "./ameli"
4
- export {
5
- findAll as findAllLois,
6
- } from "./dosleg"
7
- export {
8
- findAll as findAllQuestions,
9
- } from "./questions"
10
- export {
11
- findAll as findAllSens,
12
- findAllCirconscriptions,
13
- findAllOrganismes,
14
- } from "./sens"
@@ -1,71 +0,0 @@
1
- import { jsonArrayFrom } from "kysely/helpers/postgres";
2
- import { dbQuestions } from "../databases";
3
- import { expandToRows, rtrim, toDateString } from "./util";
4
- function reponses(questionId) {
5
- return jsonArrayFrom(dbQuestions.selectFrom("tam_reponses")
6
- .where("tam_reponses.idque", "=", questionId)
7
- .select(({ ref }) => [
8
- toDateString(ref("tam_reponses.datejorep")).as("date_reponse_JO"),
9
- "tam_reponses.minreplib as ministere_reponse",
10
- "tam_reponses.txtrep as texte",
11
- "tam_reponses.txterrrep as texte_erratum",
12
- ])
13
- .orderBy("tam_reponses.datejorep asc"));
14
- }
15
- function themes(questionId) {
16
- return jsonArrayFrom(dbQuestions.with("question_theme", (db) => db
17
- .selectFrom("tam_questions")
18
- .select(({ eb, ref, val }) => [
19
- "id as question_id",
20
- eb.cast(expandToRows(ref("tam_questions.themes"), val("#(\\d+)")), "smallint").as("theme_id"),
21
- ]))
22
- .selectFrom("the")
23
- .leftJoin("question_theme", "the.thenouidt", "question_theme.theme_id")
24
- .where("question_theme.question_id", "=", questionId)
25
- .select("the.thelib as libelle")
26
- .orderBy("the.thenouidt asc"));
27
- }
28
- const findAllQuery = dbQuestions
29
- .selectFrom("tam_questions")
30
- .leftJoin("tam_ministeres", "tam_questions.mindepotid", "tam_ministeres.minid")
31
- .leftJoin("sortquestion", (join) => join
32
- .onRef("tam_questions.sorquecod", "=", eb => eb.cast("sortquestion.sorquecod", "bigint")))
33
- .leftJoin("naturequestion", "tam_questions.natquecod", "naturequestion.natquecod")
34
- .leftJoin("etatquestion", (join) => join
35
- .onRef("tam_questions.etaquecod", "=", eb => eb.cast("etatquestion.etaquecod", "bigint")))
36
- .select(({ ref }) => [
37
- "tam_questions.repub as republique",
38
- "tam_questions.legislature as legislature",
39
- "sortquestion.sorquelib as sort",
40
- "tam_questions.natquecod as nature",
41
- "tam_questions.numero as numero",
42
- "tam_questions.reference as reference",
43
- "tam_questions.titre as titre",
44
- "tam_questions.nom as nom",
45
- "tam_questions.prenom as prenom",
46
- "tam_questions.codequalite as civilite",
47
- "tam_questions.matricule as matricule",
48
- "tam_questions.circonscription as circonscription",
49
- "tam_questions.groupe as groupe",
50
- "tam_questions.ratgrp as type_appartenance",
51
- toDateString(ref("tam_questions.datejodepot")).as("date_publication_JO"),
52
- rtrim(ref("tam_questions.mindepotlib")).as("ministere_depot"),
53
- toDateString(ref("tam_ministeres.datedebut")).as("ministere_depot_date_debut"),
54
- toDateString(ref("tam_questions.datejotran")).as("date_transmission"),
55
- "tam_questions.mintranlib as ministere_transmission",
56
- toDateString(ref("tam_questions.datejorep1")).as("date_reponse_JO"),
57
- "tam_questions.minreplib1 as ministere_reponse",
58
- toDateString(ref("tam_questions.datecloture")).as("date_cloture"),
59
- "tam_questions.refquerappelee as reference_question_rappelee",
60
- //"tam_questions.url as url", // TODO ?
61
- "tam_questions.txtque as texte",
62
- "tam_questions.txtque as texte_erratum",
63
- "tam_questions.rubrique as rubrique",
64
- ])
65
- .select(({ ref }) => [
66
- themes(ref("tam_questions.id")).as("themes"),
67
- reponses(ref("tam_questions.id")).as("reponses"),
68
- ]);
69
- export function findAll() {
70
- return findAllQuery.stream();
71
- }
@@ -1,93 +0,0 @@
1
- import { Expression, InferResult } from "kysely"
2
- import { jsonArrayFrom } from "kysely/helpers/postgres"
3
- import { dbQuestions } from "../databases"
4
- import { expandToRows, rtrim, toDateString } from "./util"
5
-
6
- function reponses (questionId: Expression<string>) {
7
- return jsonArrayFrom(
8
- dbQuestions.selectFrom("tam_reponses")
9
- .where("tam_reponses.idque", "=", questionId)
10
- .select(({ ref }) => [
11
- toDateString(ref("tam_reponses.datejorep")).as("date_reponse_JO"),
12
- "tam_reponses.minreplib as ministere_reponse",
13
- "tam_reponses.txtrep as texte",
14
- "tam_reponses.txterrrep as texte_erratum",
15
- ])
16
- .orderBy("tam_reponses.datejorep asc"),
17
- )
18
- }
19
-
20
- function themes (questionId: Expression<string>) {
21
- return jsonArrayFrom(
22
- dbQuestions.with("question_theme", (db) => db
23
- .selectFrom("tam_questions")
24
- .select(({ eb, ref, val }) => [
25
- "id as question_id",
26
- eb.cast<number>(expandToRows(ref("tam_questions.themes"), val("#(\\d+)")), "smallint").as("theme_id"),
27
- ]),
28
- )
29
- .selectFrom("the")
30
- .leftJoin("question_theme", "the.thenouidt", "question_theme.theme_id")
31
- .where("question_theme.question_id", "=", questionId)
32
- .select("the.thelib as libelle")
33
- .orderBy("the.thenouidt asc"),
34
- )
35
- }
36
-
37
- const findAllQuery = dbQuestions
38
- .selectFrom("tam_questions")
39
- .leftJoin("tam_ministeres", "tam_questions.mindepotid", "tam_ministeres.minid")
40
- .leftJoin("sortquestion", (join) => join
41
- .onRef(
42
- "tam_questions.sorquecod",
43
- "=",
44
- eb => eb.cast<number>("sortquestion.sorquecod", "bigint"),
45
- ),
46
- )
47
- .leftJoin("naturequestion", "tam_questions.natquecod", "naturequestion.natquecod")
48
- .leftJoin("etatquestion", (join) => join
49
- .onRef(
50
- "tam_questions.etaquecod",
51
- "=",
52
- eb => eb.cast<number>("etatquestion.etaquecod", "bigint"),
53
- ),
54
- )
55
- .select(({ ref }) => [
56
- "tam_questions.repub as republique",
57
- "tam_questions.legislature as legislature",
58
- "sortquestion.sorquelib as sort",
59
- "tam_questions.natquecod as nature",
60
- "tam_questions.numero as numero",
61
- "tam_questions.reference as reference",
62
- "tam_questions.titre as titre",
63
- "tam_questions.nom as nom",
64
- "tam_questions.prenom as prenom",
65
- "tam_questions.codequalite as civilite",
66
- "tam_questions.matricule as matricule",
67
- "tam_questions.circonscription as circonscription",
68
- "tam_questions.groupe as groupe",
69
- "tam_questions.ratgrp as type_appartenance",
70
- toDateString(ref("tam_questions.datejodepot")).as("date_publication_JO"),
71
- rtrim(ref("tam_questions.mindepotlib")).as("ministere_depot"),
72
- toDateString(ref("tam_ministeres.datedebut")).as("ministere_depot_date_debut"),
73
- toDateString(ref("tam_questions.datejotran")).as("date_transmission"),
74
- "tam_questions.mintranlib as ministere_transmission",
75
- toDateString(ref("tam_questions.datejorep1")).as("date_reponse_JO"),
76
- "tam_questions.minreplib1 as ministere_reponse",
77
- toDateString(ref("tam_questions.datecloture")).as("date_cloture"),
78
- "tam_questions.refquerappelee as reference_question_rappelee",
79
- //"tam_questions.url as url", // TODO ?
80
- "tam_questions.txtque as texte",
81
- "tam_questions.txtque as texte_erratum",
82
- "tam_questions.rubrique as rubrique",
83
- ])
84
- .select(({ ref }) => [
85
- themes(ref("tam_questions.id")).as("themes"),
86
- reponses(ref("tam_questions.id")).as("reponses"),
87
- ])
88
-
89
- export type QuestionResult = InferResult<typeof findAllQuery>[0]
90
-
91
- export function findAll () {
92
- return findAllQuery.stream()
93
- }