@tricoteuses/senat 2.22.4 → 2.22.5
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.
- package/lib/aggregates.d.ts +52 -0
- package/lib/aggregates.js +930 -0
- package/lib/aggregates.mjs +713 -0
- package/lib/aggregates.ts +833 -0
- package/lib/config.d.ts +10 -0
- package/lib/config.js +16 -0
- package/lib/config.mjs +16 -0
- package/lib/config.ts +26 -0
- package/lib/databases.d.ts +2 -0
- package/lib/databases.js +26 -0
- package/lib/databases.mjs +57 -0
- package/lib/databases.ts +71 -0
- package/lib/datasets.d.ts +34 -0
- package/lib/datasets.js +233 -0
- package/lib/datasets.mjs +78 -0
- package/lib/datasets.ts +118 -0
- package/lib/fields.d.ts +10 -0
- package/lib/fields.js +68 -0
- package/lib/fields.mjs +22 -0
- package/lib/fields.ts +29 -0
- package/lib/git.d.ts +26 -0
- package/lib/git.js +167 -0
- package/lib/index.d.ts +13 -0
- package/lib/index.js +1 -0
- package/lib/index.mjs +7 -0
- package/lib/index.ts +64 -0
- package/lib/inserters.d.ts +98 -0
- package/lib/inserters.js +500 -0
- package/lib/inserters.mjs +360 -0
- package/lib/inserters.ts +521 -0
- package/lib/legislatures.json +38 -0
- package/lib/loaders.d.ts +58 -0
- package/lib/loaders.js +286 -0
- package/lib/loaders.mjs +158 -0
- package/lib/loaders.ts +271 -0
- package/lib/model/agenda.d.ts +6 -0
- package/lib/model/agenda.js +148 -0
- package/lib/model/ameli.d.ts +51 -0
- package/lib/model/ameli.js +149 -0
- package/lib/model/ameli.mjs +84 -0
- package/lib/model/ameli.ts +100 -0
- package/lib/model/commission.d.ts +18 -0
- package/lib/model/commission.js +269 -0
- package/lib/model/debats.d.ts +67 -0
- package/lib/model/debats.js +95 -0
- package/lib/model/debats.mjs +43 -0
- package/lib/model/debats.ts +68 -0
- package/lib/model/documents.d.ts +12 -0
- package/lib/model/documents.js +151 -0
- package/lib/model/dosleg.d.ts +7 -0
- package/lib/model/dosleg.js +326 -0
- package/lib/model/dosleg.mjs +196 -0
- package/lib/model/dosleg.ts +240 -0
- package/lib/model/index.d.ts +7 -0
- package/lib/model/index.js +7 -0
- package/lib/model/index.mjs +5 -0
- package/lib/model/index.ts +15 -0
- package/lib/model/questions.d.ts +45 -0
- package/lib/model/questions.js +89 -0
- package/lib/model/questions.mjs +71 -0
- package/lib/model/questions.ts +93 -0
- package/lib/model/scrutins.d.ts +13 -0
- package/lib/model/scrutins.js +114 -0
- package/lib/model/seance.d.ts +3 -0
- package/lib/model/seance.js +267 -0
- package/lib/model/sens.d.ts +146 -0
- package/lib/model/sens.js +454 -0
- package/lib/model/sens.mjs +415 -0
- package/lib/model/sens.ts +516 -0
- package/lib/model/texte.d.ts +7 -0
- package/lib/model/texte.js +256 -0
- package/lib/model/texte.mjs +208 -0
- package/lib/model/texte.ts +229 -0
- package/lib/model/util.d.ts +9 -0
- package/lib/model/util.js +38 -0
- package/lib/model/util.mjs +19 -0
- package/lib/model/util.ts +32 -0
- package/lib/parsers/texte.d.ts +7 -0
- package/lib/parsers/texte.js +228 -0
- package/lib/raw_types/ameli.d.ts +914 -0
- package/lib/raw_types/ameli.js +5 -0
- package/lib/raw_types/ameli.mjs +163 -0
- package/lib/raw_types/debats.d.ts +207 -0
- package/lib/raw_types/debats.js +5 -0
- package/lib/raw_types/debats.mjs +58 -0
- package/lib/raw_types/dosleg.d.ts +1619 -0
- package/lib/raw_types/dosleg.js +5 -0
- package/lib/raw_types/dosleg.mjs +438 -0
- package/lib/raw_types/questions.d.ts +419 -0
- package/lib/raw_types/questions.js +5 -0
- package/lib/raw_types/questions.mjs +11 -0
- package/lib/raw_types/senat.d.ts +11368 -0
- package/lib/raw_types/senat.js +5 -0
- package/lib/raw_types/sens.d.ts +8248 -0
- package/lib/raw_types/sens.js +5 -0
- package/lib/raw_types/sens.mjs +508 -0
- package/lib/raw_types_kysely/ameli.d.ts +915 -0
- package/lib/raw_types_kysely/ameli.js +7 -0
- package/lib/raw_types_kysely/ameli.mjs +5 -0
- package/lib/raw_types_kysely/ameli.ts +951 -0
- package/lib/raw_types_kysely/debats.d.ts +207 -0
- package/lib/raw_types_kysely/debats.js +7 -0
- package/lib/raw_types_kysely/debats.mjs +5 -0
- package/lib/raw_types_kysely/debats.ts +222 -0
- package/lib/raw_types_kysely/dosleg.d.ts +3532 -0
- package/lib/raw_types_kysely/dosleg.js +7 -0
- package/lib/raw_types_kysely/dosleg.mjs +5 -0
- package/lib/raw_types_kysely/dosleg.ts +3621 -0
- package/lib/raw_types_kysely/questions.d.ts +414 -0
- package/lib/raw_types_kysely/questions.js +7 -0
- package/lib/raw_types_kysely/questions.mjs +5 -0
- package/lib/raw_types_kysely/questions.ts +426 -0
- package/lib/raw_types_kysely/sens.d.ts +4394 -0
- package/lib/raw_types_kysely/sens.js +7 -0
- package/lib/raw_types_kysely/sens.mjs +5 -0
- package/lib/raw_types_kysely/sens.ts +4499 -0
- package/lib/raw_types_schemats/ameli.d.ts +539 -0
- package/lib/raw_types_schemats/ameli.js +2 -0
- package/lib/raw_types_schemats/ameli.mjs +2 -0
- package/lib/raw_types_schemats/ameli.ts +601 -0
- package/lib/raw_types_schemats/debats.d.ts +127 -0
- package/lib/raw_types_schemats/debats.js +2 -0
- package/lib/raw_types_schemats/debats.mjs +2 -0
- package/lib/raw_types_schemats/debats.ts +145 -0
- package/lib/raw_types_schemats/dosleg.d.ts +977 -0
- package/lib/raw_types_schemats/dosleg.js +2 -0
- package/lib/raw_types_schemats/dosleg.mjs +2 -0
- package/lib/raw_types_schemats/dosleg.ts +2193 -0
- package/lib/raw_types_schemats/questions.d.ts +235 -0
- package/lib/raw_types_schemats/questions.js +2 -0
- package/lib/raw_types_schemats/questions.mjs +2 -0
- package/lib/raw_types_schemats/questions.ts +249 -0
- package/lib/raw_types_schemats/sens.d.ts +6915 -0
- package/lib/raw_types_schemats/sens.js +2 -0
- package/lib/raw_types_schemats/sens.mjs +2 -0
- package/lib/raw_types_schemats/sens.ts +2907 -0
- package/lib/scripts/convert_data.d.ts +1 -0
- package/lib/scripts/convert_data.js +354 -0
- package/lib/scripts/convert_data.mjs +181 -0
- package/lib/scripts/convert_data.ts +243 -0
- package/lib/scripts/data-download.d.ts +1 -0
- package/lib/scripts/data-download.js +12 -0
- package/lib/scripts/datautil.d.ts +8 -0
- package/lib/scripts/datautil.js +34 -0
- package/lib/scripts/datautil.mjs +16 -0
- package/lib/scripts/datautil.ts +19 -0
- package/lib/scripts/images/transparent_150x192.jpg +0 -0
- package/lib/scripts/images/transparent_155x225.jpg +0 -0
- package/lib/scripts/parse_textes.d.ts +1 -0
- package/lib/scripts/parse_textes.js +44 -0
- package/lib/scripts/parse_textes.mjs +46 -0
- package/lib/scripts/parse_textes.ts +65 -0
- package/lib/scripts/retrieve_agenda.d.ts +1 -0
- package/lib/scripts/retrieve_agenda.js +132 -0
- package/lib/scripts/retrieve_cr_commission.d.ts +1 -0
- package/lib/scripts/retrieve_cr_commission.js +364 -0
- package/lib/scripts/retrieve_cr_seance.d.ts +6 -0
- package/lib/scripts/retrieve_cr_seance.js +347 -0
- package/lib/scripts/retrieve_documents.d.ts +3 -0
- package/lib/scripts/retrieve_documents.js +219 -0
- package/lib/scripts/retrieve_documents.mjs +249 -0
- package/lib/scripts/retrieve_documents.ts +298 -0
- package/lib/scripts/retrieve_open_data.d.ts +1 -0
- package/lib/scripts/retrieve_open_data.js +315 -0
- package/lib/scripts/retrieve_open_data.mjs +217 -0
- package/lib/scripts/retrieve_open_data.ts +268 -0
- package/lib/scripts/retrieve_senateurs_photos.d.ts +1 -0
- package/lib/scripts/retrieve_senateurs_photos.js +147 -0
- package/lib/scripts/retrieve_senateurs_photos.mjs +147 -0
- package/lib/scripts/retrieve_senateurs_photos.ts +177 -0
- package/lib/scripts/retrieve_videos.d.ts +1 -0
- package/lib/scripts/retrieve_videos.js +461 -0
- package/lib/scripts/shared/cli_helpers.d.ts +95 -0
- package/lib/scripts/shared/cli_helpers.js +91 -0
- package/lib/scripts/shared/cli_helpers.ts +36 -0
- package/lib/scripts/shared/util.d.ts +4 -0
- package/lib/scripts/shared/util.js +35 -0
- package/lib/scripts/shared/util.ts +33 -0
- package/lib/scripts/test_iter_load.d.ts +1 -0
- package/lib/scripts/test_iter_load.js +12 -0
- package/lib/src/conversion_textes.js +10 -1
- package/lib/src/index.d.ts +1 -1
- package/lib/src/index.js +1 -1
- package/lib/src/loaders.d.ts +1 -0
- package/lib/src/loaders.js +1 -0
- package/lib/src/parsers/texte.js +2 -2
- package/lib/src/scripts/convert_data.js +11 -10
- package/lib/src/scripts/retrieve_documents.d.ts +1 -1
- package/lib/src/scripts/retrieve_documents.js +25 -10
- package/lib/src/scripts/retrieve_open_data.js +1 -1
- package/lib/src/types/sessions.d.ts +5 -4
- package/lib/src/types/sessions.js +10 -75
- package/lib/src/types/texte.d.ts +2 -0
- package/lib/strings.d.ts +1 -0
- package/lib/strings.js +18 -0
- package/lib/strings.mjs +18 -0
- package/lib/strings.ts +26 -0
- package/lib/types/agenda.d.ts +44 -0
- package/lib/types/agenda.js +1 -0
- package/lib/types/ameli.d.ts +5 -0
- package/lib/types/ameli.js +1 -0
- package/lib/types/ameli.mjs +13 -0
- package/lib/types/ameli.ts +21 -0
- package/lib/types/compte_rendu.d.ts +83 -0
- package/lib/types/compte_rendu.js +1 -0
- package/lib/types/debats.d.ts +2 -0
- package/lib/types/debats.js +1 -0
- package/lib/types/debats.mjs +2 -0
- package/lib/types/debats.ts +6 -0
- package/lib/types/dosleg.d.ts +70 -0
- package/lib/types/dosleg.js +1 -0
- package/lib/types/dosleg.mjs +151 -0
- package/lib/types/dosleg.ts +284 -0
- package/lib/types/questions.d.ts +2 -0
- package/lib/types/questions.js +1 -0
- package/lib/types/questions.mjs +1 -0
- package/lib/types/questions.ts +3 -0
- package/lib/types/sens.d.ts +10 -0
- package/lib/types/sens.js +1 -0
- package/lib/types/sens.mjs +1 -0
- package/lib/types/sens.ts +12 -0
- package/lib/types/sessions.d.ts +5 -0
- package/lib/types/sessions.js +84 -0
- package/lib/types/sessions.mjs +43 -0
- package/lib/types/sessions.ts +42 -0
- package/lib/types/texte.d.ts +74 -0
- package/lib/types/texte.js +16 -0
- package/lib/types/texte.mjs +16 -0
- package/lib/types/texte.ts +76 -0
- package/lib/typings/windows-1252.d.js +2 -0
- package/lib/typings/windows-1252.d.mjs +2 -0
- package/lib/typings/windows-1252.d.ts +11 -0
- package/lib/utils/cr_spliting.d.ts +28 -0
- package/lib/utils/cr_spliting.js +265 -0
- package/lib/utils/date.d.ts +10 -0
- package/lib/utils/date.js +100 -0
- package/lib/utils/nvs-timecode.d.ts +7 -0
- package/lib/utils/nvs-timecode.js +79 -0
- package/lib/utils/reunion_grouping.d.ts +9 -0
- package/lib/utils/reunion_grouping.js +361 -0
- package/lib/utils/reunion_odj_building.d.ts +5 -0
- package/lib/utils/reunion_odj_building.js +154 -0
- package/lib/utils/reunion_parsing.d.ts +23 -0
- package/lib/utils/reunion_parsing.js +209 -0
- package/lib/utils/scoring.d.ts +14 -0
- package/lib/utils/scoring.js +147 -0
- package/lib/utils/string_cleaning.d.ts +7 -0
- package/lib/utils/string_cleaning.js +57 -0
- package/lib/validators/config.d.ts +9 -0
- package/lib/validators/config.js +10 -0
- package/lib/validators/config.mjs +54 -0
- package/lib/validators/config.ts +79 -0
- package/lib/validators/senat.d.ts +0 -0
- package/lib/validators/senat.js +28 -0
- package/lib/validators/senat.mjs +24 -0
- package/lib/validators/senat.ts +26 -0
- package/package.json +5 -5
|
@@ -0,0 +1,196 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,240 @@
|
|
|
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]
|
|
@@ -0,0 +1,7 @@
|
|
|
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";
|
|
@@ -0,0 +1,7 @@
|
|
|
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";
|
|
@@ -0,0 +1,5 @@
|
|
|
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";
|
|
@@ -0,0 +1,15 @@
|
|
|
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"
|
|
@@ -0,0 +1,45 @@
|
|
|
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 {};
|
|
@@ -0,0 +1,89 @@
|
|
|
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
|
+
}
|