@tricoteuses/senat 3.1.3 → 3.1.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.
Files changed (81) hide show
  1. package/lib/src/config.d.ts +43 -0
  2. package/lib/src/config.js +37 -0
  3. package/lib/src/conversion_textes.d.ts +11 -0
  4. package/lib/src/conversion_textes.js +320 -0
  5. package/lib/src/databases_postgres.d.ts +4 -0
  6. package/lib/src/databases_postgres.js +23 -0
  7. package/lib/src/datasets.d.ts +38 -0
  8. package/lib/src/datasets.js +247 -0
  9. package/lib/src/git.d.ts +27 -0
  10. package/lib/src/git.js +251 -0
  11. package/lib/src/loaders.d.ts +52 -0
  12. package/lib/src/loaders.js +260 -0
  13. package/lib/src/model/agenda.d.ts +6 -0
  14. package/lib/src/model/agenda.js +148 -0
  15. package/lib/src/model/ameli.d.ts +67 -0
  16. package/lib/src/model/ameli.js +150 -0
  17. package/lib/src/model/commission.d.ts +19 -0
  18. package/lib/src/model/commission.js +269 -0
  19. package/lib/src/model/debats.d.ts +39 -0
  20. package/lib/src/model/debats.js +112 -0
  21. package/lib/src/model/documents.d.ts +32 -0
  22. package/lib/src/model/documents.js +182 -0
  23. package/lib/src/model/dosleg.d.ts +144 -0
  24. package/lib/src/model/dosleg.js +468 -0
  25. package/lib/src/model/index.d.ts +7 -0
  26. package/lib/src/model/index.js +7 -0
  27. package/lib/src/model/questions.d.ts +54 -0
  28. package/lib/src/model/questions.js +91 -0
  29. package/lib/src/model/scrutins.d.ts +48 -0
  30. package/lib/src/model/scrutins.js +121 -0
  31. package/lib/src/model/seance.d.ts +3 -0
  32. package/lib/src/model/seance.js +267 -0
  33. package/lib/src/model/sens.d.ts +112 -0
  34. package/lib/src/model/sens.js +385 -0
  35. package/lib/src/model/util.d.ts +1 -0
  36. package/lib/src/model/util.js +15 -0
  37. package/lib/src/raw_types/ameli.d.ts +1762 -0
  38. package/lib/src/raw_types/ameli.js +1074 -0
  39. package/lib/src/raw_types/debats.d.ts +380 -0
  40. package/lib/src/raw_types/debats.js +266 -0
  41. package/lib/src/raw_types/dosleg.d.ts +2954 -0
  42. package/lib/src/raw_types/dosleg.js +2005 -0
  43. package/lib/src/raw_types/questions.d.ts +699 -0
  44. package/lib/src/raw_types/questions.js +493 -0
  45. package/lib/src/raw_types/sens.d.ts +7843 -0
  46. package/lib/src/raw_types/sens.js +4691 -0
  47. package/lib/src/raw_types_schemats/ameli.d.ts +541 -0
  48. package/lib/src/raw_types_schemats/ameli.js +2 -0
  49. package/lib/src/raw_types_schemats/debats.d.ts +127 -0
  50. package/lib/src/raw_types_schemats/debats.js +2 -0
  51. package/lib/src/raw_types_schemats/dosleg.d.ts +977 -0
  52. package/lib/src/raw_types_schemats/dosleg.js +2 -0
  53. package/lib/src/raw_types_schemats/questions.d.ts +237 -0
  54. package/lib/src/raw_types_schemats/questions.js +2 -0
  55. package/lib/src/raw_types_schemats/sens.d.ts +2709 -0
  56. package/lib/src/raw_types_schemats/sens.js +2 -0
  57. package/lib/src/scripts/data-download.js +16 -9
  58. package/lib/src/scripts/debug_dosleg_query.d.ts +6 -0
  59. package/lib/src/scripts/debug_dosleg_query.js +50 -0
  60. package/lib/src/scripts/retrieve_agenda.js +2 -4
  61. package/lib/src/types/agenda.d.ts +45 -0
  62. package/lib/src/types/agenda.js +1 -0
  63. package/lib/src/types/ameli.d.ts +5 -0
  64. package/lib/src/types/ameli.js +1 -0
  65. package/lib/src/types/compte_rendu.d.ts +83 -0
  66. package/lib/src/types/compte_rendu.js +1 -0
  67. package/lib/src/types/debats.d.ts +2 -0
  68. package/lib/src/types/debats.js +1 -0
  69. package/lib/src/types/dosleg.d.ts +70 -0
  70. package/lib/src/types/dosleg.js +1 -0
  71. package/lib/src/types/questions.d.ts +2 -0
  72. package/lib/src/types/questions.js +1 -0
  73. package/lib/src/types/sens.d.ts +8 -0
  74. package/lib/src/types/sens.js +1 -0
  75. package/lib/src/types/sessions.d.ts +6 -0
  76. package/lib/src/types/sessions.js +19 -0
  77. package/lib/src/types/texte.d.ts +72 -0
  78. package/lib/src/types/texte.js +15 -0
  79. package/lib/src/validators/config.d.ts +9 -0
  80. package/lib/src/validators/config.js +10 -0
  81. package/package.json +1 -1
@@ -0,0 +1,144 @@
1
+ export interface DossierThemeRow {
2
+ libelle: string;
3
+ }
4
+ type DossierAuteurRow = {
5
+ matricule: string | null;
6
+ nom_usuel: string;
7
+ ordre: string | null;
8
+ prenom: string | null;
9
+ qualite: string | null;
10
+ role: string | null;
11
+ };
12
+ type DossierDocumentAnnexeRow = {
13
+ type_document: string;
14
+ url: string | null;
15
+ };
16
+ type DossierTexte = {
17
+ auteurs?: DossierAuteurRow[] | null;
18
+ code_adoption?: string | null;
19
+ code_organisme?: string | null;
20
+ date?: string | null;
21
+ id?: string | null;
22
+ modification?: string | null;
23
+ numero?: number | string | null;
24
+ ordre_origine?: string | null;
25
+ origine?: string | null;
26
+ session?: number | null;
27
+ titre?: string | null;
28
+ type?: string | null;
29
+ url?: string | null;
30
+ };
31
+ type DossierRapport = {
32
+ auteurs?: DossierAuteurRow[] | null;
33
+ code_organisme?: string | null;
34
+ date?: string | null;
35
+ documents_annexes?: DossierDocumentAnnexeRow[] | null;
36
+ id?: string | null;
37
+ numero?: number | string | null;
38
+ session?: number | null;
39
+ sous_titre?: string | null;
40
+ titre?: string | null;
41
+ type?: string | null;
42
+ url?: string | null;
43
+ };
44
+ type DossierDateSeance = {
45
+ date?: string | null;
46
+ };
47
+ type DossierLectureAssemblee = {
48
+ assemblee?: string | null;
49
+ code_organisme?: string | null;
50
+ date_publication_amendements_commission?: string | null;
51
+ date_publication_amendements_seance?: string | null;
52
+ dates_seances?: DossierDateSeance[] | null;
53
+ libelle_organisme?: string | null;
54
+ loi_intitule_modifie?: string | null;
55
+ numero_petite_loi?: number | null;
56
+ ordre_lecture_assemblee?: string | null;
57
+ origine_proposition?: string | null;
58
+ rapports?: DossierRapport[] | null;
59
+ session?: number | null;
60
+ textes?: DossierTexte[] | null;
61
+ url_cr_debats?: string | null;
62
+ url_petite_loi?: string | null;
63
+ };
64
+ type DossierLecture = {
65
+ lectures_assemblee?: DossierLectureAssemblee[] | null;
66
+ libelle?: string | null;
67
+ ordre_lecture?: number | string | null;
68
+ type_lecture?: string | null;
69
+ };
70
+ export interface DossierLegislatifResult {
71
+ code: string | null;
72
+ code_dossier_an: string | null;
73
+ code_nature_dossier: string | null;
74
+ code_organisme_resolution: string | null;
75
+ condition_saisine_CoC: string | null;
76
+ date_decision_CoC: string | null;
77
+ date_opposition_procedure_acceleree: string | null;
78
+ date_procedure_acceleree: string | null;
79
+ date_publication_JO: string | null;
80
+ date_publication_JO_correctif_1: string | null;
81
+ date_publication_JO_correctif_2: string | null;
82
+ date_promulgation: string | null;
83
+ date_retrait_procedure_acceleree: string | null;
84
+ date_saisine_CoC: string | null;
85
+ etat_dossier: string | null;
86
+ lectures: DossierLecture[];
87
+ libelle_decision_CoC: string | null;
88
+ libelle_type_dossier: string | null;
89
+ mot_cle: string | null;
90
+ num_decision_CoC: string | null;
91
+ numero: string | null;
92
+ numero_JO: string | null;
93
+ numero_JO_correctif_1: string | null;
94
+ numero_JO_correctif_2: string | null;
95
+ signet: string;
96
+ signet_alternatif: string | null;
97
+ themes: DossierThemeRow[];
98
+ titre: string | null;
99
+ titre_JO: string;
100
+ titre_court: string | null;
101
+ titre_long: string | null;
102
+ titre_long_original: string | null;
103
+ urgence: string | null;
104
+ url: string;
105
+ url_JO: string | null;
106
+ url_JO_correctif_1: string | null;
107
+ url_JO_correctif_2: string | null;
108
+ url_decision_CoC: string | null;
109
+ url_dossier_assemblee_nationale: string | null;
110
+ url_dossier_CoC: string | null;
111
+ url_ordonnance: string | null;
112
+ url_presentation_articles: string | null;
113
+ }
114
+ export type DossierWithLectures = DossierLegislatifResult & {
115
+ actes_legislatifs?: ActeLegislatif[] | null;
116
+ lectures?: DossierLecture[] | null;
117
+ numero_JO?: string | number | null;
118
+ signet: string;
119
+ themes?: DossierThemeRow[] | null;
120
+ url_JO?: string | null;
121
+ url_decision_CoC?: string | null;
122
+ url_dossier_CoC?: string | null;
123
+ };
124
+ export type ActeLegislatif = {
125
+ adoption?: string;
126
+ chambre: "AN" | "SN";
127
+ code_acte: string;
128
+ code_organisme: string | null;
129
+ date: string;
130
+ date_publication_JO?: string | null;
131
+ id?: string | null;
132
+ libelle: string;
133
+ numero?: string | number | null;
134
+ numero_JO?: string | number | null;
135
+ session?: number | null;
136
+ signet_dossier: string;
137
+ texte_url?: string | null;
138
+ uid: string;
139
+ url_legifrance?: string | null;
140
+ };
141
+ export declare function findAllDossiers(): AsyncGenerator<DossierLegislatifResult, void, unknown>;
142
+ export declare function getCodeActeLecture(codeNatureDossier: string, typeLecture: string, assemblee: string): string | null;
143
+ export declare function buildActesLegislatifs(dossier: DossierWithLectures): ActeLegislatif[];
144
+ export {};
@@ -0,0 +1,468 @@
1
+ import { streamUnsafeQuery } from "../databases_postgres.js";
2
+ function stripTrailingHashesSql(expr) {
3
+ return `regexp_replace(${expr}, '#+$', '')`;
4
+ }
5
+ function buildAuteursTexteSql(texteIdSql) {
6
+ return `
7
+ (
8
+ select coalesce(json_agg(author_rows order by author_rows.ordre_num nulls last), '[]'::json)
9
+ from (
10
+ select
11
+ auteur.prenom as prenom,
12
+ auteur.nomuse as nom_usuel,
13
+ auteur.autmat as matricule,
14
+ ecr.ecrnumtri::text as ordre,
15
+ ecr.ecrnumtri as ordre_num,
16
+ rolsig.rolsiglib as role,
17
+ ecr.ecrqua as qualite
18
+ from senat.dosleg_auteur as auteur
19
+ left join senat.dosleg_ecr as ecr on ecr.autcod = auteur.autcod
20
+ left join senat.dosleg_rolsig as rolsig on rolsig.signataire = ecr.signataire
21
+ where ecr.texcod = ${texteIdSql}
22
+ ) as author_rows
23
+ )
24
+ `;
25
+ }
26
+ function buildAuteursRapportSql(rapportIdSql) {
27
+ return `
28
+ (
29
+ select coalesce(json_agg(author_rows order by author_rows.ordre_num nulls last), '[]'::json)
30
+ from (
31
+ select
32
+ auteur.prenom as prenom,
33
+ auteur.nomuse as nom_usuel,
34
+ auteur.autmat as matricule,
35
+ ecr.ecrnumtri::text as ordre,
36
+ ecr.ecrnumtri as ordre_num,
37
+ rolsig.rolsiglib as role,
38
+ ecr.ecrqua as qualite
39
+ from senat.dosleg_auteur as auteur
40
+ left join senat.dosleg_ecr as ecr on ecr.autcod = auteur.autcod
41
+ left join senat.dosleg_rolsig as rolsig on rolsig.signataire = ecr.signataire
42
+ where ecr.rapcod = ${rapportIdSql}
43
+ ) as author_rows
44
+ )
45
+ `;
46
+ }
47
+ function buildDocumentsAttachesSql(rapportIdSql) {
48
+ return `
49
+ (
50
+ select coalesce(json_agg(attached_rows), '[]'::json)
51
+ from (
52
+ select
53
+ docatt.docatturl as url,
54
+ typatt.typattlib as type_document
55
+ from senat.dosleg_docatt as docatt
56
+ left join senat.dosleg_typatt as typatt on docatt.typattcod = typatt.typattcod
57
+ where docatt.rapcod = ${rapportIdSql}
58
+ ) as attached_rows
59
+ )
60
+ `;
61
+ }
62
+ function buildTextesSql(lectureAssembleeIdSql) {
63
+ return `
64
+ (
65
+ select coalesce(json_agg(text_rows order by text_rows.ordre_tri nulls last), '[]'::json)
66
+ from (
67
+ select
68
+ texte.texnum as numero,
69
+ texte.orgcod as code_organisme,
70
+ case
71
+ when texte.texurl is not null then
72
+ ${stripTrailingHashesSql("regexp_replace(trim(texte.texurl), '^(.*/)?(.*?)(\\.html)?$', '\\2')")}
73
+ else null
74
+ end as id,
75
+ case
76
+ when texte.typurl = 'I' then
77
+ ${stripTrailingHashesSql("'https://www.senat.fr/leg/' || rtrim(texte.texurl)")}
78
+ else ${stripTrailingHashesSql("rtrim(texte.texurl)")}
79
+ end as url,
80
+ rtrim(oritxt.oritxtlib) as origine,
81
+ oritxt.oriordre as ordre_origine,
82
+ oritxt.oritxtado as code_adoption,
83
+ oritxt.oritxtmod as modification,
84
+ rtrim(typtxt.typtxtlib) as type,
85
+ to_char(texte.txtoritxtdat, 'YYYY-MM-DD') as date,
86
+ texte.sesann::int as session,
87
+ ${buildAuteursTexteSql("texte.texcod")} as auteurs,
88
+ array_position(array['0','2','1'], oritxt.oriordre) as ordre_tri
89
+ from senat.dosleg_texte as texte
90
+ left join senat.dosleg_oritxt as oritxt on oritxt.oritxtcod = texte.oritxtcod
91
+ left join senat.dosleg_typtxt as typtxt on typtxt.typtxtcod = texte.typtxtcod
92
+ where texte.lecassidt = ${lectureAssembleeIdSql}
93
+ ) as text_rows
94
+ )
95
+ `;
96
+ }
97
+ function buildRapportsSql(lectureAssembleeIdSql) {
98
+ return `
99
+ (
100
+ select coalesce(json_agg(report_rows), '[]'::json)
101
+ from (
102
+ select
103
+ rap.rapnum as numero,
104
+ raporg.orgcod as code_organisme,
105
+ case
106
+ when rap.rapurl is not null then
107
+ ${stripTrailingHashesSql("regexp_replace(trim(rap.rapurl), '^(.*/)?(.*?)(\\.html)?$', '\\2')")}
108
+ else null
109
+ end as id,
110
+ case
111
+ when rap.typurl = 'I' then
112
+ ${stripTrailingHashesSql("'https://www.senat.fr/rap/' || rtrim(rap.rapurl)")}
113
+ else ${stripTrailingHashesSql("rtrim(rap.rapurl)")}
114
+ end as url,
115
+ rtrim(denrap.libdenrap) as type,
116
+ rtrim(rtrim(rap.raptil)) as titre,
117
+ rtrim(rtrim(rap.rapsoustit)) as sous_titre,
118
+ to_char(rap.date_depot, 'YYYY-MM-DD') as date,
119
+ rap.sesann::int as session,
120
+ ${buildAuteursRapportSql("rap.rapcod")} as auteurs,
121
+ ${buildDocumentsAttachesSql("rap.rapcod")} as documents_annexes
122
+ from senat.dosleg_rap as rap
123
+ left join senat.dosleg_raporg as raporg on raporg.rapcod = rap.rapcod
124
+ left join senat.dosleg_denrap as denrap on denrap.coddenrap = rap.coddenrap
125
+ left join senat.dosleg_lecassrap as lecassrap on lecassrap.rapcod = rap.rapcod
126
+ where lecassrap.lecassidt = ${lectureAssembleeIdSql}
127
+ ) as report_rows
128
+ )
129
+ `;
130
+ }
131
+ function buildDatesSeancesSql(lectureAssembleeIdSql) {
132
+ return `
133
+ (
134
+ select coalesce(json_agg(date_rows), '[]'::json)
135
+ from (
136
+ select to_char(date_seance.date_s, 'YYYY-MM-DD') as date
137
+ from senat.dosleg_date_seance as date_seance
138
+ where date_seance.lecidt = ${lectureAssembleeIdSql}
139
+ ) as date_rows
140
+ )
141
+ `;
142
+ }
143
+ function buildLecturesAssembleeSql(lectureIdSql) {
144
+ return `
145
+ (
146
+ select coalesce(json_agg(assembly_rows order by assembly_rows.ordre_lecture_assemblee_num nulls last), '[]'::json)
147
+ from (
148
+ select
149
+ rtrim(ass.libass) as assemblee,
150
+ org.orgnom as libelle_organisme,
151
+ org.senorgcod as code_organisme,
152
+ lecass.ordreass::text as ordre_lecture_assemblee,
153
+ lecass.ordreass as ordre_lecture_assemblee_num,
154
+ lecass.sesann::int as session,
155
+ orippr.oripprlib as origine_proposition,
156
+ lecass.ptlnum as numero_petite_loi,
157
+ lecass.ptlurl as url_petite_loi,
158
+ lecass.loiintmod as loi_intitule_modifie,
159
+ lecass.debatsurl as url_cr_debats,
160
+ to_char(lecass.lecassamecomdat, 'YYYY-MM-DD') as date_publication_amendements_commission,
161
+ to_char(lecass.lecassamedat, 'YYYY-MM-DD') as date_publication_amendements_seance,
162
+ ${buildTextesSql("lecass.lecassidt")} as textes,
163
+ ${buildRapportsSql("lecass.lecassidt")} as rapports,
164
+ ${buildDatesSeancesSql("lecass.lecassidt")} as dates_seances
165
+ from senat.dosleg_lecass as lecass
166
+ left join senat.dosleg_ass as ass on ass.codass = lecass.codass
167
+ left join senat.dosleg_org as org on org.orgcod = lecass.orgcod
168
+ left join senat.dosleg_orippr as orippr on orippr.oripprcod = lecass.orippr
169
+ where lecass.lecidt = ${lectureIdSql}
170
+ ) as assembly_rows
171
+ )
172
+ `;
173
+ }
174
+ function buildLecturesSql(loiIdSql) {
175
+ return `
176
+ (
177
+ select coalesce(json_agg(lecture_rows order by lecture_rows.ordre_lecture_num nulls last), '[]'::json)
178
+ from (
179
+ select
180
+ rtrim(typlec.typleclib) as type_lecture,
181
+ rtrim(lecture.leccom) as libelle,
182
+ typlec.typlecord::text as ordre_lecture,
183
+ typlec.typlecord as ordre_lecture_num,
184
+ ${buildLecturesAssembleeSql("lecture.lecidt")} as lectures_assemblee
185
+ from senat.dosleg_lecture as lecture
186
+ left join senat.dosleg_typlec as typlec on typlec.typleccod = lecture.typleccod
187
+ where lecture.loicod = ${loiIdSql}
188
+ ) as lecture_rows
189
+ )
190
+ `;
191
+ }
192
+ function buildThemesSql(loiIdSql) {
193
+ return `
194
+ (
195
+ select coalesce(json_agg(theme_rows), '[]'::json)
196
+ from (
197
+ select the.thelib as libelle
198
+ from senat.dosleg_the as the
199
+ left join senat.dosleg_loithe as loithe on loithe.thecle = the.thecle
200
+ where loithe.loicod = ${loiIdSql}
201
+ ) as theme_rows
202
+ )
203
+ `;
204
+ }
205
+ function buildFindAllDossiersQuery() {
206
+ return {
207
+ params: [],
208
+ query: `
209
+ select
210
+ rtrim(loi.loicod) as code,
211
+ loi.numero,
212
+ loi.signet,
213
+ nullif(regexp_replace(loi.url_an, '^.*\\/(DL[^\\/]+)\\.asp$', '\\1'), '') as code_dossier_an,
214
+ loi.signetalt as signet_alternatif,
215
+ rtrim(loi.motclef) as mot_cle,
216
+ rtrim(loi.loient) as titre_court,
217
+ rtrim(typloi.typloiden) || ' ' || rtrim(loi.loitit) as titre,
218
+ rtrim(typloi.typloiden) || ' ' || rtrim(loi.loiint) as titre_long,
219
+ rtrim(typloi.typloiden) || ' ' || rtrim(loi.loiintori) as titre_long_original,
220
+ 'https://www.senat.fr/dossier-legislatif/' || loi.signet || '.html' as url,
221
+ loi.urgence,
222
+ rtrim(typloi.groupe) as code_nature_dossier,
223
+ rtrim(typloi.typloilib) as libelle_type_dossier,
224
+ rtrim(etaloi.etaloilib) as etat_dossier,
225
+ loi.url_an as url_dossier_assemblee_nationale,
226
+ loi.url_presart as url_presentation_articles,
227
+ loi.url_ordonnance as url_ordonnance,
228
+ loi.orgcod as code_organisme_resolution,
229
+ deccoc.deccoclib as libelle_decision_CoC,
230
+ to_char(loi.date_decision, 'YYYY-MM-DD') as date_decision_CoC,
231
+ loi.num_decision as num_decision_CoC,
232
+ loi.deccocurl as url_decision_CoC,
233
+ loi.doscocurl as url_dossier_CoC,
234
+ to_char(loi.saisine_date, 'YYYY-MM-DD') as date_saisine_CoC,
235
+ loi.saisine_par as condition_saisine_CoC,
236
+ to_char(loi.proaccdat, 'YYYY-MM-DD') as date_procedure_acceleree,
237
+ to_char(loi.proaccoppdat, 'YYYY-MM-DD') as date_opposition_procedure_acceleree,
238
+ to_char(loi.retproaccdat, 'YYYY-MM-DD') as date_retrait_procedure_acceleree,
239
+ to_char(loi.date_loi, 'YYYY-MM-DD') as date_promulgation,
240
+ case
241
+ when loi.loititjo is not null then rtrim(typloi.typloiden) || ' ' || rtrim(loi.loititjo)
242
+ else ''
243
+ end as titre_JO,
244
+ to_char(loi.loidatjo, 'YYYY-MM-DD') as date_publication_JO,
245
+ loi.loinumjo as numero_JO,
246
+ loi.url_jo as url_JO,
247
+ to_char(loi.loidatjo2, 'YYYY-MM-DD') as date_publication_JO_correctif_1,
248
+ loi.loinumjo2 as numero_JO_correctif_1,
249
+ loi.url_jo2 as url_JO_correctif_1,
250
+ to_char(loi.loidatjo3, 'YYYY-MM-DD') as date_publication_JO_correctif_2,
251
+ loi.loinumjo3 as numero_JO_correctif_2,
252
+ loi.url_jo3 as url_JO_correctif_2,
253
+ ${buildLecturesSql("loi.loicod")} as lectures,
254
+ ${buildThemesSql("loi.loicod")} as themes
255
+ from senat.dosleg_loi as loi
256
+ left join senat.dosleg_typloi as typloi on typloi.typloicod = loi.typloicod
257
+ left join senat.dosleg_etaloi as etaloi on etaloi.etaloicod = loi.etaloicod
258
+ left join senat.dosleg_deccoc as deccoc on deccoc.deccoccod = loi.deccoccod
259
+ `,
260
+ };
261
+ }
262
+ export async function* findAllDossiers() {
263
+ const { query, params } = buildFindAllDossiersQuery();
264
+ for await (const row of streamUnsafeQuery(query, params)) {
265
+ if (!row.signet) {
266
+ continue;
267
+ }
268
+ yield {
269
+ ...row,
270
+ signet: row.signet,
271
+ lectures: row.lectures ?? [],
272
+ themes: row.themes ?? [],
273
+ };
274
+ }
275
+ }
276
+ export function getCodeActeLecture(codeNatureDossier, typeLecture, assemblee) {
277
+ const codeAssemblee = assemblee === "Sénat" ? "SN" : assemblee === "Assemblée nationale" ? "AN" : null;
278
+ if (typeLecture === "Commission mixte paritaire") {
279
+ return "CMP";
280
+ }
281
+ if (!codeAssemblee) {
282
+ return null;
283
+ }
284
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Première lecture") {
285
+ return `${codeAssemblee}1`;
286
+ }
287
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Deuxième lecture") {
288
+ return `${codeAssemblee}2`;
289
+ }
290
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Troisième lecture") {
291
+ return `${codeAssemblee}3`;
292
+ }
293
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Quatrième lecture") {
294
+ return `${codeAssemblee}4`;
295
+ }
296
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Nouvelle lecture") {
297
+ return `${codeAssemblee}NLEC`;
298
+ }
299
+ if (["ppl", "pjl", "cvn"].includes(codeNatureDossier) && typeLecture === "Lecture définitive") {
300
+ return `${codeAssemblee}LDEF`;
301
+ }
302
+ if (["ppr"].includes(codeNatureDossier) && typeLecture === "Première lecture") {
303
+ return `${codeAssemblee}LUNI`;
304
+ }
305
+ return null;
306
+ }
307
+ function getDateSortValue(value) {
308
+ if (!value) {
309
+ return Number.POSITIVE_INFINITY;
310
+ }
311
+ const timestamp = new Date(value).getTime();
312
+ return Number.isNaN(timestamp) ? Number.POSITIVE_INFINITY : timestamp;
313
+ }
314
+ function compareByDate(left, right) {
315
+ return getDateSortValue(left.date) - getDateSortValue(right.date);
316
+ }
317
+ function getPhasePrefix(lecture, assemblee) {
318
+ if (assemblee !== "Sénat")
319
+ return null;
320
+ const typeLibelle = (lecture.type_lecture || "").toLowerCase();
321
+ if (typeLibelle.includes("cmp") || typeLibelle.includes("mixte"))
322
+ return "CMP";
323
+ if (typeLibelle.includes("nouvelle lecture"))
324
+ return "SNNLEC";
325
+ if (typeLibelle.includes("définitive"))
326
+ return "SNLDEF";
327
+ if (typeLibelle.includes("unique"))
328
+ return "SNLUNI";
329
+ if (lecture.ordre_lecture) {
330
+ return `SN${lecture.ordre_lecture}`;
331
+ }
332
+ if (typeLibelle.includes("première"))
333
+ return "SN1";
334
+ if (typeLibelle.includes("deuxième") || typeLibelle.includes("seconde"))
335
+ return "SN2";
336
+ return "SN1";
337
+ }
338
+ export function buildActesLegislatifs(dossier) {
339
+ const actes = [];
340
+ const loiSignet = dossier.signet;
341
+ const lectures = dossier.lectures ?? [];
342
+ for (const lecture of lectures) {
343
+ const lecturesAssemblee = lecture.lectures_assemblee ?? [];
344
+ for (const lecAss of lecturesAssemblee) {
345
+ if (lecAss.assemblee !== "Sénat")
346
+ continue;
347
+ const phasePrefix = getPhasePrefix(lecture, lecAss.assemblee);
348
+ if (!phasePrefix)
349
+ continue;
350
+ const textes = lecAss.textes ?? [];
351
+ const textesTries = [...textes].sort(compareByDate);
352
+ const depotTexte = textesTries.find((t) => (t.origine || "").toLowerCase().includes("déposé") ||
353
+ (t.origine || "").toLowerCase().includes("transmis") ||
354
+ t.ordre_origine === "0");
355
+ if (depotTexte && depotTexte.date) {
356
+ actes.push({
357
+ code_acte: `${phasePrefix}-DEPOT`,
358
+ date: depotTexte.date,
359
+ libelle: `Dépôt du texte n°${depotTexte.numero}`,
360
+ id: depotTexte.id,
361
+ numero: depotTexte.numero,
362
+ uid: `${loiSignet}-${phasePrefix}-DEPOT`,
363
+ session: lecAss.session,
364
+ chambre: "SN",
365
+ signet_dossier: loiSignet,
366
+ texte_url: depotTexte.url,
367
+ code_organisme: null,
368
+ });
369
+ }
370
+ const rapports = lecAss.rapports ?? [];
371
+ for (const rap of rapports) {
372
+ if (rap.date) {
373
+ actes.push({
374
+ code_acte: `${phasePrefix}-COM-FOND`,
375
+ date: rap.date,
376
+ libelle: `Rapport n°${rap.numero} de la commission`,
377
+ id: rap.id,
378
+ numero: rap.numero,
379
+ code_organisme: rap.code_organisme ?? null,
380
+ uid: `${loiSignet}-${phasePrefix}-COM`,
381
+ session: lecAss.session,
382
+ chambre: "SN",
383
+ signet_dossier: loiSignet,
384
+ texte_url: rap.url,
385
+ });
386
+ }
387
+ }
388
+ const datesSeances = lecAss.dates_seances ?? [];
389
+ if (datesSeances.length > 0) {
390
+ datesSeances.sort(compareByDate);
391
+ const premiereSeance = datesSeances[0];
392
+ if (premiereSeance && premiereSeance.date) {
393
+ actes.push({
394
+ code_acte: `${phasePrefix}-DEBATS-SEANCE`,
395
+ date: premiereSeance.date,
396
+ libelle: "Discussion en séance publique",
397
+ id: null,
398
+ uid: `${loiSignet}-${phasePrefix}-DEBATS-SEANCE`,
399
+ session: lecAss.session,
400
+ chambre: "SN",
401
+ signet_dossier: loiSignet,
402
+ code_organisme: null,
403
+ });
404
+ }
405
+ }
406
+ const texteFinal = [...textesTries].reverse().find((t) => {
407
+ const origine = (t.origine || "").toLowerCase();
408
+ return (origine.includes("adopté") ||
409
+ origine.includes("rejeté") ||
410
+ origine.includes("devenu résolution") ||
411
+ t.code_adoption === "O");
412
+ });
413
+ if (texteFinal && texteFinal.date) {
414
+ const origine = (texteFinal.origine || "").toLowerCase();
415
+ let libelleStatut = "Adopté";
416
+ if (origine.includes("rejeté")) {
417
+ libelleStatut = "Rejeté";
418
+ }
419
+ else if (origine.includes("devenue résolution")) {
420
+ libelleStatut = "Adopté";
421
+ }
422
+ actes.push({
423
+ code_acte: `${phasePrefix}-DEBATS-DEC`,
424
+ date: texteFinal.date,
425
+ libelle: `${libelleStatut === "Adopté" ? "Adoption" : "Rejet"} (Texte n°${texteFinal.numero})`,
426
+ id: texteFinal.id,
427
+ numero: texteFinal.numero,
428
+ adoption: libelleStatut,
429
+ uid: `${loiSignet}-DEC-${texteFinal.numero}`,
430
+ session: lecAss.session,
431
+ chambre: "SN",
432
+ signet_dossier: loiSignet,
433
+ texte_url: texteFinal.url,
434
+ code_organisme: null,
435
+ });
436
+ }
437
+ }
438
+ }
439
+ if (dossier.date_decision_CoC) {
440
+ actes.push({
441
+ code_acte: "CC",
442
+ date: dossier.date_decision_CoC,
443
+ libelle: "Décision du Conseil constitutionnel",
444
+ id: dossier.url_decision_CoC,
445
+ uid: `${loiSignet}-CC`,
446
+ chambre: "AN",
447
+ signet_dossier: loiSignet,
448
+ code_organisme: null,
449
+ texte_url: dossier.url_decision_CoC || dossier.url_dossier_CoC,
450
+ });
451
+ }
452
+ if (dossier.date_promulgation) {
453
+ actes.push({
454
+ code_acte: "PROM",
455
+ date: dossier.date_promulgation,
456
+ libelle: "Promulgation de la loi",
457
+ date_publication_JO: dossier.date_publication_JO,
458
+ numero_JO: dossier.numero_JO,
459
+ url_legifrance: dossier.url_JO,
460
+ id: dossier.url_JO,
461
+ uid: `${loiSignet}-PROM`,
462
+ chambre: "AN",
463
+ signet_dossier: loiSignet,
464
+ code_organisme: null,
465
+ });
466
+ }
467
+ return actes.sort(compareByDate);
468
+ }
@@ -0,0 +1,7 @@
1
+ export { findAllAmendements } from "./ameli.js";
2
+ export { findAll as findAllDebats } from "./debats.js";
3
+ export { findAllDossiers } from "./dosleg.js";
4
+ export { findAllTextes, findAllRapports } from "./documents.js";
5
+ export { findAllScrutins } from "./scrutins.js";
6
+ export { findAll as findAllQuestions } from "./questions.js";
7
+ export { findAll as findAllSens, findAllCirconscriptions, findAllOrganismes } from "./sens.js";
@@ -0,0 +1,7 @@
1
+ export { findAllAmendements } from "./ameli.js";
2
+ export { findAll as findAllDebats } from "./debats.js";
3
+ export { findAllDossiers } from "./dosleg.js";
4
+ export { findAllTextes, findAllRapports } from "./documents.js";
5
+ export { findAllScrutins } from "./scrutins.js";
6
+ export { findAll as findAllQuestions } from "./questions.js";
7
+ export { findAll as findAllSens, findAllCirconscriptions, findAllOrganismes } from "./sens.js";
@@ -0,0 +1,54 @@
1
+ export interface QuestionReponseRow {
2
+ date_erratum_JO: string | null;
3
+ date_reponse_JO: string | null;
4
+ ministere_reponse: string | null;
5
+ ministere_reponse_id: string | null;
6
+ page_JO: string | null;
7
+ texte: string | null;
8
+ texte_erratum: string | null;
9
+ url: string | null;
10
+ }
11
+ export interface QuestionResult {
12
+ circonscription: string | null;
13
+ circonscription_numero: string | null;
14
+ civilite: string | null;
15
+ date_cloture: string | null;
16
+ date_erratum_JO: string | null;
17
+ date_publication_JO: string | null;
18
+ date_reponse_JO: string | null;
19
+ date_signalement: string | null;
20
+ date_transmission: string | null;
21
+ etat_code: string | null;
22
+ etat_libelle: string | null;
23
+ etat_tri: string | null;
24
+ groupe: string | null;
25
+ legislature: string | null;
26
+ matricule: string;
27
+ ministere_depot: string | null;
28
+ ministere_depot_date_debut: string | null;
29
+ ministere_depot_id: string | null;
30
+ ministere_reponse: string | null;
31
+ ministere_transmission: string | null;
32
+ nature: string | null;
33
+ nature_libelle: string | null;
34
+ nom: string | null;
35
+ nom_technique: string | null;
36
+ numero: string | null;
37
+ page_JO: string | null;
38
+ page_erratum_JO: string | null;
39
+ prenom: string | null;
40
+ reference: string | null;
41
+ reference_question_rappelee: string | null;
42
+ republique: string | null;
43
+ reponses: QuestionReponseRow[];
44
+ rubrique: string | null;
45
+ sort: string | null;
46
+ sort_code: string | null;
47
+ sort_tri: string | null;
48
+ texte: string | null;
49
+ texte_erratum: string | null;
50
+ themes: string[];
51
+ titre: string | null;
52
+ type_appartenance: string | null;
53
+ }
54
+ export declare function findAll(): AsyncGenerator<QuestionResult, void, unknown>;