Build, validate, and index web-optimized GeoJSON precinct, school district, etc. files for state repos
Project description
civic-geo-generator
Lightweight CLI and library to build web-optimized GeoJSON for election precincts (and similar layers).
Outputs three artifacts per run:
- full GeoJSON (QA and reproducibility)
- web GeoJSON (served to apps)
- TopoJSON (optional, for smaller delivery)
It also writes per-version metadata.json, and a state index.json that points to the latest layer.
Installation
pip install civic-geo-generator
Quick start
# install deps
uv sync --extra dev --extra docs --upgrade
# orchestrated runs based on yaml file
uv run civic-gen run -f inputs.yaml
# or provide a specific state and view
uv run civic-gen run MN precincts
Conventions
- Batch inputs live in
inputs.yaml. - Config files live under
data-config/(e.g.,us/mn/precincts.yaml). - Data input files should be placed in the
data-infolder, organized by state and layer as described in YAML configs (e.g.,data-config/us/mn/precincts.yaml). - Outputs are written under
data-out/us/<state-name>/<view>/<version>/.
Links
- Source: https://github.com/civic-interconnect/civic-geo-generator
- Issues: https://github.com/civic-interconnect/civic-geo-generator/issues
Pipeline
Place statewide GeoJSON input in correct location, e.g.
- data-in/us/mn/precincts_2025-04.json
Configure inputs.yaml, e.g.
# inputs.yaml (batch mode)
runs:
- state: MN
views: [precincts]
version_overrides:
precincts: "2025-04"
# 1) Build (copy/normalize/add snapshot metadata)
civic-gen build --version 2025-04
# 2) Validate (CRS, required columns, geometry, basic uniqueness)
civic-gen validate --version 2025-04
# 3) Index (flat index, manifest, state layer pointers)
civic-gen index
Development
See DEVELOPER.md
Available: Minnesota Precincts
They include voting precinct boundaries as well as the name, county, and election districts (US Congress, MN Senate and House, County Commissioner) for each precinct.
Geojson files are intended to provide basic information regarding the location of election districts within the state. For the most accurate information on precincts and districts, as well as polling place information, please use the Polling Place Finder.
Minnesota precincts - April 2025 (6225 KB json)
| Congressional District | as of April 2025 |
|---|---|
| District 1 (southern Minnesota) | C.D. 1 (1062 KB json) |
| District 2 (south Metro) | C.D. 2 (383 KB json) |
| District 3 (greater Hennepin County) | C.D. 3 (341 KB json) |
| District 4 (Ramsey County and suburbs) | C.D. 4 (217 KB json) |
| District 5 (Minneapolis and suburbs) | C.D. 5 (171 KB json) |
| District 6 (northwestern Metro, St Cloud area) | C.D. 6 (578 KB json) |
| District 7 (western Minnesota) | C.D. 7 (1760 KB json) |
| District 8 (northeastern Minnesota) | C.D. 8 (1720 KB json) |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file civic_geo_generator-0.1.3.tar.gz.
File metadata
- Download URL: civic_geo_generator-0.1.3.tar.gz
- Upload date:
- Size: 169.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3b18c5b98a42a26cab21d2195e4019e0990f020338d6677fe99faa75c97725d4
|
|
| MD5 |
899117f335f398b991642af885b56ff1
|
|
| BLAKE2b-256 |
d419a28ce2f6ec410bef24c585eb6c41b55b184469bea0a38fbc059c2ce0fbdf
|
Provenance
The following attestation bundles were made for civic_geo_generator-0.1.3.tar.gz:
Publisher:
release.yml on civic-interconnect/civic-geo-generator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
civic_geo_generator-0.1.3.tar.gz -
Subject digest:
3b18c5b98a42a26cab21d2195e4019e0990f020338d6677fe99faa75c97725d4 - Sigstore transparency entry: 685243820
- Sigstore integration time:
-
Permalink:
civic-interconnect/civic-geo-generator@d38de6d3ab667c83e2f9969a41afc9d23f9b0579 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/civic-interconnect
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d38de6d3ab667c83e2f9969a41afc9d23f9b0579 -
Trigger Event:
push
-
Statement type:
File details
Details for the file civic_geo_generator-0.1.3-py3-none-any.whl.
File metadata
- Download URL: civic_geo_generator-0.1.3-py3-none-any.whl
- Upload date:
- Size: 26.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
35f0f2106df89bb8c1ea6b3183f5d92b334e5f14e6b05f61bcd31b73c2e64b05
|
|
| MD5 |
5d2f989de4f3c18cd9396e79443c0c79
|
|
| BLAKE2b-256 |
1478e3f6160cea91378f3d565b38a52c9a0a7fbd6ee8c2319b96d5f37763421e
|
Provenance
The following attestation bundles were made for civic_geo_generator-0.1.3-py3-none-any.whl:
Publisher:
release.yml on civic-interconnect/civic-geo-generator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
civic_geo_generator-0.1.3-py3-none-any.whl -
Subject digest:
35f0f2106df89bb8c1ea6b3183f5d92b334e5f14e6b05f61bcd31b73c2e64b05 - Sigstore transparency entry: 685243821
- Sigstore integration time:
-
Permalink:
civic-interconnect/civic-geo-generator@d38de6d3ab667c83e2f9969a41afc9d23f9b0579 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/civic-interconnect
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d38de6d3ab667c83e2f9969a41afc9d23f9b0579 -
Trigger Event:
push
-
Statement type: