@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.
- package/lib/src/config.d.ts +43 -0
- package/lib/src/config.js +37 -0
- package/lib/src/conversion_textes.d.ts +11 -0
- package/lib/src/conversion_textes.js +320 -0
- package/lib/src/databases_postgres.d.ts +4 -0
- package/lib/src/databases_postgres.js +23 -0
- package/lib/src/datasets.d.ts +38 -0
- package/lib/src/datasets.js +247 -0
- package/lib/src/git.d.ts +27 -0
- package/lib/src/git.js +251 -0
- package/lib/src/loaders.d.ts +52 -0
- package/lib/src/loaders.js +260 -0
- package/lib/src/model/agenda.d.ts +6 -0
- package/lib/src/model/agenda.js +148 -0
- package/lib/src/model/ameli.d.ts +67 -0
- package/lib/src/model/ameli.js +150 -0
- package/lib/src/model/commission.d.ts +19 -0
- package/lib/src/model/commission.js +269 -0
- package/lib/src/model/debats.d.ts +39 -0
- package/lib/src/model/debats.js +112 -0
- package/lib/src/model/documents.d.ts +32 -0
- package/lib/src/model/documents.js +182 -0
- package/lib/src/model/dosleg.d.ts +144 -0
- package/lib/src/model/dosleg.js +468 -0
- package/lib/src/model/index.d.ts +7 -0
- package/lib/src/model/index.js +7 -0
- package/lib/src/model/questions.d.ts +54 -0
- package/lib/src/model/questions.js +91 -0
- package/lib/src/model/scrutins.d.ts +48 -0
- package/lib/src/model/scrutins.js +121 -0
- package/lib/src/model/seance.d.ts +3 -0
- package/lib/src/model/seance.js +267 -0
- package/lib/src/model/sens.d.ts +112 -0
- package/lib/src/model/sens.js +385 -0
- package/lib/src/model/util.d.ts +1 -0
- package/lib/src/model/util.js +15 -0
- package/lib/src/raw_types/ameli.d.ts +1762 -0
- package/lib/src/raw_types/ameli.js +1074 -0
- package/lib/src/raw_types/debats.d.ts +380 -0
- package/lib/src/raw_types/debats.js +266 -0
- package/lib/src/raw_types/dosleg.d.ts +2954 -0
- package/lib/src/raw_types/dosleg.js +2005 -0
- package/lib/src/raw_types/questions.d.ts +699 -0
- package/lib/src/raw_types/questions.js +493 -0
- package/lib/src/raw_types/sens.d.ts +7843 -0
- package/lib/src/raw_types/sens.js +4691 -0
- package/lib/src/raw_types_schemats/ameli.d.ts +541 -0
- package/lib/src/raw_types_schemats/ameli.js +2 -0
- package/lib/src/raw_types_schemats/debats.d.ts +127 -0
- package/lib/src/raw_types_schemats/debats.js +2 -0
- package/lib/src/raw_types_schemats/dosleg.d.ts +977 -0
- package/lib/src/raw_types_schemats/dosleg.js +2 -0
- package/lib/src/raw_types_schemats/questions.d.ts +237 -0
- package/lib/src/raw_types_schemats/questions.js +2 -0
- package/lib/src/raw_types_schemats/sens.d.ts +2709 -0
- package/lib/src/raw_types_schemats/sens.js +2 -0
- package/lib/src/scripts/data-download.js +16 -9
- package/lib/src/scripts/debug_dosleg_query.d.ts +6 -0
- package/lib/src/scripts/debug_dosleg_query.js +50 -0
- package/lib/src/scripts/retrieve_agenda.js +2 -4
- package/lib/src/types/agenda.d.ts +45 -0
- package/lib/src/types/agenda.js +1 -0
- package/lib/src/types/ameli.d.ts +5 -0
- package/lib/src/types/ameli.js +1 -0
- package/lib/src/types/compte_rendu.d.ts +83 -0
- package/lib/src/types/compte_rendu.js +1 -0
- package/lib/src/types/debats.d.ts +2 -0
- package/lib/src/types/debats.js +1 -0
- package/lib/src/types/dosleg.d.ts +70 -0
- package/lib/src/types/dosleg.js +1 -0
- package/lib/src/types/questions.d.ts +2 -0
- package/lib/src/types/questions.js +1 -0
- package/lib/src/types/sens.d.ts +8 -0
- package/lib/src/types/sens.js +1 -0
- package/lib/src/types/sessions.d.ts +6 -0
- package/lib/src/types/sessions.js +19 -0
- package/lib/src/types/texte.d.ts +72 -0
- package/lib/src/types/texte.js +15 -0
- package/lib/src/validators/config.d.ts +9 -0
- package/lib/src/validators/config.js +10 -0
- 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>;
|