Merge pull request #4 from joshuasundance-swca/readme
Browse files
README.md
CHANGED
@@ -10,3 +10,59 @@ tags: [geospatial, streamlit, docker]
|
|
10 |
---
|
11 |
|
12 |
# geospatial-data-converter
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
10 |
---
|
11 |
|
12 |
# geospatial-data-converter
|
13 |
+
|
14 |
+
[data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt="License: MIT"](https://opensource.org/licenses/MIT)
|
15 |
+
[data:image/s3,"s3://crabby-images/eee9f/eee9f9577d49cd33e6a891e1a267cd0f189da122" alt="python"](https://www.python.org)
|
16 |
+
data:image/s3,"s3://crabby-images/016e2/016e240b76329006d1b5089482b4c641a109f467" alt="GitHub tag (with filter)"
|
17 |
+
|
18 |
+
[data:image/s3,"s3://crabby-images/0a9bf/0a9bf747ea9b998d2de1fda12a0662b3aec249f9" alt="Push to Docker Hub"](https://github.com/joshuasundance-swca/geospatial-data-converter/actions/workflows/docker-hub.yml)
|
19 |
+
[data:image/s3,"s3://crabby-images/0bfb4/0bfb4911db95afa99ec878f5f89cd0a4f916137c" alt="Docker Image Size (tag)"](https://hub.docker.com/r/joshuasundance/geospatial-data-converter)
|
20 |
+
|
21 |
+
[data:image/s3,"s3://crabby-images/5da8d/5da8d5a85db2fd0d98279c7003f04b1cc945e5ae" alt="Push to HuggingFace Space"](https://github.com/joshuasundance-swca/geospatial-data-converter/actions/workflows/hf-space.yml)
|
22 |
+
[data:image/s3,"s3://crabby-images/129b3/129b387c019ebefca321edf63ccb7c1455614484" alt="Open HuggingFace Space"](https://huggingface.co/spaces/joshuasundance/geospatial-data-converter)
|
23 |
+
|
24 |
+
data:image/s3,"s3://crabby-images/0f451/0f4514226eaaad5f80c235d5f55d13431ca6d0ca" alt="Code Climate maintainability"
|
25 |
+
data:image/s3,"s3://crabby-images/4a0de/4a0de410189c661e266d4d8761eef256a11c5129" alt="Code Climate issues"
|
26 |
+
data:image/s3,"s3://crabby-images/0eb29/0eb295280c7c1c1aff02d65c1e1713cc7c2036ad" alt="Code Climate technical debt"
|
27 |
+
|
28 |
+
[data:image/s3,"s3://crabby-images/65ea5/65ea56a782a92978a9d1c30ea7b56b2bd4e42d2a" alt="pre-commit"](https://github.com/pre-commit/pre-commit)
|
29 |
+
[data:image/s3,"s3://crabby-images/ef6f2/ef6f2e0b2690ac24aa85b0bbb2b688996b5040f1" alt="Ruff"](https://github.com/charliermarsh/ruff)
|
30 |
+
[data:image/s3,"s3://crabby-images/ae90a/ae90a1b17cdb458fe3d891a0e5eca828a68a1e69" alt="Checked with mypy"](http://mypy-lang.org/)
|
31 |
+
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black)
|
32 |
+
|
33 |
+
[data:image/s3,"s3://crabby-images/d3868/d38687124456935c3cb2c405abeec2715b9372f9" alt="security: bandit"](https://github.com/PyCQA/bandit)
|
34 |
+
data:image/s3,"s3://crabby-images/06e7d/06e7de8891723b6f4a01d790efc4fb3003075be4" alt="Known Vulnerabilities"
|
35 |
+
|
36 |
+
This project showcases a simple geospatial data converter using [Streamlit](https://streamlit.io) and [GeoPandas](https://geopandas.org/).
|
37 |
+
|
38 |
+
# Features
|
39 |
+
- User-friendly interface for easy data conversion
|
40 |
+
- Supports conversion from the following input formats:
|
41 |
+
- ArcGIS featurelayer URL
|
42 |
+
- Uploaded file: KML, KMZ, GeoJSON, ZIP
|
43 |
+
- Provides data in the selected output format
|
44 |
+
- Presents data preview (geometry omitted for display purposes)
|
45 |
+
- Download button for the converted data
|
46 |
+
|
47 |
+
# Deployment
|
48 |
+
`geospatial-data-converter` is deployed as a [Docker image](https://hub.docker.com/r/<your-dockerhub-username>/geospatial-data-converter) based on the `python:3.11-slim-bookworm` image.
|
49 |
+
|
50 |
+
## With Docker (pull from Docker Hub)
|
51 |
+
1. Run in terminal:
|
52 |
+
`docker run -p 8501:8501 <your-dockerhub-username>/geospatial-data-converter:latest`
|
53 |
+
2. Open http://localhost:8501 in your browser
|
54 |
+
|
55 |
+
## Docker Compose (build locally)
|
56 |
+
1. Clone the repo. Navigate to cloned repo directory
|
57 |
+
2. Run in terminal: `docker compose up`
|
58 |
+
3. Open http://localhost:8501 in your browser
|
59 |
+
|
60 |
+
## Kubernetes
|
61 |
+
1. Clone the repo. Navigate to cloned repo directory
|
62 |
+
2. Run bash script: `/bin/bash ./kubernetes/deploy.sh`
|
63 |
+
3. Get the IP address for your new service: `kubectl get service geospatial-data-converter`
|
64 |
+
|
65 |
+
# Links
|
66 |
+
- [Streamlit](https://streamlit.io)
|
67 |
+
- [GeoPandas](https://geopandas.org/)
|
68 |
+
- [Docker Hub](https://hub.docker.com/)
|