@tricoteuses/senat 2.22.5 → 2.22.7

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 (146) hide show
  1. package/lib/config.d.ts +12 -1
  2. package/lib/config.js +12 -1
  3. package/lib/loaders.js +1 -1
  4. package/lib/model/ameli.js +1 -3
  5. package/lib/model/documents.js +5 -18
  6. package/lib/model/dosleg.js +11 -11
  7. package/lib/model/texte.js +15 -43
  8. package/lib/raw_types/questions.d.ts +4 -0
  9. package/lib/raw_types/senat.d.ts +4 -0
  10. package/lib/raw_types_schemats/ameli.d.ts +1 -1
  11. package/lib/raw_types_schemats/debats.d.ts +1 -1
  12. package/lib/raw_types_schemats/dosleg.d.ts +1 -1
  13. package/lib/raw_types_schemats/questions.d.ts +3 -1
  14. package/lib/raw_types_schemats/sens.d.ts +1 -1
  15. package/lib/scripts/convert_data.js +3 -3
  16. package/lib/scripts/parse_textes.js +2 -2
  17. package/lib/scripts/retrieve_open_data.js +1 -0
  18. package/lib/scripts/test_iter_load.js +1 -1
  19. package/lib/src/model/ameli.d.ts +4 -0
  20. package/lib/src/model/ameli.js +3 -3
  21. package/lib/src/scripts/retrieve_videos.js +1 -0
  22. package/lib/src/types/agenda.d.ts +1 -0
  23. package/lib/src/utils/nvs-timecode.d.ts +17 -0
  24. package/lib/src/utils/nvs-timecode.js +79 -0
  25. package/lib/src/utils/weights_scoring_config.d.ts +2 -0
  26. package/lib/src/utils/weights_scoring_config.js +15 -0
  27. package/lib/src/videos/pipeline.d.ts +2 -0
  28. package/lib/src/videos/pipeline.js +3 -2
  29. package/lib/utils/reunion_grouping.d.ts +4 -2
  30. package/lib/utils/reunion_grouping.js +6 -30
  31. package/package.json +1 -1
  32. package/lib/aggregates.d.ts +0 -52
  33. package/lib/aggregates.js +0 -930
  34. package/lib/aggregates.mjs +0 -713
  35. package/lib/aggregates.ts +0 -833
  36. package/lib/config.mjs +0 -16
  37. package/lib/config.ts +0 -26
  38. package/lib/databases.mjs +0 -57
  39. package/lib/databases.ts +0 -71
  40. package/lib/datasets.mjs +0 -78
  41. package/lib/datasets.ts +0 -118
  42. package/lib/fields.d.ts +0 -10
  43. package/lib/fields.js +0 -68
  44. package/lib/fields.mjs +0 -22
  45. package/lib/fields.ts +0 -29
  46. package/lib/index.mjs +0 -7
  47. package/lib/index.ts +0 -64
  48. package/lib/inserters.d.ts +0 -98
  49. package/lib/inserters.js +0 -500
  50. package/lib/inserters.mjs +0 -360
  51. package/lib/inserters.ts +0 -521
  52. package/lib/legislatures.json +0 -38
  53. package/lib/loaders.mjs +0 -158
  54. package/lib/loaders.ts +0 -271
  55. package/lib/model/ameli.mjs +0 -84
  56. package/lib/model/ameli.ts +0 -100
  57. package/lib/model/debats.mjs +0 -43
  58. package/lib/model/debats.ts +0 -68
  59. package/lib/model/dosleg.mjs +0 -196
  60. package/lib/model/dosleg.ts +0 -240
  61. package/lib/model/index.mjs +0 -5
  62. package/lib/model/index.ts +0 -15
  63. package/lib/model/questions.mjs +0 -71
  64. package/lib/model/questions.ts +0 -93
  65. package/lib/model/sens.mjs +0 -415
  66. package/lib/model/sens.ts +0 -516
  67. package/lib/model/texte.mjs +0 -208
  68. package/lib/model/texte.ts +0 -229
  69. package/lib/model/util.mjs +0 -19
  70. package/lib/model/util.ts +0 -32
  71. package/lib/raw_types/ameli.mjs +0 -163
  72. package/lib/raw_types/debats.mjs +0 -58
  73. package/lib/raw_types/dosleg.mjs +0 -438
  74. package/lib/raw_types/questions.mjs +0 -11
  75. package/lib/raw_types/sens.mjs +0 -508
  76. package/lib/raw_types_kysely/ameli.d.ts +0 -915
  77. package/lib/raw_types_kysely/ameli.js +0 -7
  78. package/lib/raw_types_kysely/ameli.mjs +0 -5
  79. package/lib/raw_types_kysely/ameli.ts +0 -951
  80. package/lib/raw_types_kysely/debats.d.ts +0 -207
  81. package/lib/raw_types_kysely/debats.js +0 -7
  82. package/lib/raw_types_kysely/debats.mjs +0 -5
  83. package/lib/raw_types_kysely/debats.ts +0 -222
  84. package/lib/raw_types_kysely/dosleg.d.ts +0 -3532
  85. package/lib/raw_types_kysely/dosleg.js +0 -7
  86. package/lib/raw_types_kysely/dosleg.mjs +0 -5
  87. package/lib/raw_types_kysely/dosleg.ts +0 -3621
  88. package/lib/raw_types_kysely/questions.d.ts +0 -414
  89. package/lib/raw_types_kysely/questions.js +0 -7
  90. package/lib/raw_types_kysely/questions.mjs +0 -5
  91. package/lib/raw_types_kysely/questions.ts +0 -426
  92. package/lib/raw_types_kysely/sens.d.ts +0 -4394
  93. package/lib/raw_types_kysely/sens.js +0 -7
  94. package/lib/raw_types_kysely/sens.mjs +0 -5
  95. package/lib/raw_types_kysely/sens.ts +0 -4499
  96. package/lib/raw_types_schemats/ameli.mjs +0 -2
  97. package/lib/raw_types_schemats/ameli.ts +0 -601
  98. package/lib/raw_types_schemats/debats.mjs +0 -2
  99. package/lib/raw_types_schemats/debats.ts +0 -145
  100. package/lib/raw_types_schemats/dosleg.mjs +0 -2
  101. package/lib/raw_types_schemats/dosleg.ts +0 -2193
  102. package/lib/raw_types_schemats/questions.mjs +0 -2
  103. package/lib/raw_types_schemats/questions.ts +0 -249
  104. package/lib/raw_types_schemats/sens.mjs +0 -2
  105. package/lib/raw_types_schemats/sens.ts +0 -2907
  106. package/lib/scripts/convert_data.mjs +0 -181
  107. package/lib/scripts/convert_data.ts +0 -243
  108. package/lib/scripts/datautil.mjs +0 -16
  109. package/lib/scripts/datautil.ts +0 -19
  110. package/lib/scripts/images/transparent_150x192.jpg +0 -0
  111. package/lib/scripts/images/transparent_155x225.jpg +0 -0
  112. package/lib/scripts/parse_textes.mjs +0 -46
  113. package/lib/scripts/parse_textes.ts +0 -65
  114. package/lib/scripts/retrieve_documents.mjs +0 -249
  115. package/lib/scripts/retrieve_documents.ts +0 -298
  116. package/lib/scripts/retrieve_open_data.mjs +0 -217
  117. package/lib/scripts/retrieve_open_data.ts +0 -268
  118. package/lib/scripts/retrieve_senateurs_photos.mjs +0 -147
  119. package/lib/scripts/retrieve_senateurs_photos.ts +0 -177
  120. package/lib/scripts/shared/cli_helpers.ts +0 -36
  121. package/lib/scripts/shared/util.ts +0 -33
  122. package/lib/strings.mjs +0 -18
  123. package/lib/strings.ts +0 -26
  124. package/lib/types/ameli.mjs +0 -13
  125. package/lib/types/ameli.ts +0 -21
  126. package/lib/types/debats.mjs +0 -2
  127. package/lib/types/debats.ts +0 -6
  128. package/lib/types/dosleg.mjs +0 -151
  129. package/lib/types/dosleg.ts +0 -284
  130. package/lib/types/questions.mjs +0 -1
  131. package/lib/types/questions.ts +0 -3
  132. package/lib/types/sens.mjs +0 -1
  133. package/lib/types/sens.ts +0 -12
  134. package/lib/types/sessions.mjs +0 -43
  135. package/lib/types/sessions.ts +0 -42
  136. package/lib/types/texte.mjs +0 -16
  137. package/lib/types/texte.ts +0 -76
  138. package/lib/typings/windows-1252.d.js +0 -2
  139. package/lib/typings/windows-1252.d.mjs +0 -2
  140. package/lib/typings/windows-1252.d.ts +0 -11
  141. package/lib/validators/config.mjs +0 -54
  142. package/lib/validators/config.ts +0 -79
  143. package/lib/validators/senat.d.ts +0 -0
  144. package/lib/validators/senat.js +0 -28
  145. package/lib/validators/senat.mjs +0 -24
  146. 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,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,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
- }