@tricoteuses/senat 3.1.0 → 3.1.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 (306) hide show
  1. package/lib/src/loaders.d.ts +3 -3
  2. package/lib/src/loaders.js +1 -1
  3. package/lib/src/model/agenda.d.ts +1 -1
  4. package/lib/src/model/commission.d.ts +2 -2
  5. package/lib/src/model/seance.d.ts +1 -1
  6. package/lib/src/types/ameli.d.ts +4 -1761
  7. package/lib/src/types/ameli.js +1 -1074
  8. package/lib/src/types/debats.d.ts +2 -380
  9. package/lib/src/types/debats.js +1 -266
  10. package/lib/src/types/dosleg.d.ts +69 -2953
  11. package/lib/src/types/dosleg.js +1 -2005
  12. package/lib/src/types/questions.d.ts +2 -699
  13. package/lib/src/types/questions.js +1 -493
  14. package/lib/src/types/sens.d.ts +7 -7842
  15. package/lib/src/types/sens.js +1 -4691
  16. package/lib/src/utils/nvs-parsing.d.ts +1 -1
  17. package/lib/src/utils/nvs-parsing.js +9 -1
  18. package/lib/src/videos/pipeline.d.ts +3 -3
  19. package/lib/src/videos/pipeline.js +2 -2
  20. package/package.json +1 -1
  21. package/lib/add-js-extensions-v2.d.ts +0 -1
  22. package/lib/add-js-extensions-v2.js +0 -23
  23. package/lib/add-js-extensions.d.ts +0 -1
  24. package/lib/add-js-extensions.js +0 -17
  25. package/lib/aggregates.d.ts +0 -52
  26. package/lib/aggregates.js +0 -930
  27. package/lib/aggregates.mjs +0 -713
  28. package/lib/aggregates.ts +0 -833
  29. package/lib/config.d.ts +0 -10
  30. package/lib/config.js +0 -16
  31. package/lib/config.mjs +0 -16
  32. package/lib/config.ts +0 -26
  33. package/lib/databases.d.ts +0 -2
  34. package/lib/databases.js +0 -26
  35. package/lib/databases.mjs +0 -57
  36. package/lib/databases.ts +0 -71
  37. package/lib/datasets.d.ts +0 -34
  38. package/lib/datasets.js +0 -233
  39. package/lib/datasets.mjs +0 -78
  40. package/lib/datasets.ts +0 -118
  41. package/lib/fields.d.ts +0 -10
  42. package/lib/fields.js +0 -68
  43. package/lib/fields.mjs +0 -22
  44. package/lib/fields.ts +0 -29
  45. package/lib/git.d.ts +0 -26
  46. package/lib/git.js +0 -167
  47. package/lib/index.d.ts +0 -13
  48. package/lib/index.js +0 -1
  49. package/lib/index.mjs +0 -7
  50. package/lib/index.ts +0 -64
  51. package/lib/inserters.d.ts +0 -98
  52. package/lib/inserters.js +0 -500
  53. package/lib/inserters.mjs +0 -360
  54. package/lib/inserters.ts +0 -521
  55. package/lib/legislatures.json +0 -38
  56. package/lib/loaders.d.ts +0 -58
  57. package/lib/loaders.js +0 -286
  58. package/lib/loaders.mjs +0 -158
  59. package/lib/loaders.ts +0 -271
  60. package/lib/model/agenda.d.ts +0 -6
  61. package/lib/model/agenda.js +0 -148
  62. package/lib/model/ameli.d.ts +0 -51
  63. package/lib/model/ameli.js +0 -149
  64. package/lib/model/ameli.mjs +0 -84
  65. package/lib/model/ameli.ts +0 -100
  66. package/lib/model/commission.d.ts +0 -18
  67. package/lib/model/commission.js +0 -269
  68. package/lib/model/debats.d.ts +0 -67
  69. package/lib/model/debats.js +0 -95
  70. package/lib/model/debats.mjs +0 -43
  71. package/lib/model/debats.ts +0 -68
  72. package/lib/model/documents.d.ts +0 -12
  73. package/lib/model/documents.js +0 -151
  74. package/lib/model/dosleg.d.ts +0 -7
  75. package/lib/model/dosleg.js +0 -326
  76. package/lib/model/dosleg.mjs +0 -196
  77. package/lib/model/dosleg.ts +0 -240
  78. package/lib/model/index.d.ts +0 -7
  79. package/lib/model/index.js +0 -7
  80. package/lib/model/index.mjs +0 -5
  81. package/lib/model/index.ts +0 -15
  82. package/lib/model/questions.d.ts +0 -45
  83. package/lib/model/questions.js +0 -89
  84. package/lib/model/questions.mjs +0 -71
  85. package/lib/model/questions.ts +0 -93
  86. package/lib/model/scrutins.d.ts +0 -13
  87. package/lib/model/scrutins.js +0 -114
  88. package/lib/model/seance.d.ts +0 -3
  89. package/lib/model/seance.js +0 -267
  90. package/lib/model/sens.d.ts +0 -146
  91. package/lib/model/sens.js +0 -454
  92. package/lib/model/sens.mjs +0 -415
  93. package/lib/model/sens.ts +0 -516
  94. package/lib/model/texte.d.ts +0 -7
  95. package/lib/model/texte.js +0 -256
  96. package/lib/model/texte.mjs +0 -208
  97. package/lib/model/texte.ts +0 -229
  98. package/lib/model/util.d.ts +0 -9
  99. package/lib/model/util.js +0 -38
  100. package/lib/model/util.mjs +0 -19
  101. package/lib/model/util.ts +0 -32
  102. package/lib/parsers/texte.d.ts +0 -7
  103. package/lib/parsers/texte.js +0 -228
  104. package/lib/raw_types/ameli.d.ts +0 -914
  105. package/lib/raw_types/ameli.js +0 -5
  106. package/lib/raw_types/ameli.mjs +0 -163
  107. package/lib/raw_types/debats.d.ts +0 -207
  108. package/lib/raw_types/debats.js +0 -5
  109. package/lib/raw_types/debats.mjs +0 -58
  110. package/lib/raw_types/dosleg.d.ts +0 -1619
  111. package/lib/raw_types/dosleg.js +0 -5
  112. package/lib/raw_types/dosleg.mjs +0 -438
  113. package/lib/raw_types/questions.d.ts +0 -419
  114. package/lib/raw_types/questions.js +0 -5
  115. package/lib/raw_types/questions.mjs +0 -11
  116. package/lib/raw_types/senat.d.ts +0 -11368
  117. package/lib/raw_types/senat.js +0 -5
  118. package/lib/raw_types/sens.d.ts +0 -8248
  119. package/lib/raw_types/sens.js +0 -5
  120. package/lib/raw_types/sens.mjs +0 -508
  121. package/lib/raw_types_kysely/ameli.d.ts +0 -915
  122. package/lib/raw_types_kysely/ameli.js +0 -7
  123. package/lib/raw_types_kysely/ameli.mjs +0 -5
  124. package/lib/raw_types_kysely/ameli.ts +0 -951
  125. package/lib/raw_types_kysely/debats.d.ts +0 -207
  126. package/lib/raw_types_kysely/debats.js +0 -7
  127. package/lib/raw_types_kysely/debats.mjs +0 -5
  128. package/lib/raw_types_kysely/debats.ts +0 -222
  129. package/lib/raw_types_kysely/dosleg.d.ts +0 -3532
  130. package/lib/raw_types_kysely/dosleg.js +0 -7
  131. package/lib/raw_types_kysely/dosleg.mjs +0 -5
  132. package/lib/raw_types_kysely/dosleg.ts +0 -3621
  133. package/lib/raw_types_kysely/questions.d.ts +0 -414
  134. package/lib/raw_types_kysely/questions.js +0 -7
  135. package/lib/raw_types_kysely/questions.mjs +0 -5
  136. package/lib/raw_types_kysely/questions.ts +0 -426
  137. package/lib/raw_types_kysely/sens.d.ts +0 -4394
  138. package/lib/raw_types_kysely/sens.js +0 -7
  139. package/lib/raw_types_kysely/sens.mjs +0 -5
  140. package/lib/raw_types_kysely/sens.ts +0 -4499
  141. package/lib/raw_types_schemats/ameli.d.ts +0 -539
  142. package/lib/raw_types_schemats/ameli.js +0 -2
  143. package/lib/raw_types_schemats/ameli.mjs +0 -2
  144. package/lib/raw_types_schemats/ameli.ts +0 -601
  145. package/lib/raw_types_schemats/debats.d.ts +0 -127
  146. package/lib/raw_types_schemats/debats.js +0 -2
  147. package/lib/raw_types_schemats/debats.mjs +0 -2
  148. package/lib/raw_types_schemats/debats.ts +0 -145
  149. package/lib/raw_types_schemats/dosleg.d.ts +0 -977
  150. package/lib/raw_types_schemats/dosleg.js +0 -2
  151. package/lib/raw_types_schemats/dosleg.mjs +0 -2
  152. package/lib/raw_types_schemats/dosleg.ts +0 -2193
  153. package/lib/raw_types_schemats/questions.d.ts +0 -235
  154. package/lib/raw_types_schemats/questions.js +0 -2
  155. package/lib/raw_types_schemats/questions.mjs +0 -2
  156. package/lib/raw_types_schemats/questions.ts +0 -249
  157. package/lib/raw_types_schemats/sens.d.ts +0 -6915
  158. package/lib/raw_types_schemats/sens.js +0 -2
  159. package/lib/raw_types_schemats/sens.mjs +0 -2
  160. package/lib/raw_types_schemats/sens.ts +0 -2907
  161. package/lib/scripts/convert_data.d.ts +0 -1
  162. package/lib/scripts/convert_data.js +0 -354
  163. package/lib/scripts/convert_data.mjs +0 -181
  164. package/lib/scripts/convert_data.ts +0 -243
  165. package/lib/scripts/data-download.d.ts +0 -1
  166. package/lib/scripts/data-download.js +0 -12
  167. package/lib/scripts/datautil.d.ts +0 -8
  168. package/lib/scripts/datautil.js +0 -34
  169. package/lib/scripts/datautil.mjs +0 -16
  170. package/lib/scripts/datautil.ts +0 -19
  171. package/lib/scripts/images/transparent_150x192.jpg +0 -0
  172. package/lib/scripts/images/transparent_155x225.jpg +0 -0
  173. package/lib/scripts/parse_textes.d.ts +0 -1
  174. package/lib/scripts/parse_textes.js +0 -44
  175. package/lib/scripts/parse_textes.mjs +0 -46
  176. package/lib/scripts/parse_textes.ts +0 -65
  177. package/lib/scripts/retrieve_agenda.d.ts +0 -1
  178. package/lib/scripts/retrieve_agenda.js +0 -132
  179. package/lib/scripts/retrieve_cr_commission.d.ts +0 -1
  180. package/lib/scripts/retrieve_cr_commission.js +0 -364
  181. package/lib/scripts/retrieve_cr_seance.d.ts +0 -6
  182. package/lib/scripts/retrieve_cr_seance.js +0 -347
  183. package/lib/scripts/retrieve_documents.d.ts +0 -3
  184. package/lib/scripts/retrieve_documents.js +0 -219
  185. package/lib/scripts/retrieve_documents.mjs +0 -249
  186. package/lib/scripts/retrieve_documents.ts +0 -298
  187. package/lib/scripts/retrieve_open_data.d.ts +0 -1
  188. package/lib/scripts/retrieve_open_data.js +0 -315
  189. package/lib/scripts/retrieve_open_data.mjs +0 -217
  190. package/lib/scripts/retrieve_open_data.ts +0 -268
  191. package/lib/scripts/retrieve_senateurs_photos.d.ts +0 -1
  192. package/lib/scripts/retrieve_senateurs_photos.js +0 -147
  193. package/lib/scripts/retrieve_senateurs_photos.mjs +0 -147
  194. package/lib/scripts/retrieve_senateurs_photos.ts +0 -177
  195. package/lib/scripts/retrieve_videos.d.ts +0 -1
  196. package/lib/scripts/retrieve_videos.js +0 -461
  197. package/lib/scripts/shared/cli_helpers.d.ts +0 -95
  198. package/lib/scripts/shared/cli_helpers.js +0 -91
  199. package/lib/scripts/shared/cli_helpers.ts +0 -36
  200. package/lib/scripts/shared/util.d.ts +0 -4
  201. package/lib/scripts/shared/util.js +0 -35
  202. package/lib/scripts/shared/util.ts +0 -33
  203. package/lib/scripts/test_iter_load.d.ts +0 -1
  204. package/lib/scripts/test_iter_load.js +0 -12
  205. package/lib/src/ameli.d.ts +0 -66
  206. package/lib/src/ameli.js +0 -1
  207. package/lib/src/databases.d.ts +0 -3
  208. package/lib/src/databases.js +0 -26
  209. package/lib/src/db_types/ameli.d.ts +0 -1762
  210. package/lib/src/db_types/ameli.js +0 -1074
  211. package/lib/src/db_types/debats.d.ts +0 -380
  212. package/lib/src/db_types/debats.js +0 -266
  213. package/lib/src/db_types/dosleg.d.ts +0 -2954
  214. package/lib/src/db_types/dosleg.js +0 -2005
  215. package/lib/src/db_types/questions.d.ts +0 -699
  216. package/lib/src/db_types/questions.js +0 -493
  217. package/lib/src/db_types/sens.d.ts +0 -7843
  218. package/lib/src/db_types/sens.js +0 -4691
  219. package/lib/src/debats.d.ts +0 -38
  220. package/lib/src/debats.js +0 -1
  221. package/lib/src/dosleg.d.ts +0 -142
  222. package/lib/src/dosleg.js +0 -193
  223. package/lib/src/model/ameli_postgres.d.ts +0 -67
  224. package/lib/src/model/ameli_postgres.js +0 -150
  225. package/lib/src/other_types/questions.d.ts +0 -2
  226. package/lib/src/other_types/questions.js +0 -1
  227. package/lib/src/questions.d.ts +0 -53
  228. package/lib/src/questions.js +0 -1
  229. package/lib/src/raw_types/senat.d.ts +0 -11372
  230. package/lib/src/raw_types/senat.js +0 -5
  231. package/lib/src/rich_types/agenda.d.ts +0 -45
  232. package/lib/src/rich_types/agenda.js +0 -1
  233. package/lib/src/rich_types/compte_rendu.d.ts +0 -83
  234. package/lib/src/rich_types/compte_rendu.js +0 -1
  235. package/lib/src/rich_types/sessions.d.ts +0 -6
  236. package/lib/src/rich_types/sessions.js +0 -19
  237. package/lib/src/rich_types/texte.d.ts +0 -72
  238. package/lib/src/rich_types/texte.js +0 -15
  239. package/lib/src/scripts/test_iter_load.d.ts +0 -1
  240. package/lib/src/scripts/test_iter_load.js +0 -12
  241. package/lib/src/sens.d.ts +0 -104
  242. package/lib/src/sens.js +0 -1
  243. package/lib/strings.d.ts +0 -1
  244. package/lib/strings.js +0 -18
  245. package/lib/strings.mjs +0 -18
  246. package/lib/strings.ts +0 -26
  247. package/lib/tsconfig.tsbuildinfo +0 -1
  248. package/lib/types/agenda.d.ts +0 -44
  249. package/lib/types/agenda.js +0 -1
  250. package/lib/types/ameli.d.ts +0 -5
  251. package/lib/types/ameli.js +0 -1
  252. package/lib/types/ameli.mjs +0 -13
  253. package/lib/types/ameli.ts +0 -21
  254. package/lib/types/compte_rendu.d.ts +0 -83
  255. package/lib/types/compte_rendu.js +0 -1
  256. package/lib/types/debats.d.ts +0 -2
  257. package/lib/types/debats.js +0 -1
  258. package/lib/types/debats.mjs +0 -2
  259. package/lib/types/debats.ts +0 -6
  260. package/lib/types/dosleg.d.ts +0 -70
  261. package/lib/types/dosleg.js +0 -1
  262. package/lib/types/dosleg.mjs +0 -151
  263. package/lib/types/dosleg.ts +0 -284
  264. package/lib/types/questions.d.ts +0 -2
  265. package/lib/types/questions.js +0 -1
  266. package/lib/types/questions.mjs +0 -1
  267. package/lib/types/questions.ts +0 -3
  268. package/lib/types/sens.d.ts +0 -10
  269. package/lib/types/sens.js +0 -1
  270. package/lib/types/sens.mjs +0 -1
  271. package/lib/types/sens.ts +0 -12
  272. package/lib/types/sessions.d.ts +0 -5
  273. package/lib/types/sessions.js +0 -84
  274. package/lib/types/sessions.mjs +0 -43
  275. package/lib/types/sessions.ts +0 -42
  276. package/lib/types/texte.d.ts +0 -74
  277. package/lib/types/texte.js +0 -16
  278. package/lib/types/texte.mjs +0 -16
  279. package/lib/types/texte.ts +0 -76
  280. package/lib/typings/windows-1252.d.js +0 -2
  281. package/lib/typings/windows-1252.d.mjs +0 -2
  282. package/lib/typings/windows-1252.d.ts +0 -11
  283. package/lib/utils/cr_spliting.d.ts +0 -28
  284. package/lib/utils/cr_spliting.js +0 -265
  285. package/lib/utils/date.d.ts +0 -10
  286. package/lib/utils/date.js +0 -100
  287. package/lib/utils/nvs-timecode.d.ts +0 -7
  288. package/lib/utils/nvs-timecode.js +0 -79
  289. package/lib/utils/reunion_grouping.d.ts +0 -9
  290. package/lib/utils/reunion_grouping.js +0 -361
  291. package/lib/utils/reunion_odj_building.d.ts +0 -5
  292. package/lib/utils/reunion_odj_building.js +0 -154
  293. package/lib/utils/reunion_parsing.d.ts +0 -23
  294. package/lib/utils/reunion_parsing.js +0 -209
  295. package/lib/utils/scoring.d.ts +0 -14
  296. package/lib/utils/scoring.js +0 -147
  297. package/lib/utils/string_cleaning.d.ts +0 -7
  298. package/lib/utils/string_cleaning.js +0 -57
  299. package/lib/validators/config.d.ts +0 -9
  300. package/lib/validators/config.js +0 -10
  301. package/lib/validators/config.mjs +0 -54
  302. package/lib/validators/config.ts +0 -79
  303. package/lib/validators/senat.d.ts +0 -0
  304. package/lib/validators/senat.js +0 -28
  305. package/lib/validators/senat.mjs +0 -24
  306. package/lib/validators/senat.ts +0 -26
