A dynamic geospatial platform that enhances farm operations management.
This full-stack, server-side rendered (SSR) dashboard is updated with real-time data, that gives farm program managers a birds-eye view of farmer engagement metrics (farmer demographics, crop types, geo-mapped farm parcels, and other rich contextual information), allowing them to effectively communicate KPIs to institutional partners, and other vested stakeholders.
Username - guest@avg-dashboard.com
Password - jungleFever
-
Live Heat-Map Visualization The landing page showcases a real-time Mapbox GL JS 'heat-map' that dynamically updates as new farm programs are added via the backend.
-
Geospatial Data Rendering Engine We've created a proprietary geospatial data rendering engine that intelligently displays relevant map features and data based on the user's viewing context, map bounds, and zoom level. This ensures smooth rendering of tens of thousands of data points without browser crashes.
-
Virtual Asset Title (VAT) Framework Our innovative VAT framework accurately documents the location and metadata of informal, unstructured assets like farmlands. It conforms to the Nigeria Society of Surveyors plot survey standards.
-
React Component Widgets We've developed React component widgets to display insights on various farm operations, including yield, harvest, profitability, and real-time resource deployments. Our approach follows company-wide standards, emphasizing federated React components, Redux state management, and GIS data warehousing best practices.
-
Event-Driven Infrastructure Our architecture leverages websockets to provide near real-time visualization of farmer on-boarding data, including biometric and geospatial information. This enhances coordination between managers and field staff and eliminates oversight duplication.
-
Performance Optimization We've achieved a 60% reduction in dashboard load time through critical asset pre-loading, geojson resource caching, and non-critical resource sourcing from Content Delivery Networks (CDNs).
-
AWS Cloud Deployment Our platform is deployed on the AWS cloud using CI/CD strategies. We leverage AWS services like EC2, S3, and RDS to ensure high availability, scalability, and reliability. Integration with services like DynamoDB, Lambda, and Elastic Load Balancing optimizes performance and cost-efficiency.
Step-by-step for deploying a Docker image of the app on an AWS EC2 instance
- The whole app is rendered server-side. Backend code resides in
server/
, and the frontend is served viaserver/public/src/
- The main entry point for the Express server is
server/server.js
- This app consists of just 2 page routes:
/landing
and/dashboard
- The main JavaScript module scripts for both pages are in
public/src/js/landing.js
andpublic/src/js/dashboard.js
respectively - All the HTML for the both pages is served up via server-side rendered
PUG
templates viaserver/routes/view-routes
- The landing page HTML is served from
landing.pug
andlanding-index.pug
- The dashboard SPA HTML is served from
dashboard.pug
anddashboard-index.pug
- Clone the Github repo from
git clone https://github.com/monolithgoon/avg-dashboard.git
- Ensure you have Docker Compose installed locally.
- Copy the
.env.compose
file and rename it to.env
in the root of the mono-repo. This file contains default environment variable definitions. - To run the platform using our pre-built Docker images, execute the following command:
docker-compose -f docker-compose.demo.yml up
(Note: it uses the latest images pre-built automatically from the head of the master branch using GitHub CI/CD.) - If you want to build everything, including code and Docker images, locally, run:
docker-compose up
(Note: this process may take a considerable amount of time. The option above is much faster.) Be patient; it might take some time for our API to seed fake data in the database during the first Docker Compose run, even if you used pre-built Docker images. - Open
http://localhost:4200
in your browser
- PostgreSQL - Primary Database
- Pgweb - Cross-platform client for PostgreSQL databases, available on http://localhost:8081
- Dejavu - Web UI for ElasticSearch, available on http://localhost:1358
- MinIO - Multi-Cloud Object Storage (AWS S3 compatible)
- Jitsu - An open-source Segment alternative. Fully-scriptable data ingestion engine for modern data teams
- Redis - In-memory data store/caching (also used by Jitsu).
- Request for a Github personal access token for
https:github.com/monolithgoon/
from the developer - Clone the app code to your local machine
git clone https://github.com/monolithgoon/avg-dashboard.git
- Install the
package.json
dependencies by runningnpm install
- Build an obfuscated version of the main app entry code
dashboard.js
by running 'npm run build:secure` - In order to make the most proprietary code for the dashboard app difficult to copy, an obfuscated version of
dashboard.js
first needs to be built locally, and then commited to the Github repo. Do this by runningnpm run build
. You'll find the built script in/public/dist/jquery-2.3.1.slim.min
. Finally, make sure the module script the HTML is pointing to at the bottom ofdashboard.pug
is the bundled & obfuscatedjquery-2.3.1.slim.min.js
file, and not the originaldashboard.js
file
- Request for the
avg.pem
key from the admin. - Connect via SSH to the AWS EC2 Ubuntu machine From the directory where the
avg.pem
key is located, runssh -i "avg.pem" ubuntu@ec2-54-225-80-233.compute-1.amazonaws.com
- Navigate to the application directory
cd /apps
cd /avg-dashboard
Instructions for setting up essential environment variables required for the project. Replace the placeholders (e.g., *****
) with the actual values relevant to your setup.
NODE_ENV=production
ATLAS_DB_STRING=*****
ATLAS_DB_PASSOWRD=*****
GEOCLUSTERS_DASHBOARD_PORT=9090
AUTO_LAND_SUBDIVISION_HOST_URL=http://51.20.26.23:9443
JWT_SECRET=*****
JWT_EXPIRES_IN_DAYS=3600000
JWT_COOKIE_EXPIRES_IN_DAYS=1
EMAIL_HOST=smtp.mailtrap.io
MAILTRAP_PORT=2525
MAILTRAP_USERNAME=*****
MAILTRAP_PASSWORD=*****
CLOUDINARY_URL=*****
To run the app in development
mode, create a file called development.env
in the /server
directory, set the Node.js environment variable to NODE_ENV=development
, and load the variables with the dotenv
package
Keep these values secure and do not expose them in public repositories.
NODE_ENV=production
Set the Node.js environment to "production" in your server or application configuration for production deployments.
GEOCLUSTERS_DASHBOARD_PORT=9090
To specify the port number where this app will run, set the GEOCLUSTERS_DASHBOARD_PORT
environment variable. This value is used by the configuration file located at /server/config/config.js
ATLAS_DB_STRING=*****
Visit the MongoDB Atlas website. Log in or create an account, and create a new cluster or select an existing one. Locate the connection string for your MongoDB cluster and replace *****
with the actual connection string.
ATLAS_DB_PASSWORD=*****
Use the password associated with your MongoDB Atlas cluster.
AUTO_LAND_SUBDIVISION_HOST_URL=http://51.20.26.23:9443
The URL where the Auto Land Subdivision service is hosted. Keep this as is. It's currently being hosted on an AWS EC2 instance. If this isn't working, ask the admin for a working link.
JWT_SECRET=*****
Generate a strong and secure secret key for JWT (JSON Web Tokens). It's used for authentication and authorization. Replace *****
with your secret key.
JWT_EXPIRES_IN_DAYS=3600000
JWT_COOKIE_EXPIRES_IN_DAYS=1
These values determine the expiration time for JWT tokens. Adjust them as needed for your application.
EMAIL_HOST=smtp.mailtrap.io
MAILTRAP_PORT=2525
MAILTRAP_USERNAME=*****
MAILTRAP_PASSWORD=*****
Visit the Mailtrap website. Sign in or create an account, and create a new project. In your project settings, you'll find the SMTP host, port, username, and password. Replace the placeholders (*****
) with these values.
CLOUDINARY_URL=*****
Visit the Cloudinary website. Log in or create an account, and obtain your Cloudinary API URL and replace *****
with the actual URL.
Because the main maps for the dashboard are rendered on the frontend, the API tokens required can't be added to, or read from the server environment variables in the /server/production.env
file.
Instead, add the map provider API tokens to this file /server/public/js/src/constants/maps-api-tokens.js
In production, do not use the map provider API tokens included in this code repository. They are for development only
The /landing
page uses Mapbox GL JS only.
The /dashboard
page uses 2 mapping providers: Bing Maps for the main centerfold map that renders all the clusters, and Mapbox GL JS for the right sidebar, cluster plot features sidebar map.
To get a Mapbox GL JS API token, you can follow these steps:
- Go to the Mapbox website
- Create a free account or sign in if you already have one
- Go to the Access Tokens page
- Generate a new access token and give it a descriptive name
To get a Bing Maps token, you can follow these steps:
- Go to the Bing Maps Dev Center website
- Create a free account or sign in if you already have one
- Go to the My Account page
- Create- a new Bing Maps key and give it a descriptive name
Add the following block to your NGINX configuration file (/etc/nginx/sites-available/geoclusters_dashboard
):
server {
listen 80;
server_name 51.20.7.129;
root /var/www/geoclusters_dashboard;
index index.html;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
location / {
proxy_pass http://localhost:9090;
proxy_http_version 1.1;
}
location /landing/ {
proxy_pass http://localhost:9090;
proxy_http_version 1.1;
}
location /api/ {
proxy_pass http://localhost:9090/api/;
proxy_http_version 1.1;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
error_page 404 /404.html;
location = /404.html {
root /var/www/geoclusters_dashboard;
}
access_log /var/log/nginx/geoclusters_dashboard_access.log;
error_log /var/log/nginx/geoclusters_dashboard_error.log;
}
Create a symbolic link in the `sites-enabled` directory:
```bash
sudo ln -s /etc/nginx/sites-available/geoclusters_dashboard /etc/nginx/sites-enabled/
```
Before applying changes, verify the syntax and configuration:
```bash
sudo nginx -t
```
Ensure the output confirms a successful test.
If the configuration test passes, restart NGINX to apply the changes:
```bash
sudo systemctl restart nginx
```
- Access the application in your browser via `http://51.20.7.129/landing` to confirm it loads correctly.