# precinct-mapper
A Python Package to preprocess precinct and district geodata and make it easy to query.
# To run in DEVELOPMENT
1. make sure you have Jupyter and ipykernel installed
2. create a conda environment (-f flag specifies file): `conda env create -f env.yaml`. This will create a conda environment called 'precinct_env'
3. activate that environment: `conda activate precinct_env`
# To run in PRODUCTION
1. create a virtual environment `python -m venv venv`
2. then activate it `source venv/bin/activate`
3. pip install precinct_mapper `pip install git+https://github.com/clear-vote/precinct-mapper.git`
4. Save it all to requirements.txt `pip freeze > requirements.txt` *in the virtual environment*
5. issue the following commands...
```
from precinct_mapper.mapper import load_state
state_obj = load_state()
json = state_obj.lookup_lat_lon(-122.3328, 47.6061)
print(json['county'].name)
```
## SSH Config (so you can modify AWS code locally)
Insert the following ssh code
1. Ask for the key (keep it somewhere safe)
2. Add the following SSH info to your config
> Host flask-app-ec2
> HostName ec2-35-88-126-46.us-west-2.compute.amazonaws.com
> User ubuntu
> IdentityFile <your-key-name-here>
## (we are moving away from this) Restarting for production on AWS EC2 instance
1. Restart and enable the flaskapp: `sudo systemctl restart flaskapp && sudo systemctl enable flaskapp`
2. Check the localhost `curl -v http://localhost:8000`
3. Check the IP `curl http://35.88.126.46/?longitude=0&latitude=0`... *Always append http:// before any IP!*
4. (optional) If you ever change the public IP, make sure to update it in the flaskapp configuration at /etc/nginx/sites-available/flaskapp
5. (optional) reload the configurations and restart nginx. You can also modify gunicorn /etc/systemd/system/flaskapp.service
## Lambda
1. Run the following
cp lambda_function.py my-deployment-package/
cp -r venv/lib/python3.x/site-packages/* my-deployment-package/
2. Push to GH
3. Download zip from GH
4. Deploy via AWS Lambda
## TODO
Amazon RDS (Relational Database Service): To host your MySQL database.
Amazon S3: To store static assets or backup data if needed.
AWS IAM (Identity and Access Management): To manage access and permissions securely.
Add this route and test with different coordinates:
```python
from flask import Flask, request, jsonify
from your_module import state_obj # Import your state_obj from the appropriate module
app = Flask(__name__)
@app.route('/lookup', methods=['GET'])
def lookup_lat_lon():
# Get coordinates from query parameters
coordinate_1 = request.args.get('coordinate_1')
coordinate_2 = request.args.get('coordinate_2')
if not coordinate_1 or not coordinate_2:
return jsonify({'error': 'Missing coordinates'}), 400
try:
# Run the command with the provided coordinates
result = state_obj.lookup_lat_lon(coordinate_1, coordinate_2)
return jsonify(result)
except Exception as e:
return jsonify({'error': str(e)}), 500
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5000)
```
Raw data
{
"_id": null,
"home_page": "https://github.com/clear-vote/precinct-mapper",
"name": "precinct-mapper",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0.0,>=3.11.7",
"maintainer_email": null,
"keywords": "precinct, geodata, geopandas, boundary, districts",
"author": "Anaya Pandit",
"author_email": "anaya.pandit7924@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/1e/75/10ec0d6b58fd16c288af0e817dd0db4076e6d672859b32ae5dfe75fb8353/precinct_mapper-0.2.1.tar.gz",
"platform": null,
"description": "# precinct-mapper\nA Python Package to preprocess precinct and district geodata and make it easy to query.\n\n# To run in DEVELOPMENT\n1. make sure you have Jupyter and ipykernel installed\n2. create a conda environment (-f flag specifies file): `conda env create -f env.yaml`. This will create a conda environment called 'precinct_env'\n3. activate that environment: `conda activate precinct_env`\n\n# To run in PRODUCTION\n1. create a virtual environment `python -m venv venv`\n2. then activate it `source venv/bin/activate`\n3. pip install precinct_mapper `pip install git+https://github.com/clear-vote/precinct-mapper.git`\n4. Save it all to requirements.txt `pip freeze > requirements.txt` *in the virtual environment*\n5. issue the following commands...\n```\nfrom precinct_mapper.mapper import load_state\nstate_obj = load_state()\njson = state_obj.lookup_lat_lon(-122.3328, 47.6061)\nprint(json['county'].name)\n\n```\n\n## SSH Config (so you can modify AWS code locally)\nInsert the following ssh code\n1. Ask for the key (keep it somewhere safe)\n2. Add the following SSH info to your config\n> Host flask-app-ec2\n> HostName ec2-35-88-126-46.us-west-2.compute.amazonaws.com\n> User ubuntu\n> IdentityFile <your-key-name-here>\n\n## (we are moving away from this) Restarting for production on AWS EC2 instance\n1. Restart and enable the flaskapp: `sudo systemctl restart flaskapp && sudo systemctl enable flaskapp`\n2. Check the localhost `curl -v http://localhost:8000`\n3. Check the IP `curl http://35.88.126.46/?longitude=0&latitude=0`... *Always append http:// before any IP!*\n4. (optional) If you ever change the public IP, make sure to update it in the flaskapp configuration at /etc/nginx/sites-available/flaskapp\n5. (optional) reload the configurations and restart nginx. You can also modify gunicorn /etc/systemd/system/flaskapp.service\n\n## Lambda\n1. Run the following\ncp lambda_function.py my-deployment-package/\ncp -r venv/lib/python3.x/site-packages/* my-deployment-package/\n2. Push to GH\n3. Download zip from GH\n4. Deploy via AWS Lambda\n\n## TODO\nAmazon RDS (Relational Database Service): To host your MySQL database.\nAmazon S3: To store static assets or backup data if needed.\nAWS IAM (Identity and Access Management): To manage access and permissions securely.\n\nAdd this route and test with different coordinates:\n```python\nfrom flask import Flask, request, jsonify\nfrom your_module import state_obj # Import your state_obj from the appropriate module\n\napp = Flask(__name__)\n\n@app.route('/lookup', methods=['GET'])\ndef lookup_lat_lon():\n # Get coordinates from query parameters\n coordinate_1 = request.args.get('coordinate_1')\n coordinate_2 = request.args.get('coordinate_2')\n \n if not coordinate_1 or not coordinate_2:\n return jsonify({'error': 'Missing coordinates'}), 400\n \n try:\n # Run the command with the provided coordinates\n result = state_obj.lookup_lat_lon(coordinate_1, coordinate_2)\n return jsonify(result)\n except Exception as e:\n return jsonify({'error': str(e)}), 500\n\nif __name__ == '__main__':\n app.run(host='0.0.0.0', port=5000)\n```\n\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A Python Package to preprocess voting precinct and district geodata and make it easy to query. Currently restricted to WA state.",
"version": "0.2.1",
"project_urls": {
"Homepage": "https://github.com/clear-vote/precinct-mapper",
"Repository": "https://github.com/clear-vote/precinct-mapper"
},
"split_keywords": [
"precinct",
" geodata",
" geopandas",
" boundary",
" districts"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "2173ff81d09318fd84925beeb734e96142fbc884ca693fe03b441803006aa8f1",
"md5": "22ed8f58992c07e214fac243c5e26398",
"sha256": "f3c0af95036cf47c56c2a4113a0780e48c2d7a44a674a241478d91b4f45091b8"
},
"downloads": -1,
"filename": "precinct_mapper-0.2.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "22ed8f58992c07e214fac243c5e26398",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0.0,>=3.11.7",
"size": 16104,
"upload_time": "2024-10-01T05:08:40",
"upload_time_iso_8601": "2024-10-01T05:08:40.125347Z",
"url": "https://files.pythonhosted.org/packages/21/73/ff81d09318fd84925beeb734e96142fbc884ca693fe03b441803006aa8f1/precinct_mapper-0.2.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1e7510ec0d6b58fd16c288af0e817dd0db4076e6d672859b32ae5dfe75fb8353",
"md5": "5a5f6da95ca6a593aa2067a0f7dce7ea",
"sha256": "b768956596cde119558a683529fdc812a19d681c7b35cee0be7191e62483d7aa"
},
"downloads": -1,
"filename": "precinct_mapper-0.2.1.tar.gz",
"has_sig": false,
"md5_digest": "5a5f6da95ca6a593aa2067a0f7dce7ea",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0.0,>=3.11.7",
"size": 14417,
"upload_time": "2024-10-01T05:08:41",
"upload_time_iso_8601": "2024-10-01T05:08:41.573913Z",
"url": "https://files.pythonhosted.org/packages/1e/75/10ec0d6b58fd16c288af0e817dd0db4076e6d672859b32ae5dfe75fb8353/precinct_mapper-0.2.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-01 05:08:41",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "clear-vote",
"github_project": "precinct-mapper",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "precinct-mapper"
}