@tricoteuses/senat 1.3.1 → 1.3.4

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 (254) 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 +12 -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.d.ts +1 -1
  16. package/lib/model/sens.js +383 -113
  17. package/lib/model/texte.js +220 -290
  18. package/lib/model/util.js +9 -26
  19. package/lib/raw_types/ameli.js +5 -6
  20. package/lib/raw_types/debats.js +5 -6
  21. package/lib/raw_types/dosleg.js +5 -6
  22. package/lib/raw_types/questions.js +5 -6
  23. package/lib/raw_types/sens.js +5 -6
  24. package/lib/raw_types_schemats/ameli.js +1 -43
  25. package/lib/raw_types_schemats/debats.js +1 -22
  26. package/lib/raw_types_schemats/dosleg.js +1 -96
  27. package/lib/raw_types_schemats/questions.js +1 -22
  28. package/lib/raw_types_schemats/sens.js +1 -112
  29. package/lib/scripts/convert_data.js +181 -631
  30. package/lib/scripts/datautil.js +17 -60
  31. package/lib/scripts/parse_textes.js +46 -129
  32. package/lib/scripts/retrieve_documents.js +247 -513
  33. package/lib/scripts/retrieve_open_data.js +211 -368
  34. package/lib/scripts/retrieve_senateurs_photos.js +144 -239
  35. package/lib/scripts/shared/cli_helpers.js +30 -30
  36. package/lib/scripts/shared/util.js +28 -94
  37. package/lib/strings.js +20 -45
  38. package/lib/types/ameli.d.ts +1 -1
  39. package/lib/types/ameli.js +14 -25
  40. package/lib/types/debats.d.ts +1 -1
  41. package/lib/types/debats.js +3 -21
  42. package/lib/types/dosleg.d.ts +1 -1
  43. package/lib/types/dosleg.js +152 -119
  44. package/lib/types/questions.d.ts +1 -1
  45. package/lib/types/questions.js +1 -13
  46. package/lib/types/sens.d.ts +1 -1
  47. package/lib/types/sens.js +1 -13
  48. package/lib/types/sessions.js +44 -49
  49. package/lib/types/texte.js +17 -22
  50. package/lib/validators/config.js +47 -111
  51. package/lib/validators/senat.js +1 -5
  52. package/package.json +18 -40
  53. package/lib/aggregates.d.ts +0 -52
  54. package/lib/aggregates.mjs +0 -930
  55. package/lib/aggregates.ts +0 -833
  56. package/lib/config.mjs +0 -16
  57. package/lib/config.ts +0 -26
  58. package/lib/data/legislatures.json +0 -38
  59. package/lib/databases.mjs +0 -57
  60. package/lib/databases.ts +0 -71
  61. package/lib/datasets.mjs +0 -78
  62. package/lib/datasets.ts +0 -118
  63. package/lib/fields.d.ts +0 -10
  64. package/lib/fields.mjs +0 -68
  65. package/lib/fields.ts +0 -29
  66. package/lib/index.mjs +0 -4
  67. package/lib/index.ts +0 -42
  68. package/lib/inserters.d.ts +0 -98
  69. package/lib/inserters.mjs +0 -500
  70. package/lib/inserters.ts +0 -521
  71. package/lib/loaders.mjs +0 -158
  72. package/lib/loaders.ts +0 -271
  73. package/lib/model/ameli.mjs +0 -84
  74. package/lib/model/ameli.ts +0 -100
  75. package/lib/model/debats.mjs +0 -1
  76. package/lib/model/debats.ts +0 -0
  77. package/lib/model/dosleg.mjs +0 -196
  78. package/lib/model/dosleg.ts +0 -240
  79. package/lib/model/index.mjs +0 -4
  80. package/lib/model/index.ts +0 -14
  81. package/lib/model/questions.mjs +0 -71
  82. package/lib/model/questions.ts +0 -93
  83. package/lib/model/sens.mjs +0 -415
  84. package/lib/model/sens.ts +0 -516
  85. package/lib/model/texte.mjs +0 -208
  86. package/lib/model/texte.ts +0 -229
  87. package/lib/model/util.mjs +0 -19
  88. package/lib/model/util.ts +0 -32
  89. package/lib/raw_types/ameli.mjs +0 -5
  90. package/lib/raw_types/ameli.ts +0 -951
  91. package/lib/raw_types/debats.mjs +0 -5
  92. package/lib/raw_types/debats.ts +0 -222
  93. package/lib/raw_types/dosleg.mjs +0 -5
  94. package/lib/raw_types/dosleg.ts +0 -3625
  95. package/lib/raw_types/questions.mjs +0 -5
  96. package/lib/raw_types/questions.ts +0 -427
  97. package/lib/raw_types/sens.mjs +0 -5
  98. package/lib/raw_types/sens.ts +0 -4499
  99. package/lib/raw_types_kysely/ameli.d.ts +0 -6
  100. package/lib/raw_types_kysely/ameli.mjs +0 -7
  101. package/lib/raw_types_kysely/ameli.ts +0 -6
  102. package/lib/raw_types_kysely/debats.d.ts +0 -6
  103. package/lib/raw_types_kysely/debats.mjs +0 -7
  104. package/lib/raw_types_kysely/debats.ts +0 -6
  105. package/lib/raw_types_kysely/dosleg.d.ts +0 -6
  106. package/lib/raw_types_kysely/dosleg.mjs +0 -7
  107. package/lib/raw_types_kysely/dosleg.ts +0 -6
  108. package/lib/raw_types_kysely/questions.d.ts +0 -6
  109. package/lib/raw_types_kysely/questions.mjs +0 -7
  110. package/lib/raw_types_kysely/questions.ts +0 -6
  111. package/lib/raw_types_kysely/sens.d.ts +0 -6
  112. package/lib/raw_types_kysely/sens.mjs +0 -7
  113. package/lib/raw_types_kysely/sens.ts +0 -6
  114. package/lib/raw_types_kysely/texte.d.ts +0 -45
  115. package/lib/raw_types_kysely/texte.mjs +0 -7
  116. package/lib/raw_types_kysely/texte.ts +0 -53
  117. package/lib/raw_types_schemats/ameli.mjs +0 -2
  118. package/lib/raw_types_schemats/ameli.ts +0 -601
  119. package/lib/raw_types_schemats/debats.mjs +0 -2
  120. package/lib/raw_types_schemats/debats.ts +0 -145
  121. package/lib/raw_types_schemats/dosleg.mjs +0 -2
  122. package/lib/raw_types_schemats/dosleg.ts +0 -2195
  123. package/lib/raw_types_schemats/questions.mjs +0 -2
  124. package/lib/raw_types_schemats/questions.ts +0 -251
  125. package/lib/raw_types_schemats/sens.mjs +0 -2
  126. package/lib/raw_types_schemats/sens.ts +0 -2907
  127. package/lib/scripts/convert_data.mjs +0 -181
  128. package/lib/scripts/convert_data.ts +0 -243
  129. package/lib/scripts/datautil.mjs +0 -16
  130. package/lib/scripts/datautil.ts +0 -19
  131. package/lib/scripts/images/transparent_150x192.jpg +0 -0
  132. package/lib/scripts/images/transparent_155x225.jpg +0 -0
  133. package/lib/scripts/parse_textes.mjs +0 -46
  134. package/lib/scripts/parse_textes.ts +0 -65
  135. package/lib/scripts/retrieve_documents.mjs +0 -249
  136. package/lib/scripts/retrieve_documents.ts +0 -298
  137. package/lib/scripts/retrieve_open_data.mjs +0 -217
  138. package/lib/scripts/retrieve_open_data.ts +0 -274
  139. package/lib/scripts/retrieve_senateurs_photos.mjs +0 -147
  140. package/lib/scripts/retrieve_senateurs_photos.ts +0 -177
  141. package/lib/scripts/retrieve_textes.d.ts +0 -1
  142. package/lib/scripts/retrieve_textes.mjs +0 -328
  143. package/lib/scripts/retrieve_textes.ts +0 -143
  144. package/lib/scripts/shared/cli_helpers.ts +0 -36
  145. package/lib/scripts/shared/util.ts +0 -33
  146. package/lib/src/aggregates.d.ts +0 -52
  147. package/lib/src/aggregates.mjs +0 -726
  148. package/lib/src/config.d.ts +0 -2
  149. package/lib/src/config.mjs +0 -16
  150. package/lib/src/databases.d.ts +0 -18
  151. package/lib/src/databases.mjs +0 -55
  152. package/lib/src/datasets.d.ts +0 -28
  153. package/lib/src/datasets.mjs +0 -78
  154. package/lib/src/fields.d.ts +0 -10
  155. package/lib/src/fields.mjs +0 -22
  156. package/lib/src/index.d.ts +0 -8
  157. package/lib/src/index.mjs +0 -7
  158. package/lib/src/inserters.d.ts +0 -98
  159. package/lib/src/inserters.mjs +0 -360
  160. package/lib/src/loaders.d.ts +0 -36
  161. package/lib/src/loaders.mjs +0 -107
  162. package/lib/src/model/ameli.d.ts +0 -4
  163. package/lib/src/model/ameli.js +0 -57
  164. package/lib/src/model/debats.d.ts +0 -4
  165. package/lib/src/model/debats.js +0 -43
  166. package/lib/src/model/dosleg.d.ts +0 -197
  167. package/lib/src/model/dosleg.js +0 -169
  168. package/lib/src/model/index.d.ts +0 -4
  169. package/lib/src/model/index.js +0 -4
  170. package/lib/src/model/questions.d.ts +0 -89
  171. package/lib/src/model/questions.js +0 -76
  172. package/lib/src/model/sens.d.ts +0 -390
  173. package/lib/src/model/sens.js +0 -339
  174. package/lib/src/model/texte.d.ts +0 -7
  175. package/lib/src/model/texte.js +0 -183
  176. package/lib/src/raw_types_kysely/ameli.d.ts +0 -915
  177. package/lib/src/raw_types_kysely/ameli.js +0 -5
  178. package/lib/src/raw_types_kysely/debats.d.ts +0 -207
  179. package/lib/src/raw_types_kysely/debats.js +0 -5
  180. package/lib/src/raw_types_kysely/dosleg.d.ts +0 -3532
  181. package/lib/src/raw_types_kysely/dosleg.js +0 -5
  182. package/lib/src/raw_types_kysely/questions.d.ts +0 -414
  183. package/lib/src/raw_types_kysely/questions.js +0 -5
  184. package/lib/src/raw_types_kysely/sens.d.ts +0 -4394
  185. package/lib/src/raw_types_kysely/sens.js +0 -5
  186. package/lib/src/raw_types_schemats/ameli.d.ts +0 -541
  187. package/lib/src/raw_types_schemats/ameli.js +0 -2
  188. package/lib/src/raw_types_schemats/debats.d.ts +0 -127
  189. package/lib/src/raw_types_schemats/debats.js +0 -2
  190. package/lib/src/raw_types_schemats/dosleg.d.ts +0 -2027
  191. package/lib/src/raw_types_schemats/dosleg.js +0 -2
  192. package/lib/src/raw_types_schemats/questions.d.ts +0 -231
  193. package/lib/src/raw_types_schemats/questions.js +0 -2
  194. package/lib/src/raw_types_schemats/sens.d.ts +0 -2709
  195. package/lib/src/raw_types_schemats/sens.js +0 -2
  196. package/lib/src/scripts/convert_data.d.ts +0 -1
  197. package/lib/src/scripts/convert_data.js +0 -95
  198. package/lib/src/scripts/datautil.d.ts +0 -5
  199. package/lib/src/scripts/datautil.js +0 -16
  200. package/lib/src/scripts/parse_textes.d.ts +0 -1
  201. package/lib/src/scripts/parse_textes.js +0 -47
  202. package/lib/src/scripts/retrieve_documents.d.ts +0 -1
  203. package/lib/src/scripts/retrieve_documents.js +0 -258
  204. package/lib/src/scripts/retrieve_open_data.d.ts +0 -1
  205. package/lib/src/scripts/retrieve_open_data.js +0 -214
  206. package/lib/src/scripts/retrieve_senateurs_photos.d.ts +0 -1
  207. package/lib/src/scripts/retrieve_senateurs_photos.js +0 -147
  208. package/lib/src/scripts/shared/cli_helpers.d.ts +0 -44
  209. package/lib/src/scripts/shared/cli_helpers.js +0 -32
  210. package/lib/src/scripts/shared/util.d.ts +0 -3
  211. package/lib/src/scripts/shared/util.js +0 -28
  212. package/lib/src/strings.d.ts +0 -1
  213. package/lib/src/strings.mjs +0 -18
  214. package/lib/src/types/ameli.d.ts +0 -10
  215. package/lib/src/types/ameli.js +0 -13
  216. package/lib/src/types/debats.d.ts +0 -4
  217. package/lib/src/types/debats.js +0 -2
  218. package/lib/src/types/dosleg.d.ts +0 -98
  219. package/lib/src/types/dosleg.js +0 -151
  220. package/lib/src/types/questions.d.ts +0 -2
  221. package/lib/src/types/questions.js +0 -1
  222. package/lib/src/types/sens.d.ts +0 -10
  223. package/lib/src/types/sens.js +0 -1
  224. package/lib/src/types/sessions.d.ts +0 -42
  225. package/lib/src/types/sessions.js +0 -43
  226. package/lib/src/types/texte.d.ts +0 -61
  227. package/lib/src/types/texte.js +0 -16
  228. package/lib/src/validators/config.d.ts +0 -1
  229. package/lib/src/validators/config.js +0 -54
  230. package/lib/src/validators/senat.d.ts +0 -0
  231. package/lib/src/validators/senat.js +0 -24
  232. package/lib/strings.mjs +0 -18
  233. package/lib/strings.ts +0 -26
  234. package/lib/types/ameli.mjs +0 -13
  235. package/lib/types/ameli.ts +0 -21
  236. package/lib/types/debats.mjs +0 -2
  237. package/lib/types/debats.ts +0 -6
  238. package/lib/types/dosleg.mjs +0 -151
  239. package/lib/types/dosleg.ts +0 -284
  240. package/lib/types/questions.mjs +0 -1
  241. package/lib/types/questions.ts +0 -3
  242. package/lib/types/sens.mjs +0 -1
  243. package/lib/types/sens.ts +0 -12
  244. package/lib/types/sessions.mjs +0 -43
  245. package/lib/types/sessions.ts +0 -42
  246. package/lib/types/texte.mjs +0 -16
  247. package/lib/types/texte.ts +0 -76
  248. package/lib/typings/windows-1252.d.js +0 -2
  249. package/lib/typings/windows-1252.d.mjs +0 -2
  250. package/lib/typings/windows-1252.d.ts +0 -11
  251. package/lib/validators/config.mjs +0 -54
  252. package/lib/validators/config.ts +0 -79
  253. package/lib/validators/senat.mjs +0 -24
  254. 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
- }