@@ -1,196 +0,0 @@
1
- import { sql } from "kysely";
2
- import { jsonArrayFrom } from "kysely/helpers/postgres";
3
- import { dbDosleg } from "../databases";
4
- import { concat, removeSubstring, rtrim, toDateString } from "./util";
5
- function orderOrdreOrigineTexte(expr) {
6
- return sql `array_position(array['0','2','1'], ${expr})`;
7
- }
8
- function datesSeances(lectureAssembleeId) {
9
- return jsonArrayFrom(dbDosleg.selectFrom("date_seance")
10
- .where("date_seance.lecidt", "=", lectureAssembleeId)
11
- .select(({ ref }) => [
12
- toDateString(ref("date_seance.date_s")).as("date"),
13
- ]));
14
- }
15
- function organismesRapport(rapportId) {
16
- return jsonArrayFrom(dbDosleg.selectFrom("org")
17
- .leftJoin("raporg", "raporg.orgcod", "org.orgcod")
18
- .where("raporg.rapcod", "=", rapportId)
19
- .select([
20
- "org.orgnom as libelle",
21
- ]));
22
- }
23
- function auteursRapport(rapportId) {
24
- return jsonArrayFrom(dbDosleg.selectFrom("auteur")
25
- .leftJoin("ecr", "ecr.autcod", "auteur.autcod")
26
- .where("ecr.rapcod", "=", rapportId)
27
- .select([
28
- "auteur.prenom as prenom",
29
- "auteur.nomuse as nom_usuel",
30
- "auteur.autmat as matricule",
31
- ])
32
- .orderBy("ecr.ecrnumtri", "asc"));
33
- }
34
- function rapports(lectureAssembleeId) {
35
- return jsonArrayFrom(dbDosleg.selectFrom("rap")
36
- .leftJoin("lecassrap", "lecassrap.rapcod", "rap.rapcod")
37
- .leftJoin("denrap", "denrap.coddenrap", "rap.coddenrap")
38
- .where("lecassrap.lecassidt", "=", lectureAssembleeId)
39
- .select(({ eb, ref, val }) => [
40
- "rap.rapnum as numero",
41
- rtrim(ref("denrap.libdenrap")).as("type_rapport"),
42
- eb.case()
43
- .when("rap.typurl", "=", "I")
44
- .then(concat(val("https://www.senat.fr/rap/"), rtrim(ref("rap.rapurl"))))
45
- .else(rtrim(ref("rap.rapurl")))
46
- .end()
47
- .as("url"),
48
- toDateString(ref("rap.date_depot")).as("date_depot"),
49
- auteursRapport(ref("rap.rapcod")).as("auteurs"),
50
- organismesRapport(ref("rap.rapcod")).as("organismes"),
51
- ]));
52
- }
53
- function auteursTexte(texteId) {
54
- return jsonArrayFrom(dbDosleg.selectFrom("auteur")
55
- .leftJoin("ecr", "ecr.autcod", "auteur.autcod")
56
- .where("ecr.texcod", "=", texteId)
57
- .select([
58
- "auteur.prenom as prenom",
59
- "auteur.nomuse as nom_usuel",
60
- "auteur.autmat as matricule",
61
- ])
62
- .orderBy("ecr.ecrnumtri", "asc"));
63
- }
64
- function textes(lectureAssembleeId) {
65
- return jsonArrayFrom(dbDosleg.selectFrom("texte")
66
- .leftJoin("oritxt", "oritxt.oritxtcod", "texte.oritxtcod")
67
- .leftJoin("typtxt", "typtxt.typtxtcod", "texte.typtxtcod")
68
- .where("texte.lecassidt", "=", lectureAssembleeId)
69
- .select(({ eb, ref, val }) => [
70
- "texte.texnum as numero",
71
- eb.case()
72
- .when("texte.typurl", "=", "I")
73
- .then(removeSubstring(ref("texte.texurl"), val(".html")))
74
- .else(null)
75
- .end()
76
- .as("id"),
77
- eb.case()
78
- .when("texte.typurl", "=", "I")
79
- .then(concat(val("https://www.senat.fr/leg/"), rtrim(ref("texte.texurl"))))
80
- .else(rtrim(ref("texte.texurl")))
81
- .end()
82
- .as("url"),
83
- rtrim(ref("oritxt.oritxtlib")).as("origine_texte"),
84
- rtrim(ref("typtxt.typtxtlib")).as("type_texte"),
85
- toDateString(ref("texte.txtoritxtdat")).as("date"),
86
- "sesann as session",
87
- auteursTexte(ref("texte.texcod")).as("auteurs"),
88
- ])
89
- .orderBy(({ ref }) => orderOrdreOrigineTexte(ref("oritxt.oriordre"))));
90
- }
91
- function lecturesAssemblee(lectureId) {
92
- return jsonArrayFrom(dbDosleg.selectFrom("lecass")
93
- .where("lecass.lecidt", "=", lectureId)
94
- .leftJoin("ass", "ass.codass", "lecass.codass")
95
- .leftJoin("org", "org.orgcod", "lecass.orgcod")
96
- .select(({ ref }) => [
97
- rtrim(ref("ass.libass")).as("assemblee"),
98
- "org.orgnom as libelle_organisme",
99
- "org.orgcod as code_organisme",
100
- "lecass.ordreass as ordre_lecture_assemblee",
101
- textes(ref("lecass.lecassidt")).as("textes"),
102
- rapports(ref("lecass.lecassidt")).as("rapports"),
103
- datesSeances(ref("lecass.lecassidt")).as("dates_seances"),
104
- ])
105
- .orderBy("lecass.ordreass", "asc"));
106
- }
107
- function lectures(loiId) {
108
- return jsonArrayFrom(dbDosleg.selectFrom("lecture")
109
- .leftJoin("typlec", "typlec.typleccod", "lecture.typleccod")
110
- .where("lecture.loicod", "=", loiId)
111
- .select(({ ref }) => [
112
- rtrim(ref("typlec.typleclib")).as("type_lecture"),
113
- rtrim(ref("lecture.leccom")).as("libelle"),
114
- "typlec.typlecord as ordre_lecture",
115
- lecturesAssemblee(ref("lecture.lecidt")).as("lectures_assemblee"),
116
- ])
117
- .orderBy("typlec.typlecord", "asc"));
118
- }
119
- function themes(loiId) {
120
- return jsonArrayFrom(dbDosleg.selectFrom("the")
121
- .leftJoin("loithe", "loithe.thecle", "the.thecle")
122
- .where("loithe.loicod", "=", loiId)
123
- .select([
124
- "the.thelib as libelle",
125
- ]));
126
- }
127
- const findAllQuery = dbDosleg
128
- .selectFrom("loi")
129
- .leftJoin("typloi", "typloi.typloicod", "loi.typloicod")
130
- .leftJoin("etaloi", "etaloi.etaloicod", "loi.etaloicod")
131
- .select(({ eb, ref, val }) => [
132
- "loi.signet as signet",
133
- concat(val("https://www.senat.fr/dossier-legislatif/"), ref("loi.signet"), val(".html")).as("url"),
134
- concat(rtrim(ref("typloi.typloiden")), val(" "), rtrim(ref("loi.loitit"))).as("titre"),
135
- rtrim(ref("loi.loient")).as("titre_court"),
136
- rtrim(ref("typloi.groupe")).as("code_nature_dossier"),
137
- rtrim(ref("typloi.typloilib")).as("libelle_type_dossier"),
138
- rtrim(ref("etaloi.etaloilib")).as("etat_dossier"),
139
- "loi.url_an as url_dossier_assemblee_nationale",
140
- toDateString(ref("loi.date_decision")).as("date_decision_CoC"),
141
- "loi.num_decision as num_decision_CoC",
142
- "loi.deccocurl as url_decision_CoC",
143
- toDateString(ref("loi.saisine_date")).as("date_saisine_CoC"),
144
- "loi.saisine_par as condition_saisine_CoC",
145
- toDateString(ref("loi.date_loi")).as("date_promulgation"),
146
- "loi.numero as numero_loi",
147
- eb.case()
148
- .when("loi.loititjo", "is not", null)
149
- .then(concat(rtrim(ref("typloi.typloiden")), val(" "), rtrim(ref("loi.loititjo"))))
150
- .else("")
151
- .end()
152
- .as("titre_JO"),
153
- toDateString(ref("loi.loidatjo")).as("date_publication_JO"),
154
- "loi.loinumjo as numero_JO",
155
- "loi.url_jo as url_JO",
156
- lectures(ref("loi.loicod")).as("lectures"),
157
- themes(ref("loi.loicod")).as("themes"),
158
- ])
159
- .$narrowType();
160
- export function findAll() {
161
- return findAllQuery.stream();
162
- }
163
- export function findSenatTexteUrls(sessions = []) {
164
- return dbDosleg
165
- .selectFrom("texte")
166
- .where("texurl", "is not", null)
167
- .where("typurl", "=", "I")
168
- .$if(sessions.length > 0, (qb) => qb
169
- .where("sesann", "in", sessions))
170
- .select(({ eb, ref }) => [
171
- "sesann as session",
172
- rtrim(ref("texurl")).as("url"),
173
- eb.case()
174
- .when("oritxtcod", "=", "1")
175
- .then(true)
176
- .else(false)
177
- .end()
178
- .as("hasExposeDesMotifs"),
179
- ])
180
- .$narrowType()
181
- .stream();
182
- }
183
- export function findSenatRapportUrls(sessions = []) {
184
- return dbDosleg
185
- .selectFrom("rap")
186
- .where("rapurl", "is not", null)
187
- .where("typurl", "=", "I")
188
- .$if(sessions.length > 0, (qb) => qb
189
- .where("sesann", "in", sessions))
190
- .select(({ ref }) => [
191
- rtrim(ref("rapurl")).as("url"),
192
- "sesann as session",
193
- ])
194
- .$narrowType()
195
- .stream();
196
- }
@@ -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,7 +0,0 @@
1
- export { findAllAmendements } from "./ameli";
2
- export { findAll as findAllDebats } from "./debats";
3
- export { findAllDossiers } from "./dosleg";
4
- export { findAllTextes, findAllRapports } from "./documents";
5
- export { findAllScrutins } from "./scrutins";
6
- export { findAll as findAllQuestions } from "./questions";
7
- export { findAll as findAllSens, findAllCirconscriptions, findAllOrganismes } from "./sens";
@@ -1,7 +0,0 @@
1
- export { findAllAmendements } from "./ameli";
2
- export { findAll as findAllDebats } from "./debats";
3
- export { findAllDossiers } from "./dosleg";
4
- export { findAllTextes, findAllRapports } from "./documents";
5
- export { findAllScrutins } from "./scrutins";
6
- export { findAll as findAllQuestions } from "./questions";
7
- export { findAll as findAllSens, findAllCirconscriptions, findAllOrganismes } from "./sens";
@@ -1,5 +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";
5
- export { allFollows, Aggregator } from "../aggregates";
@@ -1,15 +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"
15
- export { allFollows, Aggregator } from "../aggregates"
@@ -1,45 +0,0 @@
1
- import { InferResult } from "kysely";
2
- export type QuestionResult = InferResult<typeof findAllQuery>[0];
3
- declare const findAllQuery: import("kysely").SelectQueryBuilder<{
4
- [x: string]: any;
5
- [x: number]: any;
6
- [x: symbol]: any;
7
- }, "tam_questions" | "sortquestion" | "etatquestion" | "tam_ministeres" | "naturequestion", {
8
- [x: string]: any;
9
- date_publication_JO: string;
10
- ministere_depot: string;
11
- ministere_depot_date_debut: string;
12
- date_transmission: string;
13
- date_reponse_JO: string;
14
- date_erratum_JO: string;
15
- date_cloture: string;
16
- date_signalement: string;
17
- themes: {
18
- libelle: any;
19
- }[];
20
- reponses: {
21
- [x: string]: any;
22
- date_reponse_JO: string;
23
- date_erratum_JO: string;
24
- }[];
25
- }>;
26
- export declare function findAll(): AsyncIterableIterator<{
27
- [x: string]: any;
28
- date_publication_JO: string;
29
- ministere_depot: string;
30
- ministere_depot_date_debut: string;
31
- date_transmission: string;
32
- date_reponse_JO: string;
33
- date_erratum_JO: string;
34
- date_cloture: string;
35
- date_signalement: string;
36
- themes: {
37
- libelle: any;
38
- }[];
39
- reponses: {
40
- [x: string]: any;
41
- date_reponse_JO: string;
42
- date_erratum_JO: string;
43
- }[];
44
- }>;
45
- export {};
@@ -1,89 +0,0 @@
1
- import { jsonArrayFrom } from "kysely/helpers/postgres";
2
- import { dbSenat } from "../databases";
3
- import { expandToRows, rtrim, toDateString } from "./util";
4
- function reponses(questionId) {
5
- return jsonArrayFrom(dbSenat
6
- .withSchema("questions")
7
- .selectFrom("tam_reponses")
8
- .where("tam_reponses.idque", "=", questionId)
9
- .select(({ ref }) => [
10
- toDateString(ref("tam_reponses.datejorep")).as("date_reponse_JO"),
11
- "tam_reponses.pagejorep as page_JO",
12
- toDateString(ref("tam_reponses.errdate")).as("date_erratum_JO"),
13
- "tam_reponses.minreplib as ministere_reponse",
14
- "tam_reponses.minrepid as ministere_reponse_id",
15
- "tam_reponses.urlrep as url",
16
- "tam_reponses.txtrep as texte",
17
- "tam_reponses.txterrrep as texte_erratum",
18
- ])
19
- .orderBy("tam_reponses.datejorep", "asc"));
20
- }
21
- function themes(questionId) {
22
- return jsonArrayFrom(dbSenat
23
- .withSchema("questions")
24
- .with("question_theme", (db) => db
25
- .selectFrom("tam_questions")
26
- .select(({ eb, ref, val }) => [
27
- "id as question_id",
28
- eb.cast(expandToRows(ref("tam_questions.themes"), val("#(\\d+)")), "smallint").as("theme_id"),
29
- ]))
30
- .selectFrom("the")
31
- .leftJoin("question_theme", "the.thenouidt", "question_theme.theme_id")
32
- .where("question_theme.question_id", "=", questionId)
33
- .select("the.thelib as libelle")
34
- .orderBy("the.thenouidt", "asc"));
35
- }
36
- const findAllQuery = dbSenat
37
- .withSchema("questions")
38
- .selectFrom("tam_questions")
39
- .leftJoin("tam_ministeres", "tam_questions.mindepotid", "tam_ministeres.minid")
40
- .leftJoin("sortquestion", (join) => join.onRef("tam_questions.sorquecod", "=", (eb) => eb.cast("sortquestion.sorquecod", "bigint")))
41
- .leftJoin("naturequestion", "tam_questions.natquecod", "naturequestion.natquecod")
42
- .leftJoin("etatquestion", (join) => join.onRef("tam_questions.etaquecod", "=", (eb) => eb.cast("etatquestion.etaquecod", "bigint")))
43
- .select(({ ref }) => [
44
- "tam_questions.repub as republique",
45
- "tam_questions.legislature as legislature",
46
- "tam_questions.natquecod as nature",
47
- "naturequestion.natquelib as nature_libelle",
48
- "tam_questions.numero as numero",
49
- "tam_questions.reference as reference",
50
- "tam_questions.titre as titre",
51
- "tam_questions.nom as nom",
52
- "tam_questions.prenom as prenom",
53
- "tam_questions.nomtechnique as nom_technique",
54
- "tam_questions.codequalite as civilite",
55
- "tam_questions.matricule as matricule",
56
- "tam_questions.cirnum as circonscription_numero",
57
- "tam_questions.circonscription as circonscription",
58
- "tam_questions.groupe as groupe",
59
- "tam_questions.ratgrp as type_appartenance",
60
- toDateString(ref("tam_questions.datejodepot")).as("date_publication_JO"),
61
- "tam_questions.pagejodepot as page_JO",
62
- rtrim(ref("tam_questions.mindepotlib")).as("ministere_depot"),
63
- "tam_questions.mindepotid as ministere_depot_id",
64
- toDateString(ref("tam_ministeres.datedebut")).as("ministere_depot_date_debut"),
65
- toDateString(ref("tam_questions.datejotran")).as("date_transmission"),
66
- "tam_questions.mintranlib as ministere_transmission",
67
- toDateString(ref("tam_questions.datejorep1")).as("date_reponse_JO"),
68
- toDateString(ref("tam_questions.dateerr")).as("date_erratum_JO"),
69
- "tam_questions.pageerr as page_erratum_JO",
70
- "tam_questions.minreplib1 as ministere_reponse",
71
- toDateString(ref("tam_questions.datecloture")).as("date_cloture"),
72
- toDateString(ref("tam_questions.datesignal")).as("date_signalement"),
73
- "tam_questions.refquerappelee as reference_question_rappelee",
74
- //"tam_questions.url as url", // TODO ?
75
- "tam_questions.txtque as texte",
76
- "tam_questions.txterrque as texte_erratum",
77
- "tam_questions.rubrique as rubrique",
78
- "sortquestion.sorquelib as sort",
79
- "sortquestion.sorquecod as sort_code",
80
- "sortquestion.sorquenumtri as sort_tri",
81
- "etatquestion.etaquelib as etat_libelle",
82
- "etatquestion.etaquecod as etat_code",
83
- "etatquestion.etaquenumtri as etat_tri",
84
- themes(ref("tam_questions.id")).as("themes"),
85
- reponses(ref("tam_questions.id")).as("reponses"),
86
- ]);
87
- export function findAll() {
88
- return findAllQuery.stream();
89
- }