@tricoteuses/senat 2.22.15 → 2.23.0
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/README.md +168 -0
- 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/config.d.ts +22 -0
- package/lib/src/config.js +17 -7
- package/lib/src/conversion_textes.js +5 -1
- package/lib/src/databases.d.ts +2 -1
- package/lib/src/databases_postgres.d.ts +4 -0
- package/lib/src/databases_postgres.js +23 -0
- package/lib/src/datasets.d.ts +4 -0
- package/lib/src/datasets.js +16 -2
- package/lib/src/git.d.ts +1 -0
- package/lib/src/git.js +45 -11
- package/lib/src/loaders.js +10 -4
- package/lib/src/model/agenda.js +2 -2
- package/lib/src/model/ameli.d.ts +64 -52
- package/lib/src/model/ameli.js +147 -145
- package/lib/src/model/ameli_postgres.d.ts +67 -0
- package/lib/src/model/ameli_postgres.js +150 -0
- package/lib/src/model/commission.d.ts +3 -2
- package/lib/src/model/commission.js +2 -2
- package/lib/src/model/debats.d.ts +38 -66
- package/lib/src/model/debats.js +110 -93
- package/lib/src/model/documents.d.ts +32 -12
- package/lib/src/model/documents.js +171 -130
- package/lib/src/model/dosleg.d.ts +142 -5
- package/lib/src/model/dosleg.js +298 -156
- package/lib/src/model/questions.d.ts +54 -45
- package/lib/src/model/questions.js +89 -87
- package/lib/src/model/scrutins.d.ts +48 -13
- package/lib/src/model/scrutins.js +118 -111
- package/lib/src/model/seance.js +3 -3
- package/lib/src/model/sens.d.ts +109 -179
- package/lib/src/model/sens.js +384 -484
- package/lib/src/model/util.d.ts +0 -8
- package/lib/src/model/util.js +0 -23
- package/lib/src/parsers/texte.js +7 -7
- package/lib/src/raw_types_schemats/ameli.d.ts +4 -2
- package/lib/src/raw_types_schemats/debats.d.ts +2 -2
- package/lib/src/raw_types_schemats/dosleg.d.ts +2 -2
- package/lib/src/raw_types_schemats/questions.d.ts +2 -2
- package/lib/src/raw_types_schemats/sens.d.ts +10 -4216
- package/lib/src/scripts/convert_data.js +7 -6
- package/lib/src/scripts/convert_xml_to_html.js +2 -2
- package/lib/src/scripts/data-download.js +3 -2
- package/lib/src/scripts/retrieve_agenda.js +21 -9
- package/lib/src/scripts/retrieve_cr_commission.js +17 -17
- package/lib/src/scripts/retrieve_cr_seance.d.ts +14 -1
- package/lib/src/scripts/retrieve_cr_seance.js +10 -11
- package/lib/src/scripts/retrieve_documents.d.ts +11 -2
- package/lib/src/scripts/retrieve_documents.js +25 -14
- package/lib/src/scripts/retrieve_open_data.js +400 -145
- package/lib/src/scripts/retrieve_senateurs_photos.js +25 -11
- package/lib/src/scripts/retrieve_videos.js +12 -11
- package/lib/src/scripts/shared/cli_helpers.d.ts +1 -6
- package/lib/src/scripts/shared/cli_helpers.js +9 -8
- package/lib/src/scripts/shared/incremental_import_sql.d.ts +2 -0
- package/lib/src/scripts/shared/incremental_import_sql.js +894 -0
- package/lib/src/scripts/shared/prefixed_tables.d.ts +7 -0
- package/lib/src/scripts/shared/prefixed_tables.js +30 -0
- package/lib/src/scripts/shared/schema_version.d.ts +3 -0
- package/lib/src/scripts/shared/schema_version.js +97 -0
- package/lib/src/scripts/shared/staging_import.d.ts +3 -0
- package/lib/src/scripts/shared/staging_import.js +80 -0
- package/lib/src/scripts/shared/staging_metadata_sql.d.ts +1 -0
- package/lib/src/scripts/shared/staging_metadata_sql.js +221 -0
- package/lib/src/scripts/validate_prefixed_tables.d.ts +1 -0
- package/lib/src/scripts/validate_prefixed_tables.js +102 -0
- package/lib/src/types/texte.d.ts +1 -1
- package/lib/src/utils/cr_spliting.d.ts +9 -6
- package/lib/src/utils/cr_spliting.js +6 -101
- package/lib/src/utils/reunion_odj_building.d.ts +7 -3
- package/lib/src/utils/reunion_parsing.d.ts +2 -1
- package/lib/src/utils/reunion_parsing.js +2 -2
- package/lib/src/videos/match.js +8 -5
- package/lib/src/videos/pipeline.d.ts +6 -2
- package/lib/src/videos/pipeline.js +21 -8
- package/lib/src/videos/search.js +6 -2
- 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/tests/incrementalImportSql.test.d.ts +1 -0
- package/lib/tests/incrementalImportSql.test.js +155 -0
- package/lib/tests/prefixedTables.test.d.ts +1 -0
- package/lib/tests/prefixedTables.test.js +29 -0
- package/lib/tests/schemaVersion.test.d.ts +1 -0
- package/lib/tests/schemaVersion.test.js +23 -0
- package/lib/tests/validatePrefixedTables.test.d.ts +1 -0
- package/lib/tests/validatePrefixedTables.test.js +14 -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 +6 -10
package/README.md
CHANGED
|
@@ -138,6 +138,174 @@ for (const { item: question } of iterLoadSenatQuestions("../senat-data", 17)) {
|
|
|
138
138
|
npm run data:generate_schemas ../senat-data
|
|
139
139
|
```
|
|
140
140
|
|
|
141
|
+
## PostgreSQL import modes
|
|
142
|
+
|
|
143
|
+
`retrieve_open_data.ts` supports two import modes:
|
|
144
|
+
|
|
145
|
+
- default mode: direct import in a single database
|
|
146
|
+
- `--incremental`: separate staging database plus `postgres_fdw` bridge into the target database
|
|
147
|
+
|
|
148
|
+
The default mode is the simplest one and is the one used by the Docker image. The incremental mode is intended for replicated environments where heavy transient work should stay outside the target database.
|
|
149
|
+
|
|
150
|
+
## Incremental PostgreSQL import architecture
|
|
151
|
+
|
|
152
|
+
When `--incremental` is enabled, the open-data SQL import is designed to keep heavy transient work out of the replicated target database.
|
|
153
|
+
|
|
154
|
+
```text
|
|
155
|
+
+-----------------------------------+
|
|
156
|
+
| Source Open Data Senat |
|
|
157
|
+
| ZIP -> SQL dumps |
|
|
158
|
+
+----------------+------------------+
|
|
159
|
+
|
|
|
160
|
+
v
|
|
161
|
+
+-----------------------------------+
|
|
162
|
+
| PostgreSQL staging instance |
|
|
163
|
+
| non-replicated |
|
|
164
|
+
| database: senat_staging |
|
|
165
|
+
| |
|
|
166
|
+
| schemas: |
|
|
167
|
+
| - ameli_staging |
|
|
168
|
+
| - debats_staging |
|
|
169
|
+
| - dosleg_staging |
|
|
170
|
+
| - questions_staging |
|
|
171
|
+
| - sens_staging |
|
|
172
|
+
| |
|
|
173
|
+
| heavy operations: |
|
|
174
|
+
| - raw dump import |
|
|
175
|
+
| - table renaming/prefixing |
|
|
176
|
+
| - staging indexes |
|
|
177
|
+
+----------------+------------------+
|
|
178
|
+
|
|
|
179
|
+
postgres_fdw (read-only bridge)
|
|
180
|
+
|
|
|
181
|
+
v
|
|
182
|
+
+----------------------------------------------------------------------------+
|
|
183
|
+
| PostgreSQL target instance, replicated |
|
|
184
|
+
| database: canutes |
|
|
185
|
+
| |
|
|
186
|
+
| preserved schemas: assemblee, legifrance, ... |
|
|
187
|
+
| updated schema: senat |
|
|
188
|
+
| |
|
|
189
|
+
| lightweight temporary FDW schemas: |
|
|
190
|
+
| - ameli_staging |
|
|
191
|
+
| - debats_staging |
|
|
192
|
+
| - dosleg_staging |
|
|
193
|
+
| - questions_staging |
|
|
194
|
+
| - sens_staging |
|
|
195
|
+
| |
|
|
196
|
+
| final operations only: |
|
|
197
|
+
| - read staging data through postgres_fdw |
|
|
198
|
+
| - incremental merge into canutes.senat |
|
|
199
|
+
| - optional schema alignment when source structure changes |
|
|
200
|
+
+----------------------------------------------------------------------------+
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
At the end of an incremental import:
|
|
204
|
+
|
|
205
|
+
- the target database is `canutes`
|
|
206
|
+
- the target schema is `senat`
|
|
207
|
+
- other schemas in `canutes` are left untouched
|
|
208
|
+
- bulk transient data stays in the staging database
|
|
209
|
+
|
|
210
|
+
## Direct single-database mode
|
|
211
|
+
|
|
212
|
+
Without `--incremental`, the script works directly in the configured target database:
|
|
213
|
+
|
|
214
|
+
- dumps are imported into temporary `*_staging` schemas in that same database
|
|
215
|
+
- the final tables are merged into schema `senat`
|
|
216
|
+
- the temporary staging schemas are dropped at the end
|
|
217
|
+
|
|
218
|
+
This mode is appropriate for:
|
|
219
|
+
|
|
220
|
+
- local development
|
|
221
|
+
- disposable databases
|
|
222
|
+
- the Docker image workflow
|
|
223
|
+
- environments where replication cost is not a concern
|
|
224
|
+
|
|
225
|
+
## Preparing postgres_fdw and database rights
|
|
226
|
+
|
|
227
|
+
This section only applies when using `--incremental`.
|
|
228
|
+
|
|
229
|
+
The target database must be able to connect to the separate staging database with `postgres_fdw`.
|
|
230
|
+
|
|
231
|
+
### Environment variables
|
|
232
|
+
|
|
233
|
+
Set the target connection in `.env`. Add the staging connection only if you use `--incremental`:
|
|
234
|
+
|
|
235
|
+
```bash
|
|
236
|
+
# Target database
|
|
237
|
+
DB_HOST="localhost"
|
|
238
|
+
DB_PORT=5432
|
|
239
|
+
DB_USER="postgres"
|
|
240
|
+
DB_PASSWORD="PASSWORD"
|
|
241
|
+
DB_NAME="canutes"
|
|
242
|
+
|
|
243
|
+
# Separate non-replicated staging database or instance, only for --incremental
|
|
244
|
+
STAGING_DB_HOST="localhost"
|
|
245
|
+
STAGING_DB_PORT=5433
|
|
246
|
+
STAGING_DB_USER="postgres"
|
|
247
|
+
STAGING_DB_PASSWORD="PASSWORD"
|
|
248
|
+
STAGING_DB_NAME="senat_staging"
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
### Typical commands
|
|
252
|
+
|
|
253
|
+
Default direct mode:
|
|
254
|
+
|
|
255
|
+
```bash
|
|
256
|
+
npm run data:retrieve_open_data -- ../senat-data --all
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
Incremental mode with separate staging database:
|
|
260
|
+
|
|
261
|
+
```bash
|
|
262
|
+
npm run data:retrieve_open_data -- ../senat-data --all --incremental
|
|
263
|
+
```
|
|
264
|
+
|
|
265
|
+
### Target database prerequisites
|
|
266
|
+
|
|
267
|
+
On `canutes`, the import role must be able to:
|
|
268
|
+
|
|
269
|
+
- connect to the database
|
|
270
|
+
- create the `postgres_fdw` extension, or reuse it if already installed
|
|
271
|
+
- create and drop FDW servers and user mappings
|
|
272
|
+
- create and drop temporary `*_staging` schemas used for foreign tables
|
|
273
|
+
- create, alter and drop objects inside schema `senat`
|
|
274
|
+
|
|
275
|
+
Typical one-time setup on the target database:
|
|
276
|
+
|
|
277
|
+
```sql
|
|
278
|
+
CREATE EXTENSION IF NOT EXISTS postgres_fdw;
|
|
279
|
+
```
|
|
280
|
+
|
|
281
|
+
### Staging database prerequisites
|
|
282
|
+
|
|
283
|
+
The staging PostgreSQL instance should ideally be outside the replicated cluster.
|
|
284
|
+
|
|
285
|
+
The staging role must be able to:
|
|
286
|
+
|
|
287
|
+
- recreate the `senat_staging` database
|
|
288
|
+
- create schemas and import dumps there
|
|
289
|
+
- create the technical staging indexes
|
|
290
|
+
|
|
291
|
+
The target instance must also be allowed to connect to the staging instance over the network. In practice:
|
|
292
|
+
|
|
293
|
+
- open the staging host and port from the target server
|
|
294
|
+
- allow the staging user in `pg_hba.conf`
|
|
295
|
+
- ensure the staging credentials used in `.env` are valid
|
|
296
|
+
|
|
297
|
+
### Operational note
|
|
298
|
+
|
|
299
|
+
The replicated target still sees a small amount of temporary DDL for FDW objects, but the large dump imports and staging tables remain outside the replicated database. Most replicated volume should therefore come from the real incremental changes applied to `canutes.senat`.
|
|
300
|
+
|
|
301
|
+
## Validation of prefixed SQL imports
|
|
302
|
+
|
|
303
|
+
After importing datasets with prefixed tables in schema `senat`, you can verify that the expected renamed tables exist and still match the generated definitions:
|
|
304
|
+
|
|
305
|
+
```bash
|
|
306
|
+
npm run data:validate_prefixed_tables -- --categories All
|
|
307
|
+
```
|
|
308
|
+
|
|
141
309
|
## Publishing
|
|
142
310
|
|
|
143
311
|
To publish a new version of this package onto npm, bump the package version and publish.
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { Ses, Sub, TxtAmeli } from "./types/ameli";
|
|
2
|
+
import { Debat } from "./types/debats";
|
|
3
|
+
import { Ass, Aud, Auteur, DateSeance, DecCoc, DenRap, DocAtt, Ecr, EtaLoi, LecAss, LecAssRap, Lecture, Loi, Org, OriTxt, Qua, Rap, Scr, Texte, TypAtt, TypLec, TypLoi, TypTxt, TypUrl } from "./types/dosleg";
|
|
4
|
+
import { Question } from "./types/questions";
|
|
5
|
+
export declare const allFollows: string[];
|
|
6
|
+
export declare class Aggregator {
|
|
7
|
+
follow: Set<string>;
|
|
8
|
+
objectByIdByTableName: {
|
|
9
|
+
[name: string]: {
|
|
10
|
+
[id: string]: object;
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
requestedIdsByTableName: {
|
|
14
|
+
[name: string]: Set<string>;
|
|
15
|
+
};
|
|
16
|
+
visitedIdsByTableName: {
|
|
17
|
+
[name: string]: Set<string>;
|
|
18
|
+
};
|
|
19
|
+
constructor(follow: Set<string>);
|
|
20
|
+
addAss(ass: Ass): void;
|
|
21
|
+
addAud(aud: Aud): void;
|
|
22
|
+
addAuteur(auteur: Auteur): void;
|
|
23
|
+
addDateSeance(dateSeance: DateSeance): void;
|
|
24
|
+
addDebat(debat: Debat): void;
|
|
25
|
+
addDeccoc(deccoc: DecCoc): void;
|
|
26
|
+
addDenrap(denrap: DenRap): void;
|
|
27
|
+
addDocatt(docatt: DocAtt): void;
|
|
28
|
+
addEcr(ecr: Ecr): void;
|
|
29
|
+
addEtaloi(etaloi: EtaLoi): void;
|
|
30
|
+
addLecass(lecass: LecAss): void;
|
|
31
|
+
addLecassrap(lecassrap: LecAssRap): void;
|
|
32
|
+
addLecture(lecture: Lecture): void;
|
|
33
|
+
addLoi(loi: Loi): void;
|
|
34
|
+
addOrg(org: Org): void;
|
|
35
|
+
addOritxt(oritxt: OriTxt): void;
|
|
36
|
+
addQua(qua: Qua): void;
|
|
37
|
+
addQuestion(question: Question): void;
|
|
38
|
+
addRap(rap: Rap): void;
|
|
39
|
+
addScr(scr: Scr): void;
|
|
40
|
+
addSes(ses: Ses): void;
|
|
41
|
+
addSub(sub: Sub): void;
|
|
42
|
+
addTexte(texte: Texte): void;
|
|
43
|
+
addTxtAmeli(txtAmeli: TxtAmeli): void;
|
|
44
|
+
addTypatt(typatt: TypAtt): void;
|
|
45
|
+
addTyplec(typlec: TypLec): void;
|
|
46
|
+
addTyploi(typloi: TypLoi): void;
|
|
47
|
+
addTyptxt(typtxt: TypTxt): void;
|
|
48
|
+
addTypurl(typurl: TypUrl): void;
|
|
49
|
+
getAll(): Promise<void>;
|
|
50
|
+
request(tableName: string, id: string): void;
|
|
51
|
+
toJson(): any;
|
|
52
|
+
}
|