This is a webservice showcasing my favorite forests (and a few other places with trees and magical memories).
The service is a super-lightweight showcase of MapBox being used with React/TypeScript, with geographic information served from a SQLite DB via FastAPI/python.
The repo here encapsulates all of this with docker. If deploying something similar in production you'd probably want to seperate these services into something like:
Mapbox / React FastAPI PostgreSQL DB
<------> <------>
Served from CloudFront Hosted on ECS / EC2 Persisted by AWS RDS
To run the service pull the repos to a local machine and build/start the service with docker-compose:
git clone https://github.com/mackdelany/forest-inventory.git
cd forest-inventory
docker-compose up
After a few minutes the service should be on localhost
(http://0.0.0.0)
Simply run the ./run-tests
shell script in the root directory, you may need to make the file executable:
chmod +x ./run-tests.sh
./run-tests.sh
There are approximately 2 million things I'd add/fix, but he's a quick rundown of the most important:
I felt naughty calling a GetAllForests endpoint. Rest assured I wouldn't do this in a normal-and-not-fun-dummy-exercise universe.
I wanted to store GeoJSON in the DB for each forest... then render these in the detail page on MapBox. Run outta time on this one.
I'd use Postgres for the DB. SQLite was great to get going but Postgres is more likely to be used in production.
I would add auth to the DB, and I would store access tokens / auth details / other credentials securely with envorinment variables.
There a bunch of design issues left, it kills me to leave them, but dimishing returns... some of what I would fix though:
- I'd standardize image sizes and widths/heights
- I'd ensure all of the white titles of the images are easily readable (some aren't)
- I'd find/design/procure fun icons for the health metrics
- I'd get someone with fresh eyes to play with the service to find holes... people don't do this enough!
- I'd design/style custom components (where needed) instead of using the bootstrap library the entire time (would also get my code reviewed == best learning in my opinion!)
- I'd use Pachama brand colours / logos / favicons / fonts / iconography -- brand is important!
This one bugged me when I saw it wasn't working in production. I <3 MapBox terrain so it pains me that I messed it up somehow.
I wish I had time to write all of these myself! I also wanted to go dig out old photos of me to use as the images... but alas.
I thought about doing this, but schedules are tight and this is bonus scope..... and it's always good to have engineers that stick to scope right? ;)
Easier said than done this one! ;)
I had 3 unit tests for the server, none for the client. Definitely not optimal test coverage!
In the pursuit of velocity I used SQLite with one table and simple data types, I wouldn't have done this in production. For example, I made forest type a string - which would be error prone (what happens if someone accidently uses Restoration instead of Reforestation?).. this would have been better as an ENUM which was one of the trade offs of using SQLite ie SQLite doesn't have ENUMs but Postgres does.
A few @media css statements would have gone a long way on the detail page!
For example, line 29 in Map.tsx looks like this: zoom: area < 100000 ? 12 : 9,
which clearly is not much help to anyone... I should have noted that this was a hack that worked well for the forests I chose... and that it wasn't a magic formula that would work for future forests.
I <3 simple, short, explainable documentation and fell a little short on my own standards there.
Something simple like 700 t * area would have been more realistic than me tapping random numbers like I did